บทช่วยสอน 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