บทช่วยสอน Ruby / DBI
บทนี้สอนวิธีเข้าถึงฐานข้อมูลโดยใช้ Ruby ทับทิม DBIโมดูลมีอินเตอร์เฟซที่ใช้ฐานข้อมูลอิสระสคริปต์ทับทิมคล้ายกับที่ของโมดูล Perl DBI
DBI ย่อมาจาก Database Independent Interface สำหรับ Ruby ซึ่งหมายความว่า DBI จัดเตรียมเลเยอร์ที่เป็นนามธรรมระหว่างโค้ด Ruby และฐานข้อมูลที่อยู่เบื้องหลังทำให้คุณสามารถสลับการใช้งานฐานข้อมูลได้อย่างง่ายดาย กำหนดชุดวิธีการตัวแปรและรูปแบบที่จัดเตรียมอินเทอร์เฟซฐานข้อมูลที่สอดคล้องกันโดยไม่ขึ้นกับฐานข้อมูลจริงที่ใช้อยู่
DBI สามารถเชื่อมต่อกับสิ่งต่อไปนี้ -
- ADO (วัตถุข้อมูล ActiveX)
- DB2
- Frontbase
- mSQL
- MySQL
- ODBC
- Oracle
- OCI8 (ออราเคิล)
- PostgreSQL
- Proxy/Server
- SQLite
- SQLRelay
สถาปัตยกรรมของ DBI Application
DBI ไม่ขึ้นอยู่กับฐานข้อมูลใด ๆ ที่มีอยู่ในแบ็กเอนด์ คุณสามารถใช้ DBI ได้ไม่ว่าคุณจะทำงานกับ Oracle, MySQL หรือ Informix เป็นต้นซึ่งชัดเจนจากแผนภาพสถาปัตยกรรมต่อไปนี้
สถาปัตยกรรมทั่วไปสำหรับ Ruby DBI ใช้สองชั้น -
เลเยอร์อินเทอร์เฟซฐานข้อมูล (DBI) เลเยอร์นี้ไม่ขึ้นกับฐานข้อมูลและมีชุดวิธีการเข้าถึงทั่วไปที่ใช้ในลักษณะเดียวกันโดยไม่คำนึงถึงประเภทของเซิร์ฟเวอร์ฐานข้อมูลที่คุณกำลังสื่อสาร
เลเยอร์ไดรเวอร์ฐานข้อมูล (DBD) เลเยอร์นี้ขึ้นอยู่กับฐานข้อมูล ไดรเวอร์ที่แตกต่างกันให้การเข้าถึงเอ็นจิ้นฐานข้อมูลต่างๆ มีไดรเวอร์สำหรับ MySQL หนึ่งตัวอีกตัวสำหรับ PostgreSQL อีกตัวสำหรับ InterBase อีกตัวสำหรับ Oracle และอื่น ๆ ไดรเวอร์แต่ละตัวตีความคำร้องขอจากเลเยอร์ DBI และแมปเข้ากับคำร้องขอที่เหมาะสมกับประเภทของเซิร์ฟเวอร์ฐานข้อมูลที่กำหนด
ข้อกำหนดเบื้องต้น
หากคุณต้องการเขียนสคริปต์ Ruby เพื่อเข้าถึงฐานข้อมูล MySQL คุณจะต้องติดตั้งโมดูล Ruby MySQL
โมดูลนี้ทำหน้าที่เป็น DBD ตามที่อธิบายไว้ข้างต้นและสามารถดาวน์โหลดได้จาก https://www.tmtm.org/en/mysql/ruby/
การรับและติดตั้ง Ruby / DBI
คุณสามารถดาวน์โหลดและติดตั้งโมดูล Ruby DBI จากตำแหน่งต่อไปนี้ -
https://imgur.com/NFEuWe4/embed
ก่อนเริ่มการติดตั้งนี้ตรวจสอบให้แน่ใจว่าคุณมีสิทธิ์ระดับราก ตอนนี้ทำตามขั้นตอนด้านล่าง -
ขั้นตอนที่ 1
$ tar zxf dbi-0.2.0.tar.gz
ขั้นตอนที่ 2
ไปที่ไดเร็กทอรีการแจกจ่ายdbi-0.2.0และกำหนดค่าโดยใช้สคริปต์setup.rbในไดเร็กทอรีนั้น คำสั่งคอนฟิกูเรชันทั่วไปส่วนใหญ่มีลักษณะเช่นนี้โดยไม่มีอาร์กิวเมนต์ตามอาร์กิวเมนต์ config คำสั่งนี้กำหนดค่าการแจกจ่ายเพื่อติดตั้งไดรเวอร์ทั้งหมดตามค่าเริ่มต้น
$ 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
คุณได้สร้าง EMPLOYEE ใน TESTDB
ตารางนี้มีฟิลด์ FIRST_NAME, LAST_NAME, AGE, SEX และ INCOME
ID ผู้ใช้ "testuser" และรหัสผ่าน "test123" ถูกตั้งค่าให้เข้าถึง TESTDB
Ruby Module DBI ได้รับการติดตั้งอย่างถูกต้องบนเครื่องของคุณ
คุณได้อ่านบทช่วยสอน MySQL เพื่อทำความเข้าใจเกี่ยวกับ MySQL Basics
ต่อไปนี้เป็นตัวอย่างการเชื่อมต่อกับฐานข้อมูล 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
ขณะรันสคริปต์นี้จะสร้างผลลัพธ์ต่อไปนี้ที่เครื่อง Linux ของเรา
Server version: 5.0.45
หากสร้างการเชื่อมต่อกับแหล่งข้อมูลแล้ว Database Handle จะถูกส่งคืนและบันทึกลงใน dbh เพื่อการใช้งานอื่น ๆ ต่อไป dbhถูกตั้งค่าเป็นค่าศูนย์และe.errและe :: errstrส่งคืนรหัสข้อผิดพลาดและสตริงข้อผิดพลาดตามลำดับ
สุดท้ายก่อนที่จะออกมาตรวจสอบให้แน่ใจว่าการเชื่อมต่อฐานข้อมูลถูกปิดและปล่อยทรัพยากร
การทำงานของ INSERT
จำเป็นต้องมีการดำเนินการ INSERT เมื่อคุณต้องการสร้างระเบียนของคุณลงในตารางฐานข้อมูล
เมื่อสร้างการเชื่อมต่อฐานข้อมูลแล้วเราก็พร้อมที่จะสร้างตารางหรือบันทึกลงในตารางฐานข้อมูลโดยใช้ do วิธีการหรือ prepare และ execute วิธี.
ใช้ do Statement
คำสั่งที่ไม่ส่งคืนแถวสามารถออกได้โดยการเรียกใช้ 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 )" );
ในทำนองเดียวกันคุณสามารถดำเนินการคำสั่ง SQL INSERTเพื่อสร้างเรกคอร์ดลงในตาราง EMPLOYEE
#!/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
ใช้การเตรียมและดำเนินการ
คุณสามารถใช้วิธีการเตรียมและดำเนินการของคลาส DBI เพื่อดำเนินการคำสั่ง SQL ผ่านรหัส Ruby
การสร้างเรกคอร์ดทำตามขั้นตอนต่อไปนี้ -
การเตรียมคำสั่ง SQL ด้วยคำสั่ง INSERT ซึ่งจะทำได้โดยใช้ไฟล์prepare วิธี.
ดำเนินการสอบถาม SQL เพื่อเลือกผลลัพธ์ทั้งหมดจากฐานข้อมูล ซึ่งจะทำได้โดยใช้ไฟล์execute วิธี.
การปลดหมายเลขอ้างอิงคำชี้แจง ซึ่งจะทำได้โดยใช้finish API
หากทุกอย่างเป็นไปด้วยดี commit การดำเนินการนี้คุณสามารถทำได้ rollback การทำธุรกรรมที่สมบูรณ์
ต่อไปนี้เป็นไวยากรณ์ที่จะใช้สองวิธีนี้ -
sth = dbh.prepare(statement)
sth.execute
... zero or more SQL operations ...
sth.finish
สองวิธีนี้สามารถใช้เพื่อผ่าน bindค่าของคำสั่ง SQL อาจมีบางกรณีที่ไม่ได้ให้ค่าที่จะป้อนล่วงหน้า ในกรณีเช่นนี้จะใช้ค่าการผูก เครื่องหมายคำถาม (?) ใช้แทนค่าจริงจากนั้นค่าจริงจะถูกส่งผ่าน execute () API
ต่อไปนี้เป็นตัวอย่างในการสร้างสองระเบียนในตารางพนักงาน -
#!/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
หากมีการแทรกหลายครั้งการเตรียมคำสั่งก่อนจากนั้นจึงดำเนินการหลาย ๆ ครั้งภายในลูปจะมีประสิทธิภาพมากกว่าการเรียกใช้ทุกครั้งผ่านลูป
อ่านการทำงาน
READ Operation บนฐานข้อมูลใด ๆ หมายถึงการดึงข้อมูลที่เป็นประโยชน์จากฐานข้อมูล
เมื่อสร้างการเชื่อมต่อฐานข้อมูลแล้วเราก็พร้อมที่จะทำการสืบค้นในฐานข้อมูลนี้ เราสามารถใช้อย่างใดอย่างหนึ่งdo วิธีการหรือ prepare และ execute วิธีการดึงค่าจากตารางฐานข้อมูล
การดึงบันทึกจะทำตามขั้นตอนต่อไปนี้ -
การจัดเตรียมแบบสอบถาม SQL ตามเงื่อนไขที่จำเป็น ซึ่งจะทำได้โดยใช้ไฟล์prepare วิธี.
ดำเนินการสอบถาม SQL เพื่อเลือกผลลัพธ์ทั้งหมดจากฐานข้อมูล ซึ่งจะทำได้โดยใช้ไฟล์execute วิธี.
ดึงผลลัพธ์ทั้งหมดทีละรายการและพิมพ์ผลลัพธ์เหล่านั้น ซึ่งจะทำได้โดยใช้ไฟล์fetch วิธี.
การปลดหมายเลขอ้างอิงคำชี้แจง ซึ่งจะทำได้โดยใช้ไฟล์finish วิธี.
ต่อไปนี้เป็นขั้นตอนในการสืบค้นบันทึกทั้งหมดจากตารางพนักงานที่มีเงินเดือนมากกว่า 1,000
#!/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
มีวิธีการทางลัดมากขึ้นในการดึงข้อมูลจากฐานข้อมูล หากคุณสนใจให้ไปที่การดึงผลลัพธ์หรือดำเนินการต่อในส่วนถัดไป
อัปเดตการทำงาน
UPDATE การทำงานบนฐานข้อมูลหมายถึงการอัปเดตระเบียนตั้งแต่หนึ่งรายการขึ้นไปซึ่งมีอยู่แล้วในฐานข้อมูล ต่อไปนี้เป็นขั้นตอนในการอัปเดตระเบียนทั้งหมดที่มี SEX เป็น 'M' ที่นี่เราจะเพิ่ม AGE ของผู้ชายทุกคนขึ้นหนึ่งปี ขั้นตอนนี้จะใช้สามขั้นตอน -
การจัดเตรียมแบบสอบถาม 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 เมื่อคุณต้องการลบบางระเบียนออกจากฐานข้อมูลของคุณ ต่อไปนี้เป็นขั้นตอนในการลบบันทึกทั้งหมดจาก 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 มีสองวิธีในการคอมมิตหรือย้อนกลับธุรกรรม มีอีกวิธีหนึ่งที่เรียกว่าธุรกรรมซึ่งสามารถใช้ในการทำธุรกรรมได้ มีสองวิธีง่ายๆในการทำธุรกรรม -
วิธีการ I
แนวทางแรกใช้วิธีการคอมมิตและการย้อนกลับของ 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 คือการดำเนินการซึ่งให้สัญญาณสีเขียวไปยังฐานข้อมูลเพื่อดำเนินการเปลี่ยนแปลงให้เสร็จสิ้นและหลังจากการดำเนินการนี้จะไม่สามารถย้อนกลับการเปลี่ยนแปลงได้
นี่คือตัวอย่างง่ายๆในการเรียกไฟล์ commit วิธี.
dbh.commit
การทำงานของ ROLLBACK
หากคุณไม่พอใจกับการเปลี่ยนแปลงอย่างน้อยหนึ่งรายการและต้องการเปลี่ยนกลับการเปลี่ยนแปลงเหล่านั้นทั้งหมดให้ใช้ไฟล์ rollback วิธี.
นี่คือตัวอย่างง่ายๆในการเรียกไฟล์ rollback วิธี.
dbh.rollback
กำลังยกเลิกการเชื่อมต่อฐานข้อมูล
หากต้องการยกเลิกการเชื่อมต่อฐานข้อมูลให้ใช้ disconnect API
dbh.disconnect
หากการเชื่อมต่อกับฐานข้อมูลถูกปิดโดยผู้ใช้ด้วยวิธีการตัดการเชื่อมต่อธุรกรรมที่ค้างอยู่จะถูกย้อนกลับโดย DBI อย่างไรก็ตามแทนที่จะขึ้นอยู่กับรายละเอียดการนำไปใช้งานของ DBI แอปพลิเคชันของคุณจะดีกว่าหากเรียกคอมมิตหรือย้อนกลับอย่างชัดเจน
การจัดการข้อผิดพลาด
มีหลายแหล่งที่มาของข้อผิดพลาด ตัวอย่างบางส่วน ได้แก่ ข้อผิดพลาดทางไวยากรณ์ในคำสั่ง SQL ที่เรียกใช้งานความล้มเหลวในการเชื่อมต่อหรือการเรียกวิธีการดึงข้อมูลสำหรับหมายเลขอ้างอิงคำสั่งที่ยกเลิกไปแล้วหรือเสร็จสิ้นแล้ว
หากเมธอด DBI ล้มเหลว DBI จะมีข้อยกเว้น วิธี DBI อาจเพิ่มใด ๆ ของหลายประเภทยกเว้น แต่ทั้งสองที่สำคัญที่สุดในการเรียนการยกเว้นเป็นDBI :: InterfaceErrorและDBI :: DatabaseError
อ็อบเจ็กต์ข้อยกเว้นของคลาสเหล่านี้มีแอ็ตทริบิวต์สามตัวชื่อerr , errstrและstateซึ่งแสดงถึงหมายเลขข้อผิดพลาดสตริงข้อผิดพลาดที่อธิบายได้และรหัสข้อผิดพลาดมาตรฐาน แอตทริบิวต์มีคำอธิบายด้านล่าง -
err- ส่งคืนการแทนค่าจำนวนเต็มของข้อผิดพลาดที่เกิดขึ้นหรือศูนย์หาก DBD ไม่สนับสนุนตัวอย่างเช่น Oracle DBD ส่งคืนส่วนที่เป็นตัวเลขของข้อความแสดงข้อผิดพลาดORA-XXXX
errstr - ส่งกลับการแสดงสตริงของข้อผิดพลาดที่เกิดขึ้น
state- ส่งคืนรหัส SQLSTATE ของข้อผิดพลาดที่เกิดขึ้น SQLSTATE เป็นสตริงความยาวห้าอักขระ DBD ส่วนใหญ่ไม่สนับสนุนสิ่งนี้และส่งคืนค่าศูนย์แทน
คุณได้เห็นโค้ดต่อไปนี้ในตัวอย่างส่วนใหญ่ -
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 / trace ก่อนจากนั้นเรียกใช้เมธอดการติดตามที่ควบคุมโหมดการติดตามและปลายทางเอาต์พุต -
require "dbi/trace"
..............
trace(mode, destination)
ค่าโหมดอาจเป็น 0 (ปิด), 1, 2 หรือ 3 และปลายทางควรเป็นอ็อบเจ็กต์ IO ค่าเริ่มต้นคือ 2 และ STDERR ตามลำดับ
รหัสบล็อกด้วยวิธีการ
มีวิธีการบางอย่างที่สร้างแฮนเดิล วิธีการเหล่านี้สามารถเรียกใช้ด้วยบล็อกรหัส ข้อดีของการใช้บล็อกโค้ดร่วมกับวิธีการคือให้หมายเลขอ้างอิงกับบล็อกโค้ดเป็นพารามิเตอร์และล้างหมายเลขอ้างอิงโดยอัตโนมัติเมื่อบล็อกสิ้นสุดลง มีตัวอย่างเล็กน้อยเพื่อทำความเข้าใจแนวคิด
DBI.connect- วิธีนี้จะสร้างที่จับฐานข้อมูลและขอแนะนำให้โทรยกเลิกการเชื่อมต่อที่ส่วนท้ายของบล็อกเพื่อยกเลิกการเชื่อมต่อฐานข้อมูล
dbh.prepare- วิธีนี้จะสร้างหมายเลขอ้างอิงคำสั่งและขอแนะนำให้ทำในตอนท้ายของบล็อก ภายในบล็อกคุณต้องเรียกใช้เมธอด execute เพื่อดำเนินการคำสั่ง
dbh.execute- วิธีนี้คล้ายกันยกเว้นเราไม่จำเป็นต้องเรียกใช้ 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 ยังใช้บล็อกรหัสซึ่งได้อธิบายไว้ข้างต้น
ฟังก์ชั่นและคุณสมบัติเฉพาะของไดรเวอร์
DBI ช่วยให้ไดรเวอร์ฐานข้อมูลมีฟังก์ชันเฉพาะฐานข้อมูลเพิ่มเติมซึ่งผู้ใช้สามารถเรียกใช้ผ่านวิธีfuncของวัตถุ Handle ใด ๆ
รองรับแอตทริบิวต์เฉพาะไดรเวอร์และสามารถตั้งค่าหรือรับได้โดยใช้ []= หรือ [] วิธีการ
ซีเนียร์ | ฟังก์ชั่นและคำอธิบาย |
---|---|
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 แต่ส่งคืน Fixnum แทนการต่อย |
8 | dbh.func(:host_info) => String ส่งคืนข้อมูลโฮสต์ |
9 | dbh.func(:proto_info) => Fixnum ส่งคืนโปรโตคอลที่ใช้สำหรับการสื่อสาร |
10 | dbh.func(:server_info) => String ส่งคืนข้อมูลเซิร์ฟเวอร์ MySQL ในรูปแบบของเวอร์ชัน |
11 | dbh.func(:stat) => String ส่งคืนสถานะปัจจุบันของฐานข้อมูล |
12 | dbh.func(:thread_id) => Fixnum ส่งคืน ID เธรดปัจจุบัน |
ตัวอย่าง
#!/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