एसएएस - एसक्यूएल

एसएएस कार्यक्रमों के अंदर एसक्यूएल प्रश्नों का उपयोग करके लोकप्रिय लोकप्रिय रिलेशनल डेटाबेस में एसएएस व्यापक समर्थन प्रदान करता है। अधिकतरANSI SQLसिंटैक्स का समर्थन किया जाता है। प्रक्रियाPROC SQLSQL कथनों को संसाधित करने के लिए उपयोग किया जाता है। यह प्रक्रिया न केवल SQL क्वेरी का परिणाम वापस दे सकती है, यह SAS टेबल और चर भी बना सकती है। इन सभी परिदृश्यों का उदाहरण नीचे वर्णित है।

वाक्य - विन्यास

SAS में PROC SQL का उपयोग करने के लिए मूल सिंटैक्स है -

PROC SQL;
SELECT Columns
FROM TABLE
WHERE Columns
GROUP BY Columns
;
QUIT;

निम्नलिखित मापदंडों का वर्णन है -

  • SQL क्वेरी PROC SQL कथन के नीचे QUIT कथन द्वारा लिखी गई है।

नीचे हम देखेंगे कि इस एसएएस प्रक्रिया का उपयोग कैसे किया जा सकता है CRUD SQL में (Create, Read, Update and Delete) ऑपरेशंस।

SQL ऑपरेशन बनाएँ

SQL का उपयोग करके हम नए डेटा सेट फॉर्म को रॉ डेटा बना सकते हैं। नीचे दिए गए उदाहरण में, पहले हम TEMP नाम के एक डेटा सेट की घोषणा करते हैं जिसमें कच्चा डेटा होता है। फिर हम इस डेटा सेट के चर से एक तालिका बनाने के लिए एक SQL क्वेरी लिखते हैं।

DATA TEMP;
INPUT ID $ NAME $ SALARY DEPARTMENT $;
DATALINES;
1 Rick 623.3 IT
2 Dan 515.2 Operations
3 Michelle 611 IT
4 Ryan 729 HR
5 Gary 843.25 Finance
6 Nina 578 IT
7 Simon 632.8 Operations
8 Guru 722.5 Finance
;
RUN;

PROC SQL;
CREATE TABLE EMPLOYEES AS
SELECT * FROM TEMP;
QUIT;

PROC PRINT data = EMPLOYEES;
RUN;

जब उपरोक्त कोड निष्पादित होता है तो हमें निम्नलिखित परिणाम मिलते हैं -

SQL पढ़ें ऑपरेशन

SQL में रीड ऑपरेशन में टेबल से डेटा पढ़ने के लिए SQL SELECT क्वेरीज़ लिखना शामिल है। नीचे दिए गए कार्यक्रम में एसएएस नाम का एसएएस डेटा लाइब्रेरी एसएएसएचईएलपी में उपलब्ध है। क्वेरी डेटा सेट के कुछ कॉलम लाती है।

PROC SQL;
SELECT make,model,type,invoice,horsepower
FROM 
SASHELP.CARS
;
QUIT;

जब उपरोक्त कोड निष्पादित होता है तो हमें निम्नलिखित परिणाम मिलते हैं -

SQL क्‍लर्क के साथ चयन करें

नीचे दिए गए प्रोग्राम में एक के साथ सेट CARS डेटा के बारे में बताया गया है whereखंड। परिणाम में हमें केवल वही अवलोकन मिलता है जो 'ऑडी' के रूप में बनता है और 'स्पोर्ट्स' के रूप में टाइप करता है।

PROC SQL;
SELECT make,model,type,invoice,horsepower
FROM 
SASHELP.CARS
Where make = 'Audi'
and Type = 'Sports'
;
QUIT;

जब उपरोक्त कोड निष्पादित होता है तो हमें निम्नलिखित परिणाम मिलते हैं -

SQL अद्यतन ऑपरेशन

हम SQL अपडेट स्टेटमेंट का उपयोग करके एसएएस टेबल को अपडेट कर सकते हैं। नीचे हम पहले EMPLOYEES2 नाम से एक नई तालिका बनाते हैं और फिर SQL UPDATE स्टेटमेंट का उपयोग करके इसे अपडेट करते हैं।

DATA TEMP;
INPUT ID $ NAME $ SALARY DEPARTMENT $;
DATALINES;
1 Rick 623.3 IT
2 Dan 515.2 Operations
3 Michelle 611 IT
4 Ryan 729 HR
5 Gary 843.25 Finance
6 Nina 578 IT
7 Simon 632.8 Operations
8 Guru 722.5 Finance
;
RUN;

PROC SQL;
CREATE TABLE EMPLOYEES2 AS
SELECT ID as EMPID,
Name as EMPNAME ,
SALARY as SALARY,
DEPARTMENT as DEPT,
SALARY*0.23 as COMMISION
FROM TEMP;
QUIT;

PROC SQL;
UPDATE EMPLOYEES2
      SET SALARY = SALARY*1.25;
   QUIT;
      PROC PRINT data = EMPLOYEES2;
RUN;

जब उपरोक्त कोड निष्पादित होता है तो हमें निम्नलिखित परिणाम मिलते हैं -

SQL DELETE ऑपरेशन

SQL में डिलीट ऑपरेशन में SQL DELETE स्टेटमेंट का उपयोग करके टेबल से कुछ मानों को हटाना शामिल है। हम उपरोक्त उदाहरण से डेटा का उपयोग करना जारी रखते हैं और उस तालिका से पंक्तियों को हटाते हैं जिसमें कर्मचारियों का वेतन 900 से अधिक है।

PROC SQL;
DELETE FROM EMPLOYEES2
      WHERE SALARY > 900;
QUIT;
      PROC PRINT data = EMPLOYEES2;
RUN;

जब उपरोक्त कोड निष्पादित होता है तो हमें निम्नलिखित परिणाम मिलते हैं -