MySQL - ธุรกรรม

ธุรกรรมคือกลุ่มตามลำดับของการดำเนินการจัดการฐานข้อมูลซึ่งดำเนินการราวกับว่าเป็นหน่วยงานเดียว กล่าวอีกนัยหนึ่งการทำธุรกรรมจะไม่สมบูรณ์จนกว่าการดำเนินการแต่ละอย่างภายในกลุ่มจะประสบความสำเร็จ หากการดำเนินการใด ๆ ภายในธุรกรรมล้มเหลวธุรกรรมทั้งหมดจะล้มเหลว

ในทางปฏิบัติคุณจะรวมคำถาม SQL จำนวนมากไว้ในกลุ่มและคุณจะดำเนินการทั้งหมดร่วมกันเป็นส่วนหนึ่งของธุรกรรม

คุณสมบัติของธุรกรรม

ธุรกรรมมีคุณสมบัติมาตรฐาน 4 ประการดังต่อไปนี้ซึ่งโดยปกติจะอ้างถึงด้วยตัวย่อ ACID -

  • Atomicity- เพื่อให้แน่ใจว่าการดำเนินการทั้งหมดภายในหน่วยงานจะเสร็จสมบูรณ์ มิฉะนั้นธุรกรรมจะถูกยกเลิกเมื่อถึงจุดที่ล้มเหลวและการดำเนินการก่อนหน้านี้จะย้อนกลับไปสู่สถานะเดิม

  • Consistency - สิ่งนี้ช่วยให้มั่นใจได้ว่าฐานข้อมูลมีการเปลี่ยนแปลงสถานะอย่างเหมาะสมเมื่อทำธุรกรรมสำเร็จ

  • Isolation - สิ่งนี้ช่วยให้ธุรกรรมสามารถดำเนินการได้อย่างอิสระและโปร่งใสซึ่งกันและกัน

  • Durability - สิ่งนี้ช่วยให้มั่นใจได้ว่าผลลัพธ์หรือผลของธุรกรรมที่มุ่งมั่นยังคงมีอยู่ในกรณีที่ระบบล้มเหลว

ใน MySQL ธุรกรรมจะเริ่มต้นด้วยคำสั่ง BEGIN WORK และลงท้ายด้วย a COMMIT หรือก ROLLBACKคำให้การ. คำสั่ง SQL ระหว่างคำสั่งเริ่มต้นและคำสั่งสิ้นสุดจะสร้างธุรกรรมจำนวนมาก

COMMIT และ ROLLBACK

คำหลักสองคำนี้ Commit และ Rollback ส่วนใหญ่จะใช้สำหรับธุรกรรม MySQL

  • เมื่อทำธุรกรรมสำเร็จคำสั่ง COMMIT ควรถูกออกเพื่อให้การเปลี่ยนแปลงตารางที่เกี่ยวข้องทั้งหมดมีผล

  • หากเกิดความล้มเหลวคำสั่ง ROLLBACK ควรถูกออกเพื่อส่งคืนทุกตารางที่อ้างอิงในธุรกรรมกลับสู่สถานะก่อนหน้า

คุณสามารถควบคุมพฤติกรรมของธุรกรรมได้โดยการตั้งค่าตัวแปรเซสชันที่เรียกว่า AUTOCOMMIT. ถ้า AUTOCOMMIT ถูกตั้งค่าเป็น 1 (ค่าเริ่มต้น) คำสั่ง SQL แต่ละคำสั่ง (ภายในธุรกรรมหรือไม่) จะถือว่าเป็นธุรกรรมที่สมบูรณ์และตกลงตามค่าเริ่มต้นเมื่อเสร็จสิ้น

เมื่อตั้งค่า AUTOCOMMIT เป็น 0 โดยการออก SET AUTOCOMMIT = 0 คำสั่งชุดคำสั่งที่ตามมาจะทำหน้าที่เหมือนธุรกรรมและไม่มีกิจกรรมใด ๆ เกิดขึ้นจนกว่าจะมีการออกคำสั่ง COMMIT อย่างชัดเจน

