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แต่ขึ้นอยู่กับการติดตั้งของคุณว่ารองรับตารางทั้งสองประเภทนี้หรือไม่