लुआ - डेटाबेस एक्सेस
सरल डेटा संचालन के लिए, हम फ़ाइलों का उपयोग कर सकते हैं, लेकिन, कभी-कभी, ये फ़ाइल संचालन कुशल, स्केलेबल और शक्तिशाली नहीं हो सकते हैं। इस उद्देश्य के लिए, हम अक्सर डेटाबेस का उपयोग करने के लिए स्विच कर सकते हैं। LuaSQL Lua से कई डेटाबेस प्रबंधन प्रणालियों के लिए एक सरल इंटरफ़ेस है। LuaSQL पुस्तकालय है, जो विभिन्न प्रकार के एसक्यूएल के लिए समर्थन प्रदान करता है। इसमें शामिल हैं,
- SQLite
- Mysql
- ODBC
इस ट्यूटोरियल में, हम Lua में MySQL a SQLite के डेटाबेस हैंडलिंग को कवर करेंगे। यह दोनों के लिए एक सामान्य इंटरफ़ेस का उपयोग करता है और इस कार्यान्वयन को अन्य प्रकार के डेटाबेस में भी पोर्ट करना संभव होना चाहिए। पहले देखते हैं कि आप MySQL में ऑपरेशन कैसे कर सकते हैं।
MySQL db सेटअप
अपेक्षा के अनुसार काम करने के लिए निम्नलिखित उदाहरणों का उपयोग करने के लिए, हमें प्रारंभिक db सेटअप की आवश्यकता है। मान्यताओं को नीचे सूचीबद्ध किया गया है।
आपने MySQL को रूट और पासवर्ड के साथ '123456' के रूप में स्थापित और सेटअप किया है।
आपने एक डेटाबेस टेस्ट बनाया है।
आप MySQL बेसिक्स को समझने के लिए MySQL ट्यूटोरियल से गुजरे हैं।
आयात MySQL
हम एक साधारण का उपयोग कर सकते हैं require अपने Lua कार्यान्वयन सही ढंग से किया गया था कि यह मानते हुए कि साइक्लाइट लाइब्रेरी आयात करने के लिए बयान।
mysql = require "luasql.mysql"
चर mysql मुख्य mysql तालिका का संदर्भ देकर कार्यों तक पहुंच प्रदान करेगा।
कनेक्शन स्थापित करना
हम एक MySQL पर्यावरण शुरू करके और फिर पर्यावरण के लिए एक कनेक्शन बनाकर कनेक्शन सेट कर सकते हैं। इसे नीचे दिखाया गया है।
local env = mysql.mysql()
local conn = env:connect('test','root','123456')
उपरोक्त कनेक्शन मौजूदा MySQL फ़ाइल से कनेक्ट होगा और नए बनाए गए फ़ाइल के साथ कनेक्शन स्थापित करेगा।
निष्पादन समारोह
कनेक्शन के साथ एक सरल निष्पादन कार्य उपलब्ध है जो हमें बनाने, सम्मिलित करने, हटाने, अद्यतन करने आदि से सभी db संचालन करने में मदद करेगा। वाक्य रचना नीचे दिखाया गया है -
conn:execute([[ 'MySQLSTATEMENT' ]])
उपरोक्त सिंटैक्स में, हमें यह सुनिश्चित करने की आवश्यकता है कि कनवर्टर खुला और मौजूदा MySQL कनेक्शन है और 'MySQLSTATEMENT' को सही विवरण के साथ बदलें।
तालिका उदाहरण बनाएँ
एक सरल बनाने की तालिका उदाहरण नीचे दिखाया गया है। यह एक पूर्णांक बनाता है जिसमें दो प्रकार के पूर्णांक आईडी प्रकार के नाम और प्रकार का नाम है।
mysql = require "luasql.mysql"
local env = mysql.mysql()
local conn = env:connect('test','root','123456')
print(env,conn)
status,errorString = conn:execute([[CREATE TABLE sample2 (id INTEGER, name TEXT);]])
print(status,errorString )
जब आप उपरोक्त कार्यक्रम चलाते हैं, तो नमूना नाम की एक तालिका दो कॉलमों, आईडी और नाम के साथ बनाई जाएगी।
MySQL environment (004BB178) MySQL connection (004BE3C8)
0 nil
यदि कोई त्रुटि है, तो आपको शून्य के बजाय एक त्रुटि विवरण दिया जाएगा। एक साधारण त्रुटि विवरण नीचे दिखाया गया है।
LuaSQL: Error executing query. MySQL: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '"id INTEGER, name TEXT)' at line 1
स्टेटमेंट उदाहरण डालें
MySQL के लिए एक सम्मिलित विवरण नीचे दिखाया गया है।
conn:execute([[INSERT INTO sample values('11','Raj')]])
अपडेट स्टेटमेंट उदाहरण
MySQL के लिए एक अपडेट स्टेटमेंट नीचे दिखाया गया है।
conn:execute([[UPDATE sample3 SET name='John' where id ='12']])
उदाहरण मिटाएँ
MySQL के लिए एक डिलीट स्टेटमेंट नीचे दिखाया गया है।
conn:execute([[DELETE from sample3 where id ='12']])
स्टेटमेंट उदाहरण का चयन करें
जहाँ तक चुनिंदा कथन का सवाल है, हमें प्रत्येक पंक्तियों के माध्यम से लूप करने और आवश्यक डेटा निकालने की आवश्यकता है। एक सरल चयन विवरण नीचे दिखाया गया है।
cursor,errorString = conn:execute([[select * from sample]])
row = cursor:fetch ({}, "a")
while row do
print(string.format("Id: %s, Name: %s", row.id, row.name))
-- reusing the table of results
row = cursor:fetch (row, "a")
end
उपरोक्त कोड में, con एक खुला MySQL कनेक्शन है। निष्पादित विवरण द्वारा लौटाए गए कर्सर की सहायता से, आप तालिका प्रतिक्रिया के माध्यम से लूप कर सकते हैं और आवश्यक चुनिंदा डेटा प्राप्त कर सकते हैं।
एक पूर्ण उदाहरण
उपरोक्त सभी कथनों सहित एक पूर्ण उदाहरण नीचे दिया गया है।
mysql = require "luasql.mysql"
local env = mysql.mysql()
local conn = env:connect('test','root','123456')
print(env,conn)
status,errorString = conn:execute([[CREATE TABLE sample3 (id INTEGER, name TEXT)]])
print(status,errorString )
status,errorString = conn:execute([[INSERT INTO sample3 values('12','Raj')]])
print(status,errorString )
cursor,errorString = conn:execute([[select * from sample3]])
print(cursor,errorString)
row = cursor:fetch ({}, "a")
while row do
print(string.format("Id: %s, Name: %s", row.id, row.name))
row = cursor:fetch (row, "a")
end
-- close everything
cursor:close()
conn:close()
env:close()
जब आप उपरोक्त कार्यक्रम चलाते हैं, तो आपको निम्न आउटपुट मिलेगा।
MySQL environment (0037B178) MySQL connection (0037EBA8)
0 nil
1 nil
MySQL cursor (003778A8) nil
Id: 12, Name: Raj
लेन-देन करना
लेन-देन एक तंत्र है जो डेटा स्थिरता सुनिश्चित करता है। लेनदेन में निम्नलिखित चार गुण होने चाहिए -
Atomicity - या तो लेनदेन पूरा हो जाता है या कुछ भी नहीं होता है।
Consistency - लेन-देन सुसंगत अवस्था में शुरू होना चाहिए और सिस्टम को सुसंगत अवस्था में छोड़ना चाहिए।
Isolation - लेन-देन के मध्यवर्ती परिणाम वर्तमान लेनदेन के बाहर दिखाई नहीं देते हैं।
Durability - एक बार लेनदेन करने के बाद, सिस्टम की विफलता के बाद भी प्रभाव लगातार बना रहता है।
लेनदेन शुरू होता है स्टार्ट ट्रांसक्शन से; और कमिट या रोलबैक स्टेटमेंट के साथ समाप्त होता है।
लेनदेन शुरू करें
लेन-देन शुरू करने के लिए, हमें Lua में निम्नलिखित कथन को निष्पादित करने की आवश्यकता है, यह मानते हुए कि कनवर्टर एक खुला MySQL कनेक्शन है।
conn:execute([[START TRANSACTION;]])
रोलबैक लेनदेन
लेन-देन शुरू होने के बाद किए गए रोलबैक परिवर्तनों के लिए हमें निम्नलिखित कथन को निष्पादित करना होगा।
conn:execute([[ROLLBACK;]])
प्रतिबद्ध लेनदेन
लेनदेन शुरू होने के बाद किए गए परिवर्तनों को करने के लिए हमें निम्नलिखित कथन को क्रियान्वित करना होगा।
conn:execute([[COMMIT;]])
हमने ऊपर और निम्न अनुभाग में MySQL के बारे में जाना है जो मूल SQL ऑपरेशन के बारे में बताता है। लेन-देन को याद रखें, हालाँकि SQLite3 के लिए फिर से समझाया नहीं गया है, लेकिन समान विवरण SQLite3 के लिए भी काम करना चाहिए।
आयात SQLite
हम SQLite लाइब्रेरी को आयात करने के लिए एक साधारण आवश्यकता विवरण का उपयोग कर सकते हैं यह मानते हुए कि आपका Lua कार्यान्वयन सही तरीके से किया गया था। स्थापना के दौरान, एक फ़ोल्डर libsql जिसमें डेटाबेस से संबंधित फाइलें होती हैं।
sqlite3 = require "luasql.sqlite3"
चर sqlite3 मुख्य sqlite3 तालिका का संदर्भ देकर कार्यों तक पहुंच प्रदान करेगा।
कनेक्शन स्थापित करना
हम SQLite वातावरण आरंभ करके और फिर पर्यावरण के लिए कनेक्शन बनाकर कनेक्शन सेट कर सकते हैं। इसे नीचे दिखाया गया है।
local env = sqlite3.sqlite3()
local conn = env:connect('mydb.sqlite')
उपरोक्त कनेक्शन मौजूदा SQLite फ़ाइल से कनेक्ट होगा या एक नई SQLite फ़ाइल बनाता है और नए बनाए गए फ़ाइल के साथ कनेक्शन स्थापित करता है।
निष्पादन समारोह
कनेक्शन के साथ एक सरल निष्पादन कार्य उपलब्ध है जो हमें बनाने, सम्मिलित करने, हटाने, अद्यतन करने आदि से सभी db संचालन करने में मदद करेगा। वाक्य रचना नीचे दिखाया गया है -
conn:execute([[ 'SQLite3STATEMENT' ]])
उपरोक्त सिंटैक्स में हमें यह सुनिश्चित करने की आवश्यकता है कि कनवर्टर खुला है और मौजूदा sqlite3 कनेक्शन है और 'SQLite3STATEMENT' को सही विवरण के साथ बदलें।
तालिका उदाहरण बनाएँ
एक सरल बनाने की तालिका उदाहरण नीचे दिखाया गया है। यह एक पूर्णांक बनाता है जिसमें दो प्रकार के पूर्णांक आईडी प्रकार के नाम और प्रकार का नाम है।
sqlite3 = require "luasql.sqlite3"
local env = sqlite3.sqlite3()
local conn = env:connect('mydb.sqlite')
print(env,conn)
status,errorString = conn:execute([[CREATE TABLE sample ('id' INTEGER, 'name' TEXT)]])
print(status,errorString )
जब आप उपरोक्त कार्यक्रम चलाते हैं, तो नमूना नाम की एक तालिका दो कॉलमों, आईडी और नाम के साथ बनाई जाएगी।
SQLite3 environment (003EC918) SQLite3 connection (00421F08)
0 nil
एक त्रुटि के मामले में, आपको शून्य के बजाय एक त्रुटि विवरण दिया जाएगा। एक साधारण त्रुटि विवरण नीचे दिखाया गया है।
LuaSQL: unrecognized token: ""'id' INTEGER, 'name' TEXT)"
स्टेटमेंट उदाहरण डालें
SQLite के लिए एक सम्मिलित विवरण नीचे दिखाया गया है।
conn:execute([[INSERT INTO sample values('11','Raj')]])
स्टेटमेंट उदाहरण का चयन करें
जहाँ तक चुनिंदा कथन का सवाल है, हमें प्रत्येक पंक्तियों के माध्यम से लूप करने और आवश्यक डेटा निकालने की आवश्यकता है। एक सरल चयन विवरण नीचे दिखाया गया है।
cursor,errorString = conn:execute([[select * from sample]])
row = cursor:fetch ({}, "a")
while row do
print(string.format("Id: %s, Name: %s", row.id, row.name))
-- reusing the table of results
row = cursor:fetch (row, "a")
end
उपरोक्त कोड में, con एक खुला sqlite3 कनेक्शन है। निष्पादित विवरण द्वारा लौटाए गए कर्सर की सहायता से, आप तालिका प्रतिक्रिया के माध्यम से लूप कर सकते हैं और आवश्यक चुनिंदा डेटा प्राप्त कर सकते हैं।
एक पूर्ण उदाहरण
उपरोक्त सभी कथनों सहित एक पूर्ण उदाहरण नीचे दिया गया है।
sqlite3 = require "luasql.sqlite3"
local env = sqlite3.sqlite3()
local conn = env:connect('mydb.sqlite')
print(env,conn)
status,errorString = conn:execute([[CREATE TABLE sample ('id' INTEGER, 'name' TEXT)]])
print(status,errorString )
status,errorString = conn:execute([[INSERT INTO sample values('1','Raj')]])
print(status,errorString )
cursor,errorString = conn:execute([[select * from sample]])
print(cursor,errorString)
row = cursor:fetch ({}, "a")
while row do
print(string.format("Id: %s, Name: %s", row.id, row.name))
row = cursor:fetch (row, "a")
end
-- close everything
cursor:close()
conn:close()
env:close()
जब आप उपरोक्त कार्यक्रम चलाते हैं, तो आपको निम्न आउटपुट मिलेगा।
SQLite3 environment (005EC918) SQLite3 connection (005E77B0)
0 nil
1 nil
SQLite3 cursor (005E9200) nil
Id: 1, Name: Raj
हम इस libsql लाइब्रेरी की मदद से सभी उपलब्ध प्रश्नों को निष्पादित कर सकते हैं। तो, कृपया इन उदाहरणों के साथ मत रोको। संबंधित MySQL, SQLite3 और Lua में अन्य समर्थित db में उपलब्ध विभिन्न क्वेरी स्टेटमेंट का प्रयोग करें।