1 / 24

สถาปัตยกรรม ActiveX Data Object (ADO)

สถาปัตยกรรม ActiveX Data Object (ADO). ADO คือรูปแบบใหม่ของการติดต่อกับฐานข้อมูลอีกวิธีหนึ่ง แนวทางของ Universal Data Access ( UDA) สะดวกและง่ายขึ้น OLE DB เป็นตัวจัดการสามารถทำให้เข้าถึงข้อมูลได้ในทุก ๆ ที่ และ. การแก้ปัญหาการเข้าถึงข้อมูลแบบกระจาย.

Download Presentation

สถาปัตยกรรม ActiveX Data Object (ADO)

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. สถาปัตยกรรม ActiveX Data Object (ADO) • ADO คือรูปแบบใหม่ของการติดต่อกับฐานข้อมูลอีกวิธีหนึ่ง • แนวทางของ Universal Data Access (UDA) สะดวกและง่ายขึ้น • OLE DB เป็นตัวจัดการสามารถทำให้เข้าถึงข้อมูลได้ในทุก ๆ ที่ และ

  2. การแก้ปัญหาการเข้าถึงข้อมูลแบบกระจายการแก้ปัญหาการเข้าถึงข้อมูลแบบกระจาย • วิธีการ Universal Data Storage คือ การใช้ฐานข้อมูลสัมพันธ์ (Relational Database) ในการเก็บข้อมูลทุก ๆ ชนิด เช่น Oracle , Sybase , Informix และ Microsoft เป็นต้น • วิธีการ Universal Data Access (UDA) คือ การเข้าถึงข้อมูลในที่ที่ข้อมูลบันทึกอยู่ โดยอาศัย OLE DB เป็นตัวจัดการ • OLE DB เป็นกลุ่มคำสั่งของ Component Object Model ( COM ) ที่เป็นทางเชื่อมต่อไปยัง Data provider กล่าวคือ ถ้าข้อมูลที่จะใช้นั้นอยู่บน Application ใด ๆ ก็ตามที่มี Data provider สำหรับ OLE DB ข้อมูลนั้นก็จะสามารถเข้าถึงได้โดยวิธีการ Universal Data Access

  3. ActiveX Data Object (ADO) Object Objects ทั้ง 7 ของ ADO มีดังนี้ - Connection - Command - Parameter - Recordset - Field - Property - Error Collections ทั้ง 4 ของ ADO มีดังนี้ - Field - Properties - Parameter - Error

  4. ActiveX Data Object (ADO) Object • Connection, Recordset และ Command เป็นส่วนที่สำคัญที่สุดและใช้งานมากที่สุด ทั้งสามตัวเป็น object ในระดับบนสุดไม่ขึ้นกับ object อื่น ๆ จึงสามารถสร้างและทำลาย object ทั้งสามนี้ได้โดยตรง • สำหรับ Parameter object ทำงานเป็นอิสระก็จริงแต่เวลาจะนำมาใช้งาน ต้องใช้งานรุ่มกับ Command object เท่านั้น

  5. ActiveX Data Object (ADO) Object (ต่อ) • สำหรับ Field , Error และ Property object ไม่สามารถทำงานได้โดยตรง แต่จะสร้างได้เมื่อมี Object ระดับบนอยู่ก่อนแล้ว • ใช้ Connection Object สำหรับสร้างการเชื่อมต่อระหว่างตัว Application กับ Database source • ใช้ Command object เมื่อต้องการส่งคำสั่งที่จะกระทำกับ Data source เช่น Queries , Update เป็นต้น

  6. ActiveX Data Object (ADO) Object (ต่อ) • ใช้ Recordset Object ในการจัดการกับข้อมูลที่ได้มาจากคำสั่งที่ส่งโดย Command object ลักษณะของคำสั่งที่ส่งโดยใช้ Command object จะขึ้นอยู่กับชนิดของ OLE DBProvider ที่เชื่อมต่อ • ใช้ parameter Object ก็ต่อเมื่อคำสั่งที่จะทำการส่งโดยใช้ Command object มี parameter อยู่ด้วยโดยจะกำหนดค่าและชนิดของ parameter ผ่านทาง parameter object

  7. Connection object

  8. Connection Object • เป็น object ที่ใช้ติดต่อกับ Data source • เป็น object ใช้ในการเริ่มต้นการเชื่อมต่อกับ Data source • เป็น object ที่สามารถ runqueries และทำ Transaction

  9. Connection Object • ใช้สำหรับสร้างส่วนเชื่อมต่อกับฐานข้อมูล เพื่อส่งคำสั่งต่าง ๆ ไป Execute เพื่อให้ได้ผลลัพธ์ โดยการสร้างอ๊อบเจ็กต์สำหรับการติดต่อแล้วใช้เมธอด Open เพื่อเปิดการเชื่อมต่อนั้น Set Conn = Server.CreateObject(“ADODB.Connection”) Conn.Open “MyDSN” , “admin” , “” • บรรทัดแรกเป็นการสร้างอ๊อบเจ็กต์สำหรับการเชื่อมต่อชื่อ Conn แล้วเปิดการเชื่อมต่อด้วย เมธอด Open โดยกำหนดชื่อ Data Source Name เป็น “MyDSN” และ เข้าติดต่อด้วย Log On name เป็น “admin” ซึ่งไม่มีรหัสผ่าน

  10. การส่งคำสั่งไปยัง Data sources ด้วย Connection Object รูปแบบของ Execute method มี 2 รูปแบบ 1. ไม่มีเซตของข้อมูลกลับมาจาก Data sources (non row-returning) connection.Execute CommandText, RecordsAffected, Options 2. มีเซตของข้อมูลกลับมาจาก Data sources (row-returning) Set recordset = connection.Execute (CommandText, RecordsAffected, Options )

  11. การส่งคำสั่งไปยัง Data sources ด้วย Connection Object รายละเอียดของ Parameters CommandText คือตัวแปรชนิด String ที่มี SQLstatement, stored procedure หรือชื่อ Table RecordsAffectedคือตัวแปรชนิด Long ซึ่ง Data provider ส่ง กลับมา เพื่อแจ้งว่าคำสั่งที่ Execute ไปนี้มีผลกับ Record จำนวนเท่าไร Options คือ ตัวแปรชนิด Long ที่บ่งบอกชนิดของคำสั่ง ใน Command Text

  12. การส่งคำสั่งไปยัง Data sources ด้วย Connection Object ชนิดของคำสั่งใน CommandText ค่าคงที่ ความหมาย adCmdText SQL Statement ธรรมดา adCmdTable ชื่อ Table adCmdStoredProc ชื่อ Stored procedure adCmdUnknown ไม่ทราบชนิดของ CommandText

  13. Command Object

  14. Command Object • ใช้ส่งคำสั่งต่าง ๆ เช่น • SQL Statement • Stored Procedure • ใช้การเชื่อมต่อที่มีอยู่แล้วโดยการสร้าง Connection Object หรือ • สามารถสร้างการเชื่อมต่อใหม่ได้ด้วยตัวเอง

  15. ActiveConnection Property • เป็น property ที่ใช้กำหนดลักษณะการเชื่อมต่อกับฐานข้อมูล • ใช้การเชื่อมต่อที่มีอยู่แล้ว โดยกำหนดค่า ActiveConnection Property เป็น Connection Object ที่มีอยู่แล้ว • สร้างการเชื่อมต่อใหม่ โดยกำหนด Connection String ให้กับ ActiveConnection Property

  16. การส่งคำสั่งไปยัง Data Sources ด้วย Execute Method อาจได้ผลลัพท์เป็น record set, multiple record set หรือไม่มี record set กลับมา ขึ้นอยู่กับว่าคำสั่งที่ส่งไปมีลักษณะอย่างไร ถ้าเป็น Select Statement ผลลัพท์จะได้เป็น Record Set กลุ่มคำสั่งนั้นเป็นกลุ่มของ Select Statement ผลลัพท์ที่ได้จะเป็น multiple record set รูปแบบการใช้งานจะเหมือนกับ Connection Object

  17. รูปแบบของ Execute Method มีอยู่ 2 รูปแบบ • ไม่มีเซตของข้อมูลกลับมาจาก Data Sources (no row-return) • Connection.Execute CommandText, RecordAffected, Options • มีเซตของข้อมูลกลับมาจาก Data Sources (row-return) • Set Recordset = Connection.Execute(CommandText , RecordsAffected , Options)

  18. Parameters ของ Execute Method CommandText คือตัวแปรชนิด String ที่มี SQLstatement , stored procedure หรือชื่อ Table RecordsAffectedคือตัวแปรชนิด Long ซึ่ง Data provider ส่งกลับมา เพื่อแจ้งว่าคำสั่งที่ Execute ไปนี้มีผล กับ Record จำนวนเท่าไร Optionsคือ ตัวแปรชนิด Long ที่บ่งบอกชนิดของคำสั่ง ใน Command Text

  19. ชนิดของคำสั่งใน CommandText ค่าคงที่ความหมาย adCmdText SQL Statement ธรรมดา adCmdTable ชื่อ Table adCmdStoredProc ชื่อ Stored procedure adCmdUnknown ไม่ทราบชนิดของ CommandText

  20. การใช้งาน Stored Procedure ใช้ Execute Method ต้องกำหนดชนิดของคำสั่งให้เป็น Stored Procedure ด้วยการใช้ค่าคงที่ adCmdStoreProc

  21. ตัวอย่างโปรแกรม : การเรียกใช้ Stored Procedure • การเรียกใช้ Stored Procedure ด้วยวิธี ADO • Sp_TitlePub ในรูปแบบที่ไม่มีการส่ง parameter • Sp_Isbn มีการส่ง parameter • Sp_Insert_Titles เพิ่มข้อมูลลงในตาราง Titles

More Related