एर्लैंग - डेटाबेस

Erlang में SQL Server और Oracle जैसे पारंपरिक डेटाबेस से जुड़ने की क्षमता है। एर्लैंग ने एinbuilt odbc library कि डेटाबेस के साथ काम करने के लिए इस्तेमाल किया जा सकता है।

डेटाबेस कनेक्शन

हमारे उदाहरण में, हम Microsoft SQL सर्वर का उपयोग करने जा रहे हैं। Microsoft SQL सर्वर डेटाबेस से कनेक्ट करने से पहले, सुनिश्चित करें कि निम्न बिंदुओं की जाँच की गई है।

  • आपने एक डेटाबेस बनाया है TESTDB।

  • आपने TESTDB में एक टेबल EMPLOYEE बनाया है।

  • इस तालिका में FIRST_NAME, LAST_NAME, AGE, SEX और INCOME हैं।

  • उपयोगकर्ता ID "testuser" और पासवर्ड "test123" TESTDB तक पहुँचने के लिए निर्धारित हैं।

  • सुनिश्चित करें कि आपने ODBC DSN नाम से बनाया है usersqlserver जो डेटाबेस के लिए एक ODBC कनेक्शन बनाता है

एक कनेक्शन स्थापित करना

डेटाबेस से संबंध स्थापित करने के लिए, निम्नलिखित कोड उदाहरण का उपयोग किया जा सकता है।

Example

-module(helloworld). 
-export([start/0]). 

start() ->
   odbc:start(), 
   {ok, Ref} = odbc:connect("DSN = usersqlserver;UID = testuser;PWD = test123", []), 
   io:fwrite("~p",[Ref]).

उपरोक्त कार्यक्रम का आउटपुट निम्नानुसार है -

Output

<0.33.0>

उपरोक्त कार्यक्रम के बारे में निम्नलिखित बातों पर ध्यान देने की आवश्यकता है।

  • डेटाबेस ऑपरेशन की शुरुआत को इंगित करने के लिए ओडबेक लाइब्रेरी की शुरुआत विधि का उपयोग किया जाता है।

  • कनेक्ट करने के लिए कनेक्ट करने के लिए डीएसएन, यूजर नेम और पासवर्ड की जरूरत है।

एक डेटाबेस तालिका बनाना

डेटाबेस से कनेक्ट करने के बाद अगला कदम हमारे डेटाबेस में टेबल बनाना है। निम्न उदाहरण दिखाता है कि इरलैंग का उपयोग करके डेटाबेस में एक तालिका कैसे बनाई जाए।

Example

-module(helloworld). 
-export([start/0]). 

