रूबी / डीबीआई ट्यूटोरियल
यह अध्याय आपको सिखाता है कि रूबी का उपयोग करके डेटाबेस तक कैसे पहुँचा जाए। रूबी DBI मॉड्यूल पर्ल DBI मॉड्यूल के समान रूबी स्क्रिप्ट के लिए एक डेटाबेस स्वतंत्र इंटरफेस प्रदान करता है।
डीबीआई रूबी के लिए डेटाबेस इंडिपेंडेंट इंटरफेस के लिए है, जिसका अर्थ है कि डीबीआई रूबी कोड और अंतर्निहित डेटाबेस के बीच एक अमूर्त परत प्रदान करता है, जिससे आप डेटाबेस कार्यान्वयन को वास्तव में आसानी से स्विच कर सकते हैं। यह कई तरीकों, चर, और सम्मेलनों को परिभाषित करता है जो एक सुसंगत डेटाबेस इंटरफ़ेस प्रदान करते हैं, वास्तविक डेटाबेस का स्वतंत्र उपयोग किया जा रहा है।
डीबीआई निम्नलिखित के साथ इंटरफेस कर सकता है -
- ADO (ActiveX डेटा ऑब्जेक्ट)
- DB2
- Frontbase
- mSQL
- MySQL
- ODBC
- Oracle
- OCI8 (Oracle)
- PostgreSQL
- Proxy/Server
- SQLite
- SQLRelay
DBI एप्लिकेशन का आर्किटेक्चर
DBI बैकएंड में उपलब्ध किसी भी डेटाबेस से स्वतंत्र है। आप DBI का उपयोग कर सकते हैं चाहे आप Oracle, MySQL या Informix आदि के साथ काम कर रहे हों, यह निम्नलिखित आर्किटेक्चर आरेख से स्पष्ट है।
रूबी डीबीआई के लिए सामान्य वास्तुकला दो परतों का उपयोग करती है -
डेटाबेस इंटरफ़ेस (DBI) परत। यह परत डेटाबेस स्वतंत्र है और सामान्य एक्सेस विधियों का एक सेट प्रदान करता है जो डेटाबेस सर्वर के प्रकार की परवाह किए बिना उसी तरह से उपयोग किए जाते हैं जिसके साथ आप संवाद कर रहे हैं।
डेटाबेस ड्राइवर (DBD) परत। यह परत डेटाबेस पर निर्भर है; विभिन्न ड्राइवर विभिन्न डेटाबेस इंजनों तक पहुँच प्रदान करते हैं। MySQL के लिए एक ड्राइवर है, PostgreSQL के लिए एक और इंटरबेस के लिए एक और Oracle के लिए एक और इसके बाद का संस्करण है। प्रत्येक ड्राइवर DBI लेयर से अनुरोधों की व्याख्या करता है और उन्हें दिए गए डेटाबेस सर्वर के लिए उपयुक्त अनुरोधों पर मैप करता है।
आवश्यक शर्तें
यदि आप MySQL डेटाबेस तक पहुँचने के लिए रूबी स्क्रिप्ट लिखना चाहते हैं, तो आपको Ruby MySQL मॉड्यूल इंस्टॉल करना होगा।
यह मॉड्यूल ऊपर बताए अनुसार DBD के रूप में कार्य करता है और इससे डाउनलोड किया जा सकता है https://www.tmtm.org/en/mysql/ruby/
रूबी / डीबीआई को प्राप्त करना और स्थापित करना
आप निम्न स्थान से रूबी डीबीआई मॉड्यूल डाउनलोड और स्थापित कर सकते हैं -
https://imgur.com/NFEuWe4/embed
इस स्थापना को शुरू करने से पहले सुनिश्चित करें कि आपके पास रूट विशेषाधिकार है। अब, नीचे दिए गए चरणों का पालन करें -
चरण 1
$ tar zxf dbi-0.2.0.tar.gz
चरण 2
वितरण निर्देशिका में जाएं dbi-0.2.0 nd इसे उस निर्देशिका में setup.rb स्क्रिप्ट का उपयोग करके कॉन्फ़िगर करें । सबसे सामान्य कॉन्फ़िगरेशन कमांड इस तरह दिखता है, जिसमें कॉन्फ़िगरेशन तर्क के बाद कोई तर्क नहीं है। यह आदेश डिफ़ॉल्ट रूप से सभी ड्राइवरों को स्थापित करने के लिए वितरण को कॉन्फ़िगर करता है।
$ ruby setup.rb config
अधिक विशिष्ट होने के लिए, एक - विकल्प प्रदान करें जो आपके द्वारा उपयोग किए जाने वाले वितरण के विशेष भागों को सूचीबद्ध करता है। उदाहरण के लिए, केवल मुख्य DBI मॉड्यूल और MySQL DBD- स्तर ड्राइवर को कॉन्फ़िगर करने के लिए, निम्न कमांड जारी करें -
$ ruby setup.rb config --with = dbi,dbd_mysql
चरण 3
अंतिम चरण ड्राइवर का निर्माण करना है और इसे निम्नलिखित कमांड का उपयोग करके स्थापित करना है -
$ ruby setup.rb setup
$ ruby setup.rb install
डेटाबेस कनेक्शन
यह मानते हुए कि हम MySQL डेटाबेस के साथ काम करने जा रहे हैं, डेटाबेस से कनेक्ट करने से पहले निम्नलिखित सुनिश्चित करें -
आपने एक डेटाबेस बनाया है TESTDB।
आपने TESTDB में EMPLOYEE बनाया है।
इस तालिका में FIRST_NAME, LAST_NAME, AGE, SEX और INCOME फ़ील्ड हैं।
उपयोगकर्ता ID "testuser" और पासवर्ड "test123" TESTDB तक पहुँचने के लिए निर्धारित हैं।
रूबी मॉड्यूल डीबीआई आपकी मशीन पर ठीक से स्थापित है।
आप MySQL बेसिक्स को समझने के लिए MySQL ट्यूटोरियल से गुजरे हैं।
निम्नलिखित MySQL डेटाबेस "TESTDB" से जुड़ने का उदाहरण है
#!/usr/bin/ruby -w
require "dbi"
begin
# connect to the MySQL server
dbh = DBI.connect("DBI:Mysql:TESTDB:localhost", "testuser", "test123")
# get server version string and display it
row = dbh.select_one("SELECT VERSION()")
puts "Server version: " + row[0]
rescue DBI::DatabaseError => e
puts "An error occurred"
puts "Error code: #{e.err}"
puts "Error message: #{e.errstr}"
ensure
# disconnect from server
dbh.disconnect if dbh
end
इस स्क्रिप्ट को चलाते समय, यह हमारे लिनक्स मशीन पर निम्न परिणाम तैयार करता है।
Server version: 5.0.45
यदि डेटा स्रोत के साथ एक कनेक्शन स्थापित किया गया है, तो एक डेटाबेस हैंडल को वापस लौटाया जाता है और इसमें सहेजा जाता है dbh आगे उपयोग के लिए अन्यथा dbhशून्य मान और e.err पर सेट है और e :: क्रमशः त्रुटि त्रुटि कोड और एक त्रुटि स्ट्रिंग।
अंत में, इसे बाहर आने से पहले, सुनिश्चित करें कि डेटाबेस कनेक्शन बंद है और संसाधन जारी किए गए हैं।
INSERT ऑपरेशन
जब आप अपने रिकॉर्ड डेटाबेस तालिका में बनाना चाहते हैं, तो INSERT ऑपरेशन आवश्यक है।
डेटाबेस कनेक्शन स्थापित होने के बाद, हम डेटाबेस तालिकाओं में तालिकाओं या रिकॉर्ड बनाने के लिए तैयार हैं do विधि या prepare तथा execute तरीका।
कथन का उपयोग करना
वे कथन जो पंक्तियों को वापस नहीं लाते हैं उन्हें जारी करके जारी किया जा सकता है doडेटाबेस संभाल विधि। यह विधि एक स्टेटमेंट स्ट्रिंग तर्क लेती है और स्टेटमेंट से प्रभावित पंक्तियों की संख्या की एक गिनती लौटाती है।
dbh.do("DROP TABLE IF EXISTS EMPLOYEE")
dbh.do("CREATE TABLE EMPLOYEE (
FIRST_NAME CHAR(20) NOT NULL,
LAST_NAME CHAR(20),
AGE INT,
SEX CHAR(1),
INCOME FLOAT )" );
इसी तरह, आप EMPLOYEE तालिका में रिकॉर्ड बनाने के लिए SQL INSERT विवरण निष्पादित कर सकते हैं ।
#!/usr/bin/ruby -w
require "dbi"
begin
# connect to the MySQL server
dbh = DBI.connect("DBI:Mysql:TESTDB:localhost", "testuser", "test123")
dbh.do( "INSERT INTO EMPLOYEE(FIRST_NAME, LAST_NAME, AGE, SEX, INCOME)
VALUES ('Mac', 'Mohan', 20, 'M', 2000)" )
puts "Record has been created"
dbh.commit
rescue DBI::DatabaseError => e
puts "An error occurred"
puts "Error code: #{e.err}"
puts "Error message: #{e.errstr}"
dbh.rollback
ensure
# disconnect from server
dbh.disconnect if dbh
end
तैयारी का उपयोग करें और निष्पादित करें
आप रूबी कोड के माध्यम से एसक्यूएल स्टेटमेंट को निष्पादित करने के लिए डीबीआई क्लास के तरीकों को तैयार और निष्पादित कर सकते हैं ।
रिकॉर्ड निर्माण में निम्नलिखित कदम हैं -
INSERT स्टेटमेंट के साथ SQL स्टेटमेंट तैयार करना। यह का उपयोग करके किया जाएगाprepare तरीका।
डेटाबेस से सभी परिणामों का चयन करने के लिए SQL क्वेरी निष्पादित करना। यह का उपयोग करके किया जाएगाexecute तरीका।
स्टेटमेंट हैंडल जारी करना। यह प्रयोग करके किया जाएगाfinish एपीआई
अगर सबकुछ ठीक हो जाता है, तो commit यह ऑपरेशन अन्यथा आप कर सकते हैं rollback पूरा लेन-देन।
इन दो विधियों का उपयोग करने के लिए सिंटैक्स निम्नलिखित है -
sth = dbh.prepare(statement)
sth.execute
... zero or more SQL operations ...
sth.finish
इन दो तरीकों को पारित करने के लिए इस्तेमाल किया जा सकता है bindSQL कथन के लिए मान। ऐसा कोई मामला हो सकता है जब दर्ज किए जाने वाले मान अग्रिम में नहीं दिए गए हों। ऐसे मामले में, बाध्यकारी मूल्यों का उपयोग किया जाता है। एक प्रश्न चिह्न (?) का उपयोग वास्तविक मूल्यों के स्थान पर किया जाता है और फिर वास्तविक मूल्यों को निष्पादन () एपीआई के माध्यम से पारित किया जाता है।
EMPLOYEE तालिका में दो रिकॉर्ड बनाने के लिए निम्नलिखित उदाहरण है -
#!/usr/bin/ruby -w
require "dbi"
begin
# connect to the MySQL server
dbh = DBI.connect("DBI:Mysql:TESTDB:localhost", "testuser", "test123")
sth = dbh.prepare( "INSERT INTO EMPLOYEE(FIRST_NAME, LAST_NAME, AGE, SEX, INCOME)
VALUES (?, ?, ?, ?, ?)" )
sth.execute('John', 'Poul', 25, 'M', 2300)
sth.execute('Zara', 'Ali', 17, 'F', 1000)
sth.finish
dbh.commit
puts "Record has been created"
rescue DBI::DatabaseError => e
puts "An error occurred"
puts "Error code: #{e.err}"
puts "Error message: #{e.errstr}"
dbh.rollback
ensure
# disconnect from server
dbh.disconnect if dbh
end
यदि एक समय में कई INSERT हैं, तो पहले एक स्टेटमेंट तैयार करना और फिर इसे लूप के भीतर हर बार निष्पादित करने की तुलना में कई बार निष्पादित करना लूप के माध्यम से हर बार लागू करने से अधिक कुशल है।
पढ़ें ऑपरेशन
किसी भी डेटाबेस पर पढ़ें ऑपरेशन का मतलब डेटाबेस से कुछ उपयोगी जानकारी प्राप्त करना है।
एक बार हमारा डेटाबेस कनेक्शन स्थापित हो जाने के बाद, हम इस डेटाबेस में एक प्रश्न बनाने के लिए तैयार हैं। हम या तो उपयोग कर सकते हैंdo विधि या prepare तथा execute एक डेटाबेस तालिका से मूल्यों को लाने के तरीके।
रिकॉर्ड लाने के लिए निम्नलिखित कदम उठाए गए हैं -
आवश्यक शर्तों के आधार पर SQL क्वेरी तैयार करना। यह का उपयोग करके किया जाएगाprepare तरीका।
डेटाबेस से सभी परिणामों का चयन करने के लिए SQL क्वेरी निष्पादित करना। यह का उपयोग करके किया जाएगाexecute तरीका।
सभी परिणामों को एक-एक करके प्राप्त करना और उन परिणामों को प्रिंट करना। यह का उपयोग करके किया जाएगाfetch तरीका।
स्टेटमेंट हैंडल जारी करना। यह का उपयोग करके किया जाएगाfinish तरीका।
निम्नलिखित 1000 से अधिक वेतन वाले EMPLOYEE तालिका से सभी रिकॉर्ड को क्वेरी करने की प्रक्रिया है।
#!/usr/bin/ruby -w
require "dbi"
begin
# connect to the MySQL server
dbh = DBI.connect("DBI:Mysql:TESTDB:localhost", "testuser", "test123")
sth = dbh.prepare("SELECT * FROM EMPLOYEE WHERE INCOME > ?")
sth.execute(1000)
sth.fetch do |row|
printf "First Name: %s, Last Name : %s\n", row[0], row[1]
printf "Age: %d, Sex : %s\n", row[2], row[3]
printf "Salary :%d \n\n", row[4]
end
sth.finish
rescue DBI::DatabaseError => e
puts "An error occurred"
puts "Error code: #{e.err}"
puts "Error message: #{e.errstr}"
ensure
# disconnect from server
dbh.disconnect if dbh
end
यह निम्नलिखित परिणाम का उत्पादन करेगा -
First Name: Mac, Last Name : Mohan
Age: 20, Sex : M
Salary :2000
First Name: John, Last Name : Poul
Age: 25, Sex : M
Salary :2300
डेटाबेस से रिकॉर्ड लाने के लिए अधिक शॉर्ट कट तरीके हैं। यदि आप रुचि रखते हैं तो परिणाम प्राप्त करें अन्यथा अगले अनुभाग पर जाएं।
अद्यतन अद्यतन
किसी भी डेटाबेस पर अद्यतन ऑपरेशन का मतलब एक या एक से अधिक रिकॉर्ड को अद्यतन करना है, जो पहले से ही डेटाबेस में उपलब्ध हैं। निम्नलिखित सभी अभिलेखों को 'एम' के रूप में अद्यतन करने की प्रक्रिया है। यहां, हम सभी पुरुषों के एजीई को एक वर्ष तक बढ़ाएंगे। इसके लिए तीन कदम उठाए जाएंगे -
आवश्यक शर्तों के आधार पर SQL क्वेरी तैयार करना। यह का उपयोग करके किया जाएगाprepare तरीका।
डेटाबेस से सभी परिणामों का चयन करने के लिए SQL क्वेरी निष्पादित करना। यह का उपयोग करके किया जाएगाexecute तरीका।
स्टेटमेंट हैंडल जारी करना। यह का उपयोग करके किया जाएगाfinish तरीका।
अगर सब कुछ ठीक रहा तो commit यह ऑपरेशन अन्यथा आप कर सकते हैं rollback पूरा लेन-देन।
#!/usr/bin/ruby -w
require "dbi"
begin
# connect to the MySQL server
dbh = DBI.connect("DBI:Mysql:TESTDB:localhost", "testuser", "test123")
sth = dbh.prepare("UPDATE EMPLOYEE SET AGE = AGE + 1 WHERE SEX = ?")
sth.execute('M')
sth.finish
dbh.commit
rescue DBI::DatabaseError => e
puts "An error occurred"
puts "Error code: #{e.err}"
puts "Error message: #{e.errstr}"
dbh.rollback
ensure
# disconnect from server
dbh.disconnect if dbh
end
DELETE ऑपरेशन
DELETE ऑपरेशन की आवश्यकता तब होती है जब आप अपने डेटाबेस से कुछ रिकॉर्ड हटाना चाहते हैं। निम्नलिखित EMPLOYEE से सभी रिकॉर्ड को हटाने की प्रक्रिया है, जहां AGE 20 से अधिक है। यह ऑपरेशन निम्न चरणों का पालन करेगा।
आवश्यक शर्तों के आधार पर SQL क्वेरी तैयार करना। यह का उपयोग करके किया जाएगाprepare तरीका।
डेटाबेस से आवश्यक रिकॉर्ड को हटाने के लिए SQL क्वेरी निष्पादित करना। यह का उपयोग करके किया जाएगाexecute तरीका।
स्टेटमेंट हैंडल जारी करना। यह का उपयोग करके किया जाएगाfinish तरीका।
अगर सब कुछ ठीक रहा तो commit यह ऑपरेशन अन्यथा आप कर सकते हैं rollback पूरा लेन-देन।
#!/usr/bin/ruby -w
require "dbi"
begin
# connect to the MySQL server
dbh = DBI.connect("DBI:Mysql:TESTDB:localhost", "testuser", "test123")
sth = dbh.prepare("DELETE FROM EMPLOYEE WHERE AGE > ?")
sth.execute(20)
sth.finish
dbh.commit
rescue DBI::DatabaseError => e
puts "An error occurred"
puts "Error code: #{e.err}"
puts "Error message: #{e.errstr}"
dbh.rollback
ensure
# disconnect from server
dbh.disconnect if dbh
end
लेन-देन करना
लेन-देन एक तंत्र है जो डेटा स्थिरता सुनिश्चित करता है। लेनदेन में निम्नलिखित चार गुण होने चाहिए -
Atomicity - या तो लेनदेन पूरा हो जाता है या कुछ भी नहीं होता है।
Consistency - एक लेन-देन एक सुसंगत स्थिति में शुरू होना चाहिए और सिस्टम को छोड़ना एक सुसंगत स्थिति है।
Isolation - लेन-देन के मध्यवर्ती परिणाम वर्तमान लेनदेन के बाहर दिखाई नहीं देते हैं।
Durability - एक बार लेनदेन करने के बाद, सिस्टम की विफलता के बाद भी प्रभाव लगातार बना रहता है।
DBI दो तरीकों या तो करने के लिए प्रदान करता है प्रतिबद्ध या रोलबैक एक सौदे। लेनदेन नामक एक और विधि है जिसका उपयोग लेनदेन को लागू करने के लिए किया जा सकता है। लेनदेन को लागू करने के लिए दो सरल तरीके हैं -
दृष्टिकोण मैं
पहला दृष्टिकोण डीबीआई की प्रतिबद्ध और रोलबैक विधियों का उपयोग लेनदेन को स्पष्ट रूप से करने या रद्द करने के लिए करता है -
dbh['AutoCommit'] = false # Set auto commit to false.
begin
dbh.do("UPDATE EMPLOYEE SET AGE = AGE+1 WHERE FIRST_NAME = 'John'")
dbh.do("UPDATE EMPLOYEE SET AGE = AGE+1 WHERE FIRST_NAME = 'Zara'")
dbh.commit
rescue
puts "transaction failed"
dbh.rollback
end
dbh['AutoCommit'] = true
दृष्टिकोण II
दूसरा दृष्टिकोण लेनदेन पद्धति का उपयोग करता है । यह सरल है, क्योंकि यह एक कोड ब्लॉक करता है जिसमें स्टेटमेंट होते हैं जो लेनदेन करते हैं। लेन-देन विधि ब्लॉक निष्पादित करता है, तो आह्वान प्रतिबद्ध या रोलबैक स्वचालित रूप से, पर ब्लॉक सफल होता है या विफल रहता है कि क्या निर्भर करता है -
dbh['AutoCommit'] = false # Set auto commit to false.
dbh.transaction do |dbh|
dbh.do("UPDATE EMPLOYEE SET AGE = AGE+1 WHERE FIRST_NAME = 'John'")
dbh.do("UPDATE EMPLOYEE SET AGE = AGE+1 WHERE FIRST_NAME = 'Zara'")
end
dbh['AutoCommit'] = true
COMMIT ऑपरेशन
कमिट वह ऑपरेशन है, जो बदलावों को अंतिम रूप देने के लिए डेटाबेस को हरी झंडी देता है और इस ऑपरेशन के बाद कोई भी बदलाव वापस नहीं किया जा सकता है।
यहां कॉल करने के लिए एक सरल उदाहरण है commit तरीका।
dbh.commit
रोलबैक ऑपरेशन
यदि आप एक या अधिक परिवर्तनों से संतुष्ट नहीं हैं और आप उन परिवर्तनों को पूरी तरह से वापस लेना चाहते हैं, तो उपयोग करें rollback तरीका।
यहां कॉल करने के लिए एक सरल उदाहरण है rollback तरीका।
dbh.rollback
डेटाबेस को डिस्कनेक्ट कर रहा है
डेटाबेस कनेक्शन को डिस्कनेक्ट करने के लिए, डिस्कनेक्ट एपीआई का उपयोग करें।
dbh.disconnect
यदि किसी डेटाबेस का कनेक्शन उपयोगकर्ता द्वारा डिस्कनेक्ट विधि से बंद किया जाता है, तो कोई भी बकाया लेनदेन DBI द्वारा वापस ले लिया जाता है। हालांकि, DBI के किसी भी कार्यान्वयन विवरण के आधार पर, आपके आवेदन को कमिट या रोलबैक स्पष्ट रूप से कॉल करना बेहतर होगा।
त्रुटियों को संभालना
त्रुटियों के कई स्रोत हैं। कुछ उदाहरण एक निष्पादित SQL स्टेटमेंट, एक कनेक्शन विफलता, या पहले से रद्द किए गए स्टेटमेंट हैंडल के लिए भ्रूण विधि को कॉल करने में एक सिंटैक्स त्रुटि है।
यदि कोई DBI विधि विफल हो जाती है, तो DBI एक अपवाद उठाता है। DBI विधियाँ किसी भी प्रकार के अपवाद को बढ़ा सकती हैं लेकिन दो सबसे महत्वपूर्ण अपवाद वर्ग DBI :: InterfaceError और DBI :: DatabaseError हैं ।
इन कक्षाओं के अपवाद वस्तुओं नामित तीन गुण अं , errstr , और राज्य है, जो त्रुटि संख्या, एक वर्णनात्मक त्रुटि स्ट्रिंग, और एक मानक त्रुटि कोड का प्रतिनिधित्व करते हैं। विशेषताओं को नीचे समझाया गया है -
err- यदि यह DBD द्वारा समर्थित नहीं है, तो हुई त्रुटि या शून्य का पूर्णांक निरूपण देता है। उदाहरण के लिए Oracle DBD एक ORA-XXXX त्रुटि संदेश का संख्यात्मक भाग लौटाता है ।
errstr - हुई त्रुटि का एक स्ट्रिंग प्रतिनिधित्व लौटाता है।
state- हुई त्रुटि का SQLSTATE कोड लौटाता है। SQLSTATE पांच वर्णों वाली लंबी स्ट्रिंग है। अधिकांश डीबीडी इसका समर्थन नहीं करते हैं और इसके बजाय शून्य लौटाते हैं।
आपने ज्यादातर उदाहरणों में निम्नलिखित कोड देखे हैं -
rescue DBI::DatabaseError => e
puts "An error occurred"
puts "Error code: #{e.err}"
puts "Error message: #{e.errstr}"
dbh.rollback
ensure
# disconnect from server
dbh.disconnect if dbh
end
डिबगिंग जानकारी प्राप्त करने के लिए कि आपकी स्क्रिप्ट क्या निष्पादित कर रही है, आप ट्रेसिंग को सक्षम कर सकते हैं। ऐसा करने के लिए, आपको पहले dbi / ट्रेस मॉड्यूल लोड करना होगा और फिर ट्रेस विधि को कॉल करना चाहिए जो ट्रेस मोड और आउटपुट डेस्टिनेशन को नियंत्रित करता है -
require "dbi/trace"
..............
trace(mode, destination)
मोड मान 0 (ऑफ), 1, 2 या 3 हो सकता है, और गंतव्य एक IO ऑब्जेक्ट होना चाहिए। डिफ़ॉल्ट मान क्रमशः 2 और STDERR हैं।
विधियों के साथ कोड ब्लॉक
कुछ तरीके हैं जो हैंडल बनाते हैं। इन विधियों को एक कोड ब्लॉक के साथ लागू किया जा सकता है। विधियों के साथ कोड ब्लॉक का उपयोग करने का लाभ यह है कि वे कोड ब्लॉक को अपने पैरामीटर के रूप में हैंडल प्रदान करते हैं और ब्लॉक समाप्त होने पर स्वचालित रूप से हैंडल को साफ करते हैं। अवधारणा को समझने के लिए कुछ उदाहरण हैं।
DBI.connect- यह विधि एक डेटाबेस हैंडल उत्पन्न करती है और डेटाबेस को डिस्कनेक्ट करने के लिए ब्लॉक के अंत में डिस्कनेक्ट को कॉल करने की सिफारिश की जाती है ।
dbh.prepare- यह विधि एक स्टेटमेंट हैंडल बनाती है और इसे ब्लॉक के अंत में समाप्त करने की सिफारिश की जाती है । ब्लॉक के भीतर, आपको स्टेटमेंट निष्पादित करने के लिए एग्जीक्यूट विधि को लागू करना होगा ।
dbh.execute- यह विधि समान है सिवाय इसके कि हमें ब्लॉक के भीतर निष्पादित करने की आवश्यकता नहीं है। स्टेटमेंट हैंडल को स्वचालित रूप से निष्पादित किया जाता है।
उदाहरण 1
DBI.connect एक कोड ब्लॉक ले सकता है, डेटाबेस हैंडल को पास करता है, और ब्लॉक के अंत में स्वचालित रूप से हैंडल को डिस्कनेक्ट करता है।
dbh = DBI.connect("DBI:Mysql:TESTDB:localhost", "testuser", "test123") do |dbh|
उदाहरण 2
dbh.prepare एक कोड ब्लॉक ले सकता है, स्टेटमेंट हैंडल को पास करता है, और ब्लॉक के अंत में स्वचालित रूप से कॉल को निम्न प्रकार से कॉल करता है।
dbh.prepare("SHOW DATABASES") do |sth|
sth.execute
puts "Databases: " + sth.fetch_all.join(", ")
end
उदाहरण 3
dbh.execute एक कोड ब्लॉक ले सकता है, स्टेटमेंट हैंडल को पास करता है, और ब्लॉक के अंत में स्वचालित रूप से कॉल को निम्नानुसार पूरा करता है -
dbh.execute("SHOW DATABASES") do |sth|
puts "Databases: " + sth.fetch_all.join(", ")
end
डीबीआई लेनदेन विधि एक कोड ब्लॉक भी लेती है जिसे ऊपर वर्णित किया गया है।
ड्राइवर-विशिष्ट कार्य और गुण
DBI डेटाबेस ड्राइवरों को अतिरिक्त डेटाबेस-विशिष्ट फ़ंक्शन प्रदान करने देता है, जिसे उपयोगकर्ता द्वारा किसी भी हैंडल ऑब्जेक्ट की फ़ंक विधि के माध्यम से कॉल किया जा सकता है ।
ड्राइवर-विशिष्ट विशेषताओं का समर्थन किया जाता है और इसका उपयोग करके सेट या प्राप्त किया जा सकता है []= या [] तरीकों।
अनु क्रमांक। | कार्य और विवरण |
---|---|
1 | dbh.func(:createdb, db_name) एक नया डेटाबेस बनाता है। |
2 | dbh.func(:dropdb, db_name) एक डेटाबेस को गिराता है। |
3 | dbh.func(:reload) पुनः लोड ऑपरेशन करता है। |
4 | dbh.func(:shutdown) सर्वर को बंद कर देता है। |
5 | dbh.func(:insert_id) => Fixnum किसी कनेक्शन के लिए सबसे हाल का AUTO_INCREMENT मान लौटाता है। |
6 | dbh.func(:client_info) => String संस्करण के संदर्भ में MySQL क्लाइंट जानकारी लौटाता है। |
7 | dbh.func(:client_version) => Fixnum संस्करण के संदर्भ में क्लाइंट की जानकारी देता है। यह इसके जैसा है: client_info लेकिन यह स्टिंग के बजाय एक फ़िक्नम लौटाता है। |
8 | dbh.func(:host_info) => String मेजबान जानकारी देता है। |
9 | dbh.func(:proto_info) => Fixnum संचार के लिए इस्तेमाल किया जा रहा प्रोटोकॉल लौटाता है। |
10 | dbh.func(:server_info) => String संस्करण के संदर्भ में MySQL सर्वर जानकारी देता है। |
1 1 | dbh.func(:stat) => String डेटाबेस की वर्तमान स्थिति देता है। |
12 | dbh.func(:thread_id) => Fixnum वर्तमान थ्रेड आईडी लौटाता है। |
उदाहरण
#!/usr/bin/ruby
require "dbi"
begin
# connect to the MySQL server
dbh = DBI.connect("DBI:Mysql:TESTDB:localhost", "testuser", "test123")
puts dbh.func(:client_info)
puts dbh.func(:client_version)
puts dbh.func(:host_info)
puts dbh.func(:proto_info)
puts dbh.func(:server_info)
puts dbh.func(:thread_id)
puts dbh.func(:stat)
rescue DBI::DatabaseError => e
puts "An error occurred"
puts "Error code: #{e.err}"
puts "Error message: #{e.errstr}"
ensure
dbh.disconnect if dbh
end
यह निम्नलिखित परिणाम का उत्पादन करेगा -
5.0.45
50045
Localhost via UNIX socket
10
5.0.45
150621
Uptime: 384981 Threads: 1 Questions: 1101078 Slow queries: 4 \
Opens: 324 Flush tables: 1 Open tables: 64 \
Queries per second avg: 2.860