คุณสามารถเรียกใช้คำสั่ง SQL เหล่านี้ใน PHP ได้โดยใช้ไฟล์ mysql_query() ฟังก์ชัน

ตัวอย่างทั่วไปในการทำธุรกรรม

ลำดับเหตุการณ์นี้ไม่ขึ้นอยู่กับภาษาโปรแกรมที่ใช้ เส้นทางตรรกะสามารถสร้างขึ้นในภาษาใดก็ได้ที่คุณใช้ในการสร้างแอปพลิเคชันของคุณ

คุณสามารถเรียกใช้คำสั่ง SQL เหล่านี้ใน PHP ได้โดยใช้ไฟล์ mysql_query() ฟังก์ชัน

  • เริ่มต้นธุรกรรมโดยการออกคำสั่ง SQL BEGIN WORK.

  • ออกคำสั่ง SQL อย่างน้อยหนึ่งคำสั่งเช่น SELECT, INSERT, UPDATE หรือ DELETE

  • ตรวจสอบว่าไม่มีข้อผิดพลาดและทุกอย่างเป็นไปตามความต้องการของคุณ

  • หากมีข้อผิดพลาดใด ๆ ให้ออกคำสั่ง ROLLBACK หรือออกคำสั่ง COMMIT

ประเภทตารางที่ปลอดภัยสำหรับธุรกรรมใน MySQL

คุณไม่สามารถใช้ธุรกรรมโดยตรง แต่มีข้อยกเว้นบางประการที่คุณสามารถทำได้ อย่างไรก็ตามพวกเขาไม่ปลอดภัยและรับประกัน หากคุณวางแผนที่จะใช้ธุรกรรมในการเขียนโปรแกรม MySQL คุณจะต้องสร้างตารางด้วยวิธีพิเศษ มีตารางหลายประเภทซึ่งรองรับการทำธุรกรรม แต่ที่นิยมมากที่สุดคือInnoDB.

การสนับสนุนตาราง InnoDB ต้องการพารามิเตอร์การคอมไพล์เฉพาะเมื่อคอมไพล์ MySQL จากซอร์ส หากเวอร์ชัน MySQL ของคุณไม่มีการรองรับ InnoDB โปรดขอให้ผู้ให้บริการอินเทอร์เน็ตของคุณสร้างเวอร์ชันของ MySQL ที่รองรับประเภทตาราง InnoDB หรือดาวน์โหลดและติดตั้งMySQL-Max Binary Distribution สำหรับ Windows หรือ Linux / UNIX และทำงานกับประเภทตารางในสภาพแวดล้อมการพัฒนา

หากการติดตั้ง MySQL ของคุณรองรับตาราง InnoDB เพียงเพิ่มไฟล์ TYPE = InnoDB คำจำกัดความของคำสั่งสร้างตาราง

ตัวอย่างเช่นรหัสต่อไปนี้สร้างตาราง InnoDB ที่เรียกว่า tcount_tbl -

root@host# mysql -u root -p password;
Enter password:*******

mysql> use TUTORIALS;
Database changed

mysql> create table tcount_tbl
   -> (
   -> tutorial_author varchar(40) NOT NULL,
   -> tutorial_count  INT
   -> ) TYPE = InnoDB;
Query OK, 0 rows affected (0.05 sec)

สำหรับรายละเอียดเพิ่มเติมเกี่ยวกับ InnoDB คุณสามารถคลิกที่ลิงค์ต่อไปนี้ - InnoDB

คุณสามารถใช้ตารางประเภทอื่นเช่น GEMINI หรือ BDBแต่ขึ้นอยู่กับการติดตั้งของคุณว่ารองรับตารางทั้งสองประเภทนี้หรือไม่