start() -> 
   odbc:start(), 
   {ok, Ref} = odbc:connect("DSN = usersqlserver; UID = testuser;PWD = test123, []), 
   odbc:sql_query(Ref, "CREATE TABLE EMPLOYEE (FIRSTNAME char varying(20), 
   LASTNAME char varying(20), AGE integer, SEX char(1), INCOME integer)")

यदि आप अब डेटाबेस की जांच करते हैं, तो आप देखेंगे कि एक टेबल कहा जाता है EMPLOYEE उत्पन्न होगा।

डेटाबेस में एक रिकॉर्ड सम्मिलित करना

जब आप अपने रिकॉर्ड को डेटाबेस तालिका में बनाना चाहते हैं तो इसकी आवश्यकता होती है।

निम्न उदाहरण कर्मचारी तालिका में एक रिकॉर्ड सम्मिलित करेगा। यदि तालिका सफलतापूर्वक अपडेट की गई है, तो रिकॉर्ड और स्टेटमेंट अपडेट किए गए रिकॉर्ड के मूल्य और अपडेट किए गए रिकॉर्ड की संख्या वापस कर देंगे।

Example

-module(helloworld). 
-export([start/0]). 

start() -> 
   odbc:start(), 
   {ok, Ref} = odbc:connect("DSN = usersqlserver; UID = testuser;PWD = test123", []), 
   io:fwrite("~p",[odbc:sql_query(Ref, 
   "INSERT INTO EMPLOYEE VALUES('Mac', 'Mohan', 20, 'M', 2000)")]).

उपरोक्त कार्यक्रम का उत्पादन होगा -

Output

{updated,1}

डेटाबेस से रिकॉर्ड प्राप्त करना

Erlang में डेटाबेस से रिकॉर्ड लाने की भी क्षमता है। यह के माध्यम से किया जाता हैsql_query method

एक उदाहरण निम्नलिखित कार्यक्रम में दिखाया गया है -

Example

-module(helloworld). 
-export([start/0]). 

start() ->
   odbc:start(), 
   {ok, Ref} = odbc:connect("DSN = usersqlserver; UID = testuser;PWD = test123", []), 
   io:fwrite("~p",[odbc:sql_query(Ref, "SELECT * FROM EMPLOYEE") ]).

उपरोक्त कार्यक्रम का आउटपुट निम्नानुसार होगा -

Output

{selected,["FIRSTNAME","LASTNAME","AGE","SEX","INCOME"],
[{"Mac","Mohan",20,"M",2000}]}

तो आप देख सकते हैं कि अंतिम अनुभाग में सम्मिलित कमांड ने काम किया और सही कमांड ने सही डेटा वापस किया।

डेटाबेस के आधार पर डेटाबेस से रिकॉर्ड प्राप्त करना

Erlang में डेटाबेस से कुछ फ़िल्टर मानदंडों के आधार पर रिकॉर्ड प्राप्त करने की क्षमता भी है।

एक उदाहरण इस प्रकार है -

Example

-module(helloworld). 
-export([start/0]). 

start() -> 
   odbc:start(), 
   {ok, Ref} = odbc:connect("DSN=usersqlserver; UID=testuser;PWD=test123", []), 
   io:fwrite("~p",[ odbc:param_query(Ref, "SELECT * FROM EMPLOYEE WHERE SEX=?", 
   [{{sql_char, 1}, ["M"]}])]).

उपरोक्त कार्यक्रम का उत्पादन होगा -

Output

{selected,["FIRSTNAME","LASTNAME","AGE","SEX","INCOME"],
         [{"Mac","Mohan",20,"M",2000}]}

डेटाबेस से रिकॉर्ड अपडेट करना

Erlang में डेटाबेस से रिकॉर्ड अपडेट करने की भी क्षमता है।

उसी के लिए एक उदाहरण इस प्रकार है -

Example

-module(helloworld). 
-export([start/0]). 

start() -> 
   odbc:start(), 
   {ok, Ref} = odbc:connect("DSN = usersqlserver; UID = testuser;PWD = test123", []), 
   
   io:fwrite("~p",[ odbc:sql_query(Ref, "
      UPDATE EMPLOYEE SET AGE = 5 WHERE INCOME= 2000")]).

उपरोक्त कार्यक्रम का उत्पादन होगा -

Output

{updated,1}

डेटाबेस से रिकॉर्ड हटाना

Erlang में डेटाबेस से रिकॉर्ड हटाने की भी क्षमता है।

उसी के लिए एक उदाहरण इस प्रकार है -

Example

-module(helloworld). 
-export([start/0]). 

start() -> 
   odbc:start(), 
   {ok, Ref} = odbc:connect("DSN = usersqlserver; UID = testuser;PWD = test123", []), 
   io:fwrite("~p",[ odbc:sql_query(Ref, "DELETE EMPLOYEE WHERE INCOME= 2000")]).

उपरोक्त कार्यक्रम का आउटपुट निम्नानुसार होगा -

Output

{updated,1}

तालिका संरचना

Erlang में एक टेबल संरचना का वर्णन करने की क्षमता भी है।

एक उदाहरण इस प्रकार है -

Example

-module(helloworld). 
-export([start/0]). 

start() -> 
   odbc:start(), 
   {ok, Ref} = odbc:connect("DSN = usersqlserver; UID = testuser;PWD = test123", []), 
   io:fwrite("~p",[odbc:describe_table(Ref, "EMPLOYEE")]).

उपरोक्त कार्यक्रम का आउटपुट निम्नानुसार होगा -

Output

{ok,[{"FIRSTNAME",{sql_varchar,20}},
   {"LASTNAME",{sql_varchar,20}},
   {"AGE",sql_integer},
   {"SEX",{sql_char,1}},
   {"INCOME",sql_integer}]}

गणना रिकॉर्ड करें

एर्लांग में एक तालिका में रिकॉर्ड की कुल गिनती लाने की क्षमता भी है।

उसी के लिए एक उदाहरण निम्नलिखित कार्यक्रम में दिखाया गया है।

Example

-module(helloworld). 
-export([start/0]). 

start() ->
   odbc:start(), 
   {ok, Ref} = odbc:connect("DSN = usersqlserver; UID = sa;PWD = demo123", []), 
   io:fwrite("~p",[odbc:select_count(Ref, "SELECT * FROM EMPLOYEE")]).

उपरोक्त कार्यक्रम का उत्पादन होगा -

{ok,1}