MySQL - คู่มือฉบับย่อ
ฐานข้อมูลคืออะไร?
ฐานข้อมูลเป็นแอปพลิเคชันแยกต่างหากที่จัดเก็บชุดข้อมูล แต่ละฐานข้อมูลจะมี API ที่แตกต่างกันอย่างน้อยหนึ่งรายการสำหรับการสร้างเข้าถึงจัดการค้นหาและจำลองข้อมูลที่เก็บไว้
นอกจากนี้ยังสามารถใช้ที่เก็บข้อมูลประเภทอื่น ๆ เช่นไฟล์ในระบบไฟล์หรือตารางแฮชขนาดใหญ่ในหน่วยความจำ แต่การดึงข้อมูลและการเขียนจะไม่รวดเร็วและง่ายดายสำหรับระบบประเภทนั้น
ปัจจุบันเราใช้ระบบจัดการฐานข้อมูลเชิงสัมพันธ์ (RDBMS) เพื่อจัดเก็บและจัดการข้อมูลจำนวนมหาศาล สิ่งนี้เรียกว่าฐานข้อมูลเชิงสัมพันธ์เนื่องจากข้อมูลทั้งหมดถูกเก็บไว้ในตารางที่แตกต่างกันและสร้างความสัมพันธ์โดยใช้คีย์หลักหรือคีย์อื่น ๆ ที่เรียกว่าForeign Keys.
ก Relational DataBase Management System (RDBMS) เป็นซอฟต์แวร์ที่ -
ช่วยให้คุณใช้ฐานข้อมูลกับตารางคอลัมน์และดัชนี
รับประกันความสมบูรณ์ของการอ้างอิงระหว่างแถวของตารางต่างๆ
อัปเดตดัชนีโดยอัตโนมัติ
ตีความแบบสอบถาม SQL และรวมข้อมูลจากตารางต่างๆ
คำศัพท์ RDBMS
ก่อนที่เราจะอธิบายระบบฐานข้อมูล MySQL ต่อไปขอให้เราแก้ไขคำจำกัดความบางประการที่เกี่ยวข้องกับฐานข้อมูล
Database - ฐานข้อมูลคือชุดของตารางที่มีข้อมูลที่เกี่ยวข้อง
Table- ตารางคือเมทริกซ์ที่มีข้อมูล ตารางในฐานข้อมูลดูเหมือนสเปรดชีตธรรมดา
Column - หนึ่งคอลัมน์ (องค์ประกอบข้อมูล) ประกอบด้วยข้อมูลหนึ่งคอลัมน์และชนิดเดียวกันตัวอย่างเช่นรหัสไปรษณีย์ของคอลัมน์
Row - แถว (= tuple รายการหรือบันทึก) คือกลุ่มของข้อมูลที่เกี่ยวข้องเช่นข้อมูลของการสมัครสมาชิกหนึ่งรายการ
Redundancy - จัดเก็บข้อมูลสองครั้งซ้ำซ้อนเพื่อให้ระบบเร็วขึ้น
Primary Key- คีย์หลักไม่ซ้ำกัน ค่าคีย์ไม่สามารถเกิดขึ้นสองครั้งในตารางเดียว ด้วยคีย์คุณจะพบแถวเดียวเท่านั้น
Foreign Key - คีย์ภายนอกคือพินเชื่อมโยงระหว่างสองตาราง
Compound Key - คีย์ผสม (คีย์ผสม) คือคีย์ที่ประกอบด้วยหลายคอลัมน์เนื่องจากคอลัมน์เดียวไม่ซ้ำกันเพียงพอ
Index - ดัชนีในฐานข้อมูลมีลักษณะคล้ายกับดัชนีที่ด้านหลังของหนังสือ
Referential Integrity - Referential Integrity ทำให้แน่ใจว่าค่า Foreign Key ชี้ไปที่แถวที่มีอยู่เสมอ
ฐานข้อมูล MySQL
MySQL เป็น RDBMS ที่รวดเร็วและใช้งานง่ายที่ใช้สำหรับธุรกิจขนาดเล็กและขนาดใหญ่จำนวนมาก MySQL ได้รับการพัฒนาทำการตลาดและสนับสนุนโดย MySQL AB ซึ่งเป็น บริษัท ของสวีเดน MySQL กำลังเป็นที่นิยมอย่างมากเนื่องจากเหตุผลที่ดีหลายประการ -
MySQL เผยแพร่ภายใต้ใบอนุญาตโอเพนซอร์ส คุณจึงไม่มีอะไรต้องจ่ายเพื่อใช้มัน
MySQL เป็นโปรแกรมที่มีประสิทธิภาพมากในตัวของมันเอง จัดการฟังก์ชันย่อยขนาดใหญ่ของแพ็คเกจฐานข้อมูลที่มีราคาแพงและทรงพลังที่สุด
MySQL ใช้รูปแบบมาตรฐานของภาษาข้อมูล SQL ที่รู้จักกันดี
MySQL ทำงานได้บนระบบปฏิบัติการหลายระบบและหลายภาษาเช่น PHP, PERL, C, C ++, JAVA เป็นต้น
MySQL ทำงานได้อย่างรวดเร็วและทำงานได้ดีแม้กับชุดข้อมูลขนาดใหญ่
MySQL เป็นมิตรกับ PHP ซึ่งเป็นภาษาที่นิยมมากที่สุดสำหรับการพัฒนาเว็บ
MySQL รองรับฐานข้อมูลขนาดใหญ่มากถึง 50 ล้านแถวหรือมากกว่าในตาราง ขีด จำกัด ขนาดไฟล์เริ่มต้นสำหรับตารางคือ 4GB แต่คุณสามารถเพิ่มสิ่งนี้ได้ (หากระบบปฏิบัติการของคุณสามารถจัดการได้) เป็นขีด จำกัด ทางทฤษฎีที่ 8 ล้านเทราไบต์ (TB)
MySQL สามารถปรับแต่งได้ ใบอนุญาต GPL แบบโอเพนซอร์สช่วยให้โปรแกรมเมอร์สามารถปรับเปลี่ยนซอฟต์แวร์ MySQL ให้เข้ากับสภาพแวดล้อมเฉพาะของตนเองได้
ก่อนเริ่มต้น
ก่อนที่คุณจะเริ่มบทช่วยสอนนี้คุณควรมีความรู้พื้นฐานเกี่ยวกับข้อมูลที่ครอบคลุมในบทแนะนำ PHP และ HTML ของเรา
บทช่วยสอนนี้มุ่งเน้นไปที่การใช้ MySQL ในสภาพแวดล้อม PHP ตัวอย่างมากมายในบทช่วยสอนนี้จะเป็นประโยชน์สำหรับโปรแกรมเมอร์ PHP
เราขอแนะนำให้คุณตรวจสอบPHP Tutorialเพื่อเป็นข้อมูลอ้างอิงของคุณ
ดาวน์โหลดทั้งหมดสำหรับ MySQL จะอยู่ที่ดาวน์โหลด MySQL เลือกหมายเลขเวอร์ชันของMySQL Community Server ซึ่งจำเป็นต้องใช้ร่วมกับแพลตฟอร์มที่คุณจะใช้งาน
การติดตั้ง MySQL บน Linux / UNIX
วิธีที่แนะนำในการติดตั้ง MySQL บนระบบ Linux คือผ่าน RPM MySQL AB ทำให้ RPM ต่อไปนี้สามารถดาวน์โหลดได้บนเว็บไซต์ -
MySQL - เซิร์ฟเวอร์ฐานข้อมูล MySQL จัดการฐานข้อมูลและตารางควบคุมการเข้าถึงของผู้ใช้และประมวลผลการสืบค้น SQL
MySQL-client - โปรแกรมไคลเอนต์ MySQL ซึ่งทำให้สามารถเชื่อมต่อและโต้ตอบกับเซิร์ฟเวอร์ได้
MySQL-devel - ไลบรารีและไฟล์ส่วนหัวที่มีประโยชน์เมื่อรวบรวมโปรแกรมอื่น ๆ ที่ใช้ MySQL
MySQL-shared - ไลบรารีที่ใช้ร่วมกันสำหรับไคลเอนต์ MySQL
MySQL-bench - เกณฑ์มาตรฐานและเครื่องมือทดสอบประสิทธิภาพสำหรับเซิร์ฟเวอร์ฐานข้อมูล MySQL
MySQL RPM ที่แสดงที่นี่สร้างขึ้นจากไฟล์ SuSE Linux systemแต่โดยปกติแล้วพวกมันจะทำงานกับ Linux รุ่นอื่น ๆ ได้อย่างไม่ยากเย็น
ตอนนี้คุณจะต้องปฏิบัติตามขั้นตอนที่ระบุด้านล่างเพื่อดำเนินการติดตั้ง -
เข้าสู่ระบบโดยใช้ root ผู้ใช้
เปลี่ยนเป็นไดเร็กทอรีที่มี RPM
ติดตั้งเซิร์ฟเวอร์ฐานข้อมูล MySQL โดยดำเนินการคำสั่งต่อไปนี้ อย่าลืมแทนที่ชื่อไฟล์เป็นตัวเอียงด้วยชื่อไฟล์ RPM ของคุณ
[root@host]# rpm -i MySQL-5.0.9-0.i386.rpm
คำสั่งดังกล่าวดูแลการติดตั้งเซิร์ฟเวอร์ MySQL สร้างผู้ใช้ MySQL สร้างการกำหนดค่าที่จำเป็นและเริ่มเซิร์ฟเวอร์ MySQL โดยอัตโนมัติ
คุณสามารถค้นหาไบนารีที่เกี่ยวข้องกับ MySQL ทั้งหมดใน / usr / bin และ / usr / sbin ตารางและฐานข้อมูลทั้งหมดจะถูกสร้างขึ้นในไดเร็กทอรี / var / lib / mysql
กล่องรหัสต่อไปนี้มีขั้นตอนที่เป็นทางเลือก แต่แนะนำในการติดตั้ง RPM ที่เหลือในลักษณะเดียวกัน -
[root@host]# rpm -i MySQL-client-5.0.9-0.i386.rpm
[root@host]# rpm -i MySQL-devel-5.0.9-0.i386.rpm
[root@host]# rpm -i MySQL-shared-5.0.9-0.i386.rpm
[root@host]# rpm -i MySQL-bench-5.0.9-0.i386.rpm
การติดตั้ง MySQL บน Windows
การติดตั้งเริ่มต้นใน Windows ทุกเวอร์ชันนั้นง่ายกว่าที่เคยเป็นมามากเนื่องจากขณะนี้ MySQL มาพร้อมกับโปรแกรมติดตั้งอย่างเรียบร้อย เพียงดาวน์โหลดแพ็คเกจตัวติดตั้งเปิดเครื่องรูดที่ใดก็ได้และเรียกใช้ไฟล์ setup.exe
โปรแกรมติดตั้งเริ่มต้น setup.exe จะแนะนำคุณตลอดกระบวนการเล็กน้อยและโดยค่าเริ่มต้นจะติดตั้งทุกอย่างภายใต้ C: \ mysql
ทดสอบเซิร์ฟเวอร์โดยเริ่มจากพรอมต์คำสั่งในครั้งแรก ไปที่ตำแหน่งของไฟล์mysqld server ซึ่งน่าจะเป็น C: \ mysql \ bin และพิมพ์ -
mysqld.exe --console
NOTE - หากคุณใช้ NT คุณจะต้องใช้ mysqld-nt.exe แทน mysqld.exe
หากทุกอย่างเป็นไปด้วยดีคุณจะเห็นข้อความบางอย่างเกี่ยวกับการเริ่มต้นและ InnoDB. หากไม่เป็นเช่นนั้นคุณอาจมีปัญหาเรื่องสิทธิ์ ตรวจสอบให้แน่ใจว่าไดเร็กทอรีที่เก็บข้อมูลของคุณสามารถเข้าถึงได้โดยผู้ใช้ (อาจเป็น MySQL) ที่กระบวนการฐานข้อมูลทำงานอยู่
MySQL จะไม่เพิ่มตัวเองลงในเมนูเริ่มและไม่มีวิธี GUI ที่ดีเป็นพิเศษในการหยุดเซิร์ฟเวอร์ ดังนั้นหากคุณมีแนวโน้มที่จะเริ่มต้นเซิร์ฟเวอร์โดยการดับเบิลคลิกที่ไฟล์ปฏิบัติการ mysqld คุณควรจำไว้ว่าให้หยุดกระบวนการด้วยตนเองโดยใช้ mysqladmin, รายการงาน, ตัวจัดการงานหรือวิธีการเฉพาะ Windows อื่น ๆ
การตรวจสอบการติดตั้ง MySQL
หลังจากติดตั้ง MySQL เรียบร้อยแล้วตารางพื้นฐานได้รับการเตรียมใช้งานและเซิร์ฟเวอร์เริ่มทำงานแล้ว: คุณสามารถตรวจสอบได้ว่าทุกอย่างทำงานได้ตามที่ควรจะเป็นผ่านการทดสอบง่ายๆ
ใช้ mysqladmin Utility เพื่อรับสถานะเซิร์ฟเวอร์
ใช้ mysqladminไบนารีเพื่อตรวจสอบเวอร์ชันเซิร์ฟเวอร์ ไบนารีนี้จะมีอยู่ใน / usr / bin บน linux และใน C: \ mysql \ bin บน windows
[root@host]# mysqladmin --version
มันจะสร้างผลลัพธ์ต่อไปนี้บน Linux อาจแตกต่างกันไปขึ้นอยู่กับการติดตั้งของคุณ -
mysqladmin Ver 8.23 Distrib 5.0.9-0, for redhat-linux-gnu on i386
หากคุณไม่ได้รับข้อความดังกล่าวแสดงว่าอาจมีปัญหาในการติดตั้งของคุณและคุณต้องการความช่วยเหลือในการแก้ไข
ดำเนินการคำสั่ง SQL อย่างง่ายโดยใช้ MySQL Client
คุณสามารถเชื่อมต่อกับเซิร์ฟเวอร์ MySQL ของคุณผ่านไคลเอนต์ MySQL และโดยใช้ไฟล์ mysqlคำสั่ง ในขณะนี้คุณไม่จำเป็นต้องให้รหัสผ่านใด ๆ เนื่องจากโดยค่าเริ่มต้นรหัสผ่านจะถูกกำหนดเป็นค่าว่าง
คุณสามารถใช้คำสั่งต่อไปนี้ -
[root@host]# mysql
ควรได้รับรางวัลเป็นพรอมต์ mysql> ตอนนี้คุณเชื่อมต่อกับเซิร์ฟเวอร์ MySQL แล้วและคุณสามารถรันคำสั่ง SQL ทั้งหมดได้ที่พรอมต์ mysql> ดังนี้ -
mysql> SHOW DATABASES;
+----------+
| Database |
+----------+
| mysql |
| test |
+----------+
2 rows in set (0.13 sec)
ขั้นตอนหลังการติดตั้ง
MySQL มาพร้อมกับรหัสผ่านว่างสำหรับผู้ใช้ root MySQL ทันทีที่คุณติดตั้งฐานข้อมูลและไคลเอนต์สำเร็จคุณต้องตั้งรหัสผ่านรูทตามที่ระบุในบล็อกโค้ดต่อไปนี้ -
[root@host]# mysqladmin -u root password "new_password";
ตอนนี้ในการเชื่อมต่อกับเซิร์ฟเวอร์ MySQL ของคุณคุณจะต้องใช้คำสั่งต่อไปนี้ -
[root@host]# mysql -u root -p
Enter password:*******
ผู้ใช้ UNIX จะต้องการใส่ไดเร็กทอรี MySQL ของคุณใน PATH ของคุณด้วยดังนั้นคุณจะไม่ต้องพิมพ์พา ธ แบบเต็มทุกครั้งที่คุณต้องการใช้ไคลเอนต์บรรทัดคำสั่ง
สำหรับการทุบตีมันจะเป็นเช่น -
export PATH = $PATH:/usr/bin:/usr/sbin
เรียกใช้ MySQL ในเวลาบูต
หากคุณต้องการเรียกใช้เซิร์ฟเวอร์ MySQL ในเวลาบูตตรวจสอบให้แน่ใจว่าคุณมีรายการต่อไปนี้ในไฟล์ /etc/rc.local
/etc/init.d/mysqld start
นอกจากนี้คุณควรมีไบนารี mysqld ในไดเร็กทอรี /etc/init.d/
การเรียกใช้และการปิดเซิร์ฟเวอร์ MySQL
ก่อนอื่นให้ตรวจสอบว่าเซิร์ฟเวอร์ MySQL ของคุณกำลังทำงานอยู่หรือไม่ คุณสามารถใช้คำสั่งต่อไปนี้เพื่อตรวจสอบ -
ps -ef | grep mysqld
หาก MySql ของคุณกำลังทำงานอยู่คุณจะเห็น mysqldกระบวนการที่ระบุไว้ในผลลัพธ์ของคุณ หากเซิร์ฟเวอร์ไม่ทำงานคุณสามารถเริ่มได้โดยใช้คำสั่งต่อไปนี้ -
root@host# cd /usr/bin
./safe_mysqld &
ตอนนี้หากคุณต้องการปิดเซิร์ฟเวอร์ MySQL ที่รันอยู่แล้วคุณสามารถทำได้โดยใช้คำสั่งต่อไปนี้ -
root@host# cd /usr/bin
./mysqladmin -u root -p shutdown
Enter password: ******
การตั้งค่าบัญชีผู้ใช้ MySQL
สำหรับการเพิ่มผู้ใช้ใหม่ใน MySQL คุณเพียงแค่ต้องเพิ่มรายการใหม่ในไฟล์ user ตารางในฐานข้อมูล mysql.
โปรแกรมต่อไปนี้เป็นตัวอย่างของการเพิ่มผู้ใช้ใหม่ guest ด้วยสิทธิ์ SELECT, INSERT และ UPDATE ด้วยรหัสผ่าน guest123; แบบสอบถาม SQL คือ -
root@host# mysql -u root -p
Enter password:*******
mysql> use mysql;
Database changed
mysql> INSERT INTO user
(host, user, password,
select_priv, insert_priv, update_priv)
VALUES ('localhost', 'guest',
PASSWORD('guest123'), 'Y', 'Y', 'Y');
Query OK, 1 row affected (0.20 sec)
mysql> FLUSH PRIVILEGES;
Query OK, 1 row affected (0.01 sec)
mysql> SELECT host, user, password FROM user WHERE user = 'guest';
+-----------+---------+------------------+
| host | user | password |
+-----------+---------+------------------+
| localhost | guest | 6f8c114b58f2ce9e |
+-----------+---------+------------------+
1 row in set (0.00 sec)
เมื่อเพิ่มผู้ใช้ใหม่อย่าลืมเข้ารหัสรหัสผ่านใหม่โดยใช้ฟังก์ชัน PASSWORD () ที่ MySQL ให้มา ดังที่คุณเห็นในตัวอย่างด้านบนรหัสผ่าน mypass ถูกเข้ารหัสเป็น 6f8c114b58f2ce9e
สังเกตคำสั่ง FLUSH PRIVILEGES สิ่งนี้บอกให้เซิร์ฟเวอร์โหลดตารางการให้สิทธิ์ซ้ำ หากคุณไม่ได้ใช้งานคุณจะไม่สามารถเชื่อมต่อกับ MySQL โดยใช้บัญชีผู้ใช้ใหม่ได้อย่างน้อยจนกว่าเซิร์ฟเวอร์จะรีบูต
คุณยังสามารถระบุสิทธิพิเศษอื่น ๆ ให้กับผู้ใช้ใหม่ได้โดยตั้งค่าของคอลัมน์ต่อไปนี้ในตารางผู้ใช้เป็น "Y" เมื่อเรียกใช้แบบสอบถาม INSERT หรือคุณสามารถอัปเดตได้ในภายหลังโดยใช้แบบสอบถาม UPDATE
- Select_priv
- Insert_priv
- Update_priv
- Delete_priv
- Create_priv
- Drop_priv
- Reload_priv
- Shutdown_priv
- Process_priv
- File_priv
- Grant_priv
- References_priv
- Index_priv
- Alter_priv
อีกวิธีในการเพิ่มบัญชีผู้ใช้คือการใช้คำสั่ง GRANT SQL ตัวอย่างต่อไปนี้จะเพิ่มผู้ใช้zara ด้วยรหัสผ่าน zara123 สำหรับฐานข้อมูลเฉพาะซึ่งมีชื่อว่า TUTORIALS.
root@host# mysql -u root -p password;
Enter password:*******
mysql> use mysql;
Database changed
mysql> GRANT SELECT,INSERT,UPDATE,DELETE,CREATE,DROP
-> ON TUTORIALS.*
-> TO 'zara'@'localhost'
-> IDENTIFIED BY 'zara123';
สิ่งนี้จะสร้างรายการในตารางฐานข้อมูล MySQL ที่เรียกว่าเป็น user.
NOTE - MySQL จะไม่ยุติคำสั่งจนกว่าคุณจะใส่เครื่องหมายเซมิโคลอน (;) ที่ท้ายคำสั่ง SQL
การกำหนดค่าไฟล์ /etc/my.cnf
ในกรณีส่วนใหญ่คุณไม่ควรสัมผัสไฟล์นี้ โดยค่าเริ่มต้นจะมีรายการต่อไปนี้ -
[mysqld]
datadir = /var/lib/mysql
socket = /var/lib/mysql/mysql.sock
[mysql.server]
user = mysql
basedir = /var/lib
[safe_mysqld]
err-log = /var/log/mysqld.log
pid-file = /var/run/mysqld/mysqld.pid
ที่นี่คุณสามารถระบุไดเร็กทอรีอื่นสำหรับบันทึกข้อผิดพลาดมิฉะนั้นคุณไม่ควรเปลี่ยนรายการใด ๆ ในตารางนี้
คำสั่งการดูแลระบบ MySQL
นี่คือรายการคำสั่ง MySQL ที่สำคัญซึ่งคุณจะใช้เป็นครั้งคราวเพื่อทำงานกับฐานข้อมูล MySQL -
USE Databasename − This will be used to select a database in the MySQL workarea.
SHOW DATABASES − Lists out the databases that are accessible by the MySQL DBMS.
SHOW TABLES − Shows the tables in the database once a database has been selected with the use command.
SHOW COLUMNS FROM tablename: Shows the attributes, types of attributes, key information, whether NULL is permitted, defaults, and other information for a table.
SHOW INDEX FROM tablename − Presents the details of all indexes on the table, including the PRIMARY KEY.
SHOW TABLE STATUS LIKE tablename\G − Reports details of the MySQL DBMS performance and statistics.
In the next chapter, we will discuss regarding how PHP Syntax is used in MySQL.
MySQL works very well in combination of various programming languages like PERL, C, C++, JAVA and PHP. Out of these languages, PHP is the most popular one because of its web application development capabilities.
This tutorial focuses heavily on using MySQL in a PHP environment. If you are interested in MySQL with PERL, then you can consider reading the PERL Tutorial.
PHP provides various functions to access the MySQL database and to manipulate the data records inside the MySQL database. You would require to call the PHP functions in the same way you call any other PHP function.
The PHP functions for use with MySQL have the following general format −
mysql_function(value,value,...);
The second part of the function name is specific to the function, usually a word that describes what the function does. The following are two of the functions, which we will use in our tutorial −
mysqli_connect($connect);
mysqli_query($connect,"SQL statement");
The following example shows a generic syntax of PHP to call any MySQL function.
<html>
<head>
<title>PHP with MySQL</title>
</head>
<body>
<?php
$retval = mysql_function(value, [value,...]);
if( !$retval ) {
die ( "Error: a related error message" );
}
// Otherwise MySQL or PHP Statements
?>
</body>
</html>
Starting from the next chapter, we will see all the important MySQL functionality along with PHP.
MySQL Connection Using MySQL Binary
You can establish the MySQL database using the mysql binary at the command prompt.
Example
Here is a simple example to connect to the MySQL server from the command prompt −
[root@host]# mysql -u root -p
Enter password:******
This will give you the mysql> command prompt where you will be able to execute any SQL command. Following is the result of above command −
The following code block shows the result of above code −
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 2854760 to server version: 5.0.9
Type 'help;' or '\h' for help. Type '\c' to clear the buffer.
In the above example, we have used root as a user but you can use any other user as well. Any user will be able to perform all the SQL operations, which are allowed to that user.
You can disconnect from the MySQL database any time using the exit command at mysql> prompt.
mysql> exit
Bye
MySQL Connection Using PHP Script
PHP provides mysql_connect() function to open a database connection. This function takes five parameters and returns a MySQL link identifier on success or FALSE on failure.
Syntax
connection mysql_connect(server,user,passwd,new_link,client_flag);
Sr.No. | Parameter & Description |
---|---|
1 | server Optional − The host name running the database server. If not specified, then the default value will be localhost:3306. |
2 | user Optional − The username accessing the database. If not specified, then the default will be the name of the user that owns the server process. |
3 | passwd Optional − The password of the user accessing the database. If not specified, then the default will be an empty password. |
4 | new_link Optional − If a second call is made to mysql_connect() with the same arguments, no new connection will be established; instead, the identifier of the already opened connection will be returned. |
5 | client_flags Optional − A combination of the following constants −
|
You can disconnect from the MySQL database anytime using another PHP function mysql_close(). This function takes a single parameter, which is a connection returned by the mysql_connect() function.
Syntax
bool mysql_close ( resource $link_identifier );
If a resource is not specified, then the last opened database is closed. This function returns true if it closes the connection successfully otherwise it returns false.
Example
Try the following example to connect to a MySQL server −
<html>
<head>
<title>Connecting MySQL Server</title>
</head>
<body>
<?php
$dbhost = 'localhost:3306'; $dbuser = 'guest';
$dbpass = 'guest123'; $conn = mysql_connect($dbhost, $dbuser, $dbpass); if(! $conn ) {
die('Could not connect: ' . mysql_error());
}
echo 'Connected successfully';
mysql_close($conn);
?>
</body>
</html>
Create Database Using mysqladmin
You would need special privileges to create or to delete a MySQL database. So assuming you have access to the root user, you can create any database using the mysql mysqladmin binary.
Example
Here is a simple example to create a database called TUTORIALS −
[root@host]# mysqladmin -u root -p create TUTORIALS
Enter password:******
This will create a MySQL database called TUTORIALS.
Create a Database using PHP Script
PHP uses mysql_query function to create or delete a MySQL database. This function takes two parameters and returns TRUE on success or FALSE on failure.
Syntax
bool mysql_query( sql, connection );
Sr.No. | Parameter & Description |
---|---|
1 | sql Required - SQL query to create or delete a MySQL database |
2 | connection Optional - if not specified, then the last opened connection by mysql_connect will be used. |
Example
The following example to create a database −
<html>
<head>
<title>Creating MySQL Database</title>
</head>
<body>
<?php
$dbhost = 'localhost:3036';
$dbuser = 'root'; $dbpass = 'rootpassword';
$conn = mysql_connect($dbhost, $dbuser, $dbpass);
if(! $conn ) { die('Could not connect: ' . mysql_error()); } echo 'Connected successfully<br />'; $sql = 'CREATE DATABASE TUTORIALS';
$retval = mysql_query( $sql, $conn ); if(! $retval ) {
die('Could not create database: ' . mysql_error());
}
echo "Database TUTORIALS created successfully\n";
mysql_close($conn);
?>
</body>
</html>
Drop a Database using mysqladmin
You would need special privileges to create or to delete a MySQL database. So, assuming you have access to the root user, you can create any database using the mysql mysqladmin binary.
Be careful while deleting any database because you will lose your all the data available in your database.
Here is an example to delete a database(TUTORIALS) created in the previous chapter −
[root@host]# mysqladmin -u root -p drop TUTORIALS
Enter password:******
This will give you a warning and it will confirm if you really want to delete this database or not.
Dropping the database is potentially a very bad thing to do.
Any data stored in the database will be destroyed.
Do you really want to drop the 'TUTORIALS' database [y/N] y
Database "TUTORIALS" dropped
Drop Database using PHP Script
PHP uses mysql_query function to create or delete a MySQL database. This function takes two parameters and returns TRUE on success or FALSE on failure.
Syntax
bool mysql_query( sql, connection );
Sr.No | Parameter & Description |
---|---|
1 | sql Required − SQL query to create or delete a MySQL database |
2 | connection Optional − if not specified, then the last opened connection by mysql_connect will be used. |
Example
Try the following example to delete a database −
<html>
<head>
<title>Deleting MySQL Database</title>
</head>
<body>
<?php
$dbhost = 'localhost:3036';
$dbuser = 'root'; $dbpass = 'rootpassword';
$conn = mysql_connect($dbhost, $dbuser, $dbpass);
if(! $conn ) { die('Could not connect: ' . mysql_error()); } echo 'Connected successfully<br />'; $sql = 'DROP DATABASE TUTORIALS';
$retval = mysql_query( $sql, $conn ); if(! $retval ) {
die('Could not delete database: ' . mysql_error());
}
echo "Database TUTORIALS deleted successfully\n";
mysql_close($conn);
?>
</body>
</html>
WARNING − While deleting a database using the PHP script, it does not prompt you for any confirmation. So be careful while deleting a MySQL database.
Once you get connected with the MySQL server, it is required to select a database to work with. This is because there might be more than one database available with the MySQL Server.
Selecting MySQL Database from the Command Prompt
It is very simple to select a database from the mysql> prompt. You can use the SQL command use to select a database.
Example
Here is an example to select a database called TUTORIALS −
[root@host]# mysql -u root -p
Enter password:******
mysql> use TUTORIALS;
Database changed
mysql>
Now, you have selected the TUTORIALS database and all the subsequent operations will be performed on the TUTORIALS database.
NOTE − All the database names, table names, table fields name are case sensitive. So you would have to use the proper names while giving any SQL command.
Selecting a MySQL Database Using PHP Script
PHP provides function mysql_select_db to select a database. It returns TRUE on success or FALSE on failure.
Syntax
bool mysql_select_db( db_name, connection );
Sr.No. | Parameter & Description |
---|---|
1 | db_name Required − MySQL Database name to be selected |
2 | connection Optional − if not specified, then the last opened connection by mysql_connect will be used. |
Example
Here is an example showing you how to select a database.
<html>
<head>
<title>Selecting MySQL Database</title>
</head>
<body>
<?php
$dbhost = 'localhost:3036';
$dbuser = 'guest'; $dbpass = 'guest123';
$conn = mysql_connect($dbhost, $dbuser, $dbpass);
if(! $conn ) { die('Could not connect: ' . mysql_error()); } echo 'Connected successfully'; mysql_select_db( 'TUTORIALS' ); mysql_close($conn);
?>
</body>
</html>
Properly defining the fields in a table is important to the overall optimization of your database. You should use only the type and size of field you really need to use. For example, do not define a field 10 characters wide, if you know you are only going to use 2 characters. These type of fields (or columns) are also referred to as data types, after the type of data you will be storing in those fields.
MySQL uses many different data types broken into three categories −
- Numeric
- Date and Time
- String Types.
Let us now discuss them in detail.
Numeric Data Types
MySQL uses all the standard ANSI SQL numeric data types, so if you're coming to MySQL from a different database system, these definitions will look familiar to you.
The following list shows the common numeric data types and their descriptions −
INT − A normal-sized integer that can be signed or unsigned. If signed, the allowable range is from -2147483648 to 2147483647. If unsigned, the allowable range is from 0 to 4294967295. You can specify a width of up to 11 digits.
TINYINT − A very small integer that can be signed or unsigned. If signed, the allowable range is from -128 to 127. If unsigned, the allowable range is from 0 to 255. You can specify a width of up to 4 digits.
SMALLINT − A small integer that can be signed or unsigned. If signed, the allowable range is from -32768 to 32767. If unsigned, the allowable range is from 0 to 65535. You can specify a width of up to 5 digits.
MEDIUMINT − A medium-sized integer that can be signed or unsigned. If signed, the allowable range is from -8388608 to 8388607. If unsigned, the allowable range is from 0 to 16777215. You can specify a width of up to 9 digits.
BIGINT − A large integer that can be signed or unsigned. If signed, the allowable range is from -9223372036854775808 to 9223372036854775807. If unsigned, the allowable range is from 0 to 18446744073709551615. You can specify a width of up to 20 digits.
FLOAT(M,D) − A floating-point number that cannot be unsigned. You can define the display length (M) and the number of decimals (D). This is not required and will default to 10,2, where 2 is the number of decimals and 10 is the total number of digits (including decimals). Decimal precision can go to 24 places for a FLOAT.
DOUBLE(M,D) − A double precision floating-point number that cannot be unsigned. You can define the display length (M) and the number of decimals (D). This is not required and will default to 16,4, where 4 is the number of decimals. Decimal precision can go to 53 places for a DOUBLE. REAL is a synonym for DOUBLE.
DECIMAL(M,D) − An unpacked floating-point number that cannot be unsigned. In the unpacked decimals, each decimal corresponds to one byte. Defining the display length (M) and the number of decimals (D) is required. NUMERIC is a synonym for DECIMAL.
Date and Time Types
The MySQL date and time datatypes are as follows −
DATE − A date in YYYY-MM-DD format, between 1000-01-01 and 9999-12-31. For example, December 30th, 1973 would be stored as 1973-12-30.
DATETIME − A date and time combination in YYYY-MM-DD HH:MM:SS format, between 1000-01-01 00:00:00 and 9999-12-31 23:59:59. For example, 3:30 in the afternoon on December 30th, 1973 would be stored as 1973-12-30 15:30:00.
TIMESTAMP − A timestamp between midnight, January 1st, 1970 and sometime in 2037. This looks like the previous DATETIME format, only without the hyphens between numbers; 3:30 in the afternoon on December 30th, 1973 would be stored as 19731230153000 ( YYYYMMDDHHMMSS ).
TIME − Stores the time in a HH:MM:SS format.
YEAR(M) − Stores a year in a 2-digit or a 4-digit format. If the length is specified as 2 (for example YEAR(2)), YEAR can be between 1970 to 2069 (70 to 69). If the length is specified as 4, then YEAR can be 1901 to 2155. The default length is 4.
String Types
Although the numeric and date types are fun, most data you'll store will be in a string format. This list describes the common string datatypes in MySQL.
CHAR(M) − A fixed-length string between 1 and 255 characters in length (for example CHAR(5)), right-padded with spaces to the specified length when stored. Defining a length is not required, but the default is 1.
VARCHAR(M) − A variable-length string between 1 and 255 characters in length. For example, VARCHAR(25). You must define a length when creating a VARCHAR field.
BLOB or TEXT − A field with a maximum length of 65535 characters. BLOBs are "Binary Large Objects" and are used to store large amounts of binary data, such as images or other types of files. Fields defined as TEXT also hold large amounts of data. The difference between the two is that the sorts and comparisons on the stored data are case sensitive on BLOBs and are not case sensitive in TEXT fields. You do not specify a length with BLOB or TEXT.
TINYBLOB or TINYTEXT − A BLOB or TEXT column with a maximum length of 255 characters. You do not specify a length with TINYBLOB or TINYTEXT.
MEDIUMBLOB or MEDIUMTEXT − A BLOB or TEXT column with a maximum length of 16777215 characters. You do not specify a length with MEDIUMBLOB or MEDIUMTEXT.
LONGBLOB or LONGTEXT − A BLOB or TEXT column with a maximum length of 4294967295 characters. You do not specify a length with LONGBLOB or LONGTEXT.
ENUM − An enumeration, which is a fancy term for list. When defining an ENUM, you are creating a list of items from which the value must be selected (or it can be NULL). For example, if you wanted your field to contain "A" or "B" or "C", you would define your ENUM as ENUM ('A', 'B', 'C') and only those values (or NULL) could ever populate that field.
In the next chapter, we will discuss how to create tables in MySQL.
To begin with, the table creation command requires the following details −
- Name of the table
- Name of the fields
- Definitions for each field
Syntax
Here is a generic SQL syntax to create a MySQL table −
CREATE TABLE table_name (column_name column_type);
Now, we will create the following table in the TUTORIALS database.
create table tutorials_tbl(
tutorial_id INT NOT NULL AUTO_INCREMENT,
tutorial_title VARCHAR(100) NOT NULL,
tutorial_author VARCHAR(40) NOT NULL,
submission_date DATE,
PRIMARY KEY ( tutorial_id )
);
Here, a few items need explanation −
Field Attribute NOT NULL is being used because we do not want this field to be NULL. So, if a user will try to create a record with a NULL value, then MySQL will raise an error.
Field Attribute AUTO_INCREMENT tells MySQL to go ahead and add the next available number to the id field.
Keyword PRIMARY KEY is used to define a column as a primary key. You can use multiple columns separated by a comma to define a primary key.
Creating Tables from Command Prompt
It is easy to create a MySQL table from the mysql> prompt. You will use the SQL command CREATE TABLE to create a table.
Example
Here is an example, which will create tutorials_tbl −
root@host# mysql -u root -p
Enter password:*******
mysql> use TUTORIALS;
Database changed
mysql> CREATE TABLE tutorials_tbl(
-> tutorial_id INT NOT NULL AUTO_INCREMENT,
-> tutorial_title VARCHAR(100) NOT NULL,
-> tutorial_author VARCHAR(40) NOT NULL,
-> submission_date DATE,
-> PRIMARY KEY ( tutorial_id )
-> );
Query OK, 0 rows affected (0.16 sec)
mysql>
NOTE − MySQL does not terminate a command until you give a semicolon (;) at the end of SQL command.
Creating Tables Using PHP Script
To create new table in any existing database you would need to use PHP function mysql_query(). You will pass its second argument with a proper SQL command to create a table.
Example
The following program is an example to create a table using PHP script −
<html>
<head>
<title>Creating MySQL Tables</title>
</head>
<body>
<?php
$dbhost = 'localhost:3036'; $dbuser = 'root';
$dbpass = 'rootpassword'; $conn = mysql_connect($dbhost, $dbuser, $dbpass); if(! $conn ) {
die('Could not connect: ' . mysql_error());
}
echo 'Connected successfully<br />';
$sql = "CREATE TABLE tutorials_tbl( ". "tutorial_id INT NOT NULL AUTO_INCREMENT, ". "tutorial_title VARCHAR(100) NOT NULL, ". "tutorial_author VARCHAR(40) NOT NULL, ". "submission_date DATE, ". "PRIMARY KEY ( tutorial_id )); "; mysql_select_db( 'TUTORIALS' ); $retval = mysql_query( $sql, $conn );
if(! $retval ) { die('Could not create table: ' . mysql_error()); } echo "Table created successfully\n"; mysql_close($conn);
?>
</body>
</html>
It is very easy to drop an existing MySQL table, but you need to be very careful while deleting any existing table because the data lost will not be recovered after deleting a table.
Syntax
Here is a generic SQL syntax to drop a MySQL table −
DROP TABLE table_name ;
Dropping Tables from the Command Prompt
To drop tables from the command prompt, we need to execute the DROP TABLE SQL command at the mysql> prompt.
Example
The following program is an example which deletes the tutorials_tbl −
root@host# mysql -u root -p
Enter password:*******
mysql> use TUTORIALS;
Database changed
mysql> DROP TABLE tutorials_tbl
Query OK, 0 rows affected (0.8 sec)
mysql>
Dropping Tables Using PHP Script
To drop an existing table in any database, you would need to use the PHP function mysql_query(). You will pass its second argument with a proper SQL command to drop a table.
Example
<html>
<head>
<title>Creating MySQL Tables</title>
</head>
<body>
<?php
$dbhost = 'localhost:3036'; $dbuser = 'root';
$dbpass = 'rootpassword'; $conn = mysql_connect($dbhost, $dbuser, $dbpass); if(! $conn ) {
die('Could not connect: ' . mysql_error());
}
echo 'Connected successfully<br />';
$sql = "DROP TABLE tutorials_tbl"; mysql_select_db( 'TUTORIALS' ); $retval = mysql_query( $sql, $conn );
if(! $retval ) { die('Could not delete table: ' . mysql_error()); } echo "Table deleted successfully\n"; mysql_close($conn);
?>
</body>
</html>
To insert data into a MySQL table, you would need to use the SQL INSERT INTO command. You can insert data into the MySQL table by using the mysql> prompt or by using any script like PHP.
Syntax
Here is a generic SQL syntax of INSERT INTO command to insert data into the MySQL table −
INSERT INTO table_name ( field1, field2,...fieldN )
VALUES
( value1, value2,...valueN );
To insert string data types, it is required to keep all the values into double or single quotes. For example "value".
Inserting Data from the Command Prompt
To insert data from the command prompt, we will use SQL INSERT INTO command to insert data into MySQL table tutorials_tbl.
Example
The following example will create 3 records into tutorials_tbl table −
root@host# mysql -u root -p password;
Enter password:*******
mysql> use TUTORIALS;
Database changed
mysql> INSERT INTO tutorials_tbl
->(tutorial_title, tutorial_author, submission_date)
->VALUES
->("Learn PHP", "John Poul", NOW());
Query OK, 1 row affected (0.01 sec)
mysql> INSERT INTO tutorials_tbl
->(tutorial_title, tutorial_author, submission_date)
->VALUES
->("Learn MySQL", "Abdul S", NOW());
Query OK, 1 row affected (0.01 sec)
mysql> INSERT INTO tutorials_tbl
->(tutorial_title, tutorial_author, submission_date)
->VALUES
->("JAVA Tutorial", "Sanjay", '2007-05-06');
Query OK, 1 row affected (0.01 sec)
mysql>
NOTE − Please note that all the arrow signs (->) are not a part of the SQL command. They are indicating a new line and they are created automatically by the MySQL prompt while pressing the enter key without giving a semicolon at the end of each line of the command.
In the above example, we have not provided a tutorial_id because at the time of table creation, we had given AUTO_INCREMENT option for this field. So MySQL takes care of inserting these IDs automatically. Here, NOW() is a MySQL function, which returns the current date and time.
Inserting Data Using a PHP Script
You can use the same SQL INSERT INTO command into the PHP function mysql_query() to insert data into a MySQL table.
Example
This example will take three parameters from the user and will insert them into the MySQL table −
<html>
<head>
<title>Add New Record in MySQL Database</title>
</head>
<body>
<?php
if(isset($_POST['add'])) { $dbhost = 'localhost:3036';
$dbuser = 'root'; $dbpass = 'rootpassword';
$conn = mysql_connect($dbhost, $dbuser, $dbpass);
if(! $conn ) { die('Could not connect: ' . mysql_error()); } if(! get_magic_quotes_gpc() ) { $tutorial_title = addslashes ($_POST['tutorial_title']); $tutorial_author = addslashes ($_POST['tutorial_author']); } else { $tutorial_title = $_POST['tutorial_title']; $tutorial_author = $_POST['tutorial_author']; } $submission_date = $_POST['submission_date']; $sql = "INSERT INTO tutorials_tbl ".
"(tutorial_title,tutorial_author, submission_date) "."VALUES ".
"('$tutorial_title','$tutorial_author','$submission_date')"; mysql_select_db('TUTORIALS'); $retval = mysql_query( $sql, $conn );
if(! $retval ) { die('Could not enter data: ' . mysql_error()); } echo "Entered data successfully\n"; mysql_close($conn);
} else {
?>
<form method = "post" action = "<?php $_PHP_SELF ?>">
<table width = "600" border = "0" cellspacing = "1" cellpadding = "2">
<tr>
<td width = "250">Tutorial Title</td>
<td>
<input name = "tutorial_title" type = "text" id = "tutorial_title">
</td>
</tr>
<tr>
<td width = "250">Tutorial Author</td>
<td>
<input name = "tutorial_author" type = "text" id = "tutorial_author">
</td>
</tr>
<tr>
<td width = "250">Submission Date [ yyyy-mm-dd ]</td>
<td>
<input name = "submission_date" type = "text" id = "submission_date">
</td>
</tr>
<tr>
<td width = "250"> </td>
<td> </td>
</tr>
<tr>
<td width = "250"> </td>
<td>
<input name = "add" type = "submit" id = "add" value = "Add Tutorial">
</td>
</tr>
</table>
</form>
<?php
}
?>
</body>
</html>
While doing a data insert, it is best to use the function get_magic_quotes_gpc() to check if the current configuration for magic quote is set or not. If this function returns false, then use the function addslashes() to add slashes before the quotes.
คุณสามารถตรวจสอบความถูกต้องหลายรอบเพื่อตรวจสอบว่าข้อมูลที่ป้อนถูกต้องหรือไม่และสามารถดำเนินการตามความเหมาะสมได้
SQL SELECTคำสั่งใช้เพื่อดึงข้อมูลจากฐานข้อมูล MySQL คุณสามารถใช้คำสั่งนี้ได้ที่ mysql> prompt เช่นเดียวกับในสคริปต์ใด ๆ เช่น PHP
ไวยากรณ์
นี่คือไวยากรณ์ SQL ทั่วไปของคำสั่ง SELECT เพื่อดึงข้อมูลจากตาราง MySQL -
SELECT field1, field2,...fieldN
FROM table_name1, table_name2...
[WHERE Clause]
[OFFSET M ][LIMIT N]
คุณสามารถใช้ตารางอย่างน้อยหนึ่งตารางที่คั่นด้วยลูกน้ำเพื่อรวมเงื่อนไขต่างๆโดยใช้คำสั่ง WHERE แต่คำสั่ง WHERE เป็นส่วนเสริมของคำสั่ง SELECT
คุณสามารถดึงฟิลด์ตั้งแต่หนึ่งฟิลด์ขึ้นไปในคำสั่ง SELECT เดียว
คุณสามารถระบุดาว (*) แทนช่องได้ ในกรณีนี้ SELECT จะส่งคืนฟิลด์ทั้งหมด
คุณสามารถระบุเงื่อนไขใด ๆ โดยใช้คำสั่ง WHERE
คุณสามารถระบุออฟเซ็ตโดยใช้ OFFSETจากจุดที่ SELECT จะเริ่มส่งคืนระเบียน โดยค่าเริ่มต้นค่าชดเชยจะเริ่มต้นที่ศูนย์
คุณสามารถ จำกัด จำนวนผลตอบแทนโดยใช้ LIMIT แอตทริบิวต์
ดึงข้อมูลจากพรอมต์คำสั่ง
สิ่งนี้จะใช้คำสั่ง SQL SELECT เพื่อดึงข้อมูลจากตาราง MySQL tutorials_tbl.
ตัวอย่าง
ตัวอย่างต่อไปนี้จะส่งคืนระเบียนทั้งหมดจากไฟล์ tutorials_tbl โต๊ะ -
root@host# mysql -u root -p password;
Enter password:*******
mysql> use TUTORIALS;
Database changed
mysql> SELECT * from tutorials_tbl
+-------------+----------------+-----------------+-----------------+
| tutorial_id | tutorial_title | tutorial_author | submission_date |
+-------------+----------------+-----------------+-----------------+
| 1 | Learn PHP | John Poul | 2007-05-21 |
| 2 | Learn MySQL | Abdul S | 2007-05-21 |
| 3 | JAVA Tutorial | Sanjay | 2007-05-21 |
+-------------+----------------+-----------------+-----------------+
3 rows in set (0.01 sec)
mysql>
การดึงข้อมูลโดยใช้สคริปต์ PHP
คุณสามารถใช้คำสั่ง SQL SELECT เดียวกันในฟังก์ชัน PHP mysql_query(). ฟังก์ชันนี้ใช้เพื่อดำเนินการคำสั่ง SQL และฟังก์ชัน PHP อื่นในภายหลังmysql_fetch_array()สามารถใช้เพื่อดึงข้อมูลที่เลือกทั้งหมด ฟังก์ชันนี้จะส่งคืนแถวเป็นอาร์เรย์ที่เชื่อมโยงอาร์เรย์ตัวเลขหรือทั้งสองอย่าง ฟังก์ชันนี้จะส่งกลับค่า FALSE หากไม่มีแถวเพิ่มเติม
โปรแกรมต่อไปนี้เป็นตัวอย่างง่ายๆซึ่งจะแสดงวิธีการดึง / แสดงบันทึกจากไฟล์ tutorials_tbl ตาราง.
ตัวอย่าง
บล็อกโค้ดต่อไปนี้จะแสดงบันทึกทั้งหมดจากตาราง tutorials_tbl
<?php
$dbhost = 'localhost:3036';
$dbuser = 'root'; $dbpass = 'rootpassword';
$conn = mysql_connect($dbhost, $dbuser, $dbpass);
if(! $conn ) { die('Could not connect: ' . mysql_error()); } $sql = 'SELECT tutorial_id, tutorial_title, tutorial_author, submission_date FROM tutorials_tbl';
mysql_select_db('TUTORIALS');
$retval = mysql_query( $sql, $conn ); if(! $retval ) {
die('Could not get data: ' . mysql_error());
}
while($row = mysql_fetch_array($retval, MYSQL_ASSOC)) {
echo "Tutorial ID :{$row['tutorial_id']} <br> ". "Title: {$row['tutorial_title']} <br> ".
"Author: {$row['tutorial_author']} <br> ". "Submission Date : {$row['submission_date']} <br> ".
"--------------------------------<br>";
}
echo "Fetched data successfully\n";
mysql_close($conn);
?>
เนื้อหาของแถวจะถูกกำหนดให้กับตัวแปร $ row และจากนั้นจะพิมพ์ค่าในแถวนั้น
NOTE - อย่าลืมใส่วงเล็บปีกกาเมื่อคุณต้องการแทรกค่าอาร์เรย์ลงในสตริงโดยตรง
ในตัวอย่างข้างต้นค่าคงที่ MYSQL_ASSOC ใช้เป็นอาร์กิวเมนต์ที่สองของฟังก์ชัน PHP mysql_fetch_array()เพื่อให้ส่งคืนแถวเป็นอาร์เรย์ที่เชื่อมโยงกัน ด้วยอาร์เรย์ที่เชื่อมโยงคุณสามารถเข้าถึงฟิลด์ได้โดยใช้ชื่อแทนการใช้ดัชนี
PHP มีฟังก์ชันอื่นที่เรียกว่า mysql_fetch_assoc()ซึ่งจะส่งคืนแถวเป็นอาร์เรย์ที่เชื่อมโยงด้วย
ตัวอย่าง
ตัวอย่างต่อไปนี้เพื่อแสดงระเบียนทั้งหมดจากตาราง tutorial_tbl โดยใช้ฟังก์ชัน mysql_fetch_assoc ()
<?php
$dbhost = 'localhost:3036'; $dbuser = 'root';
$dbpass = 'rootpassword'; $conn = mysql_connect($dbhost, $dbuser, $dbpass); if(! $conn ) {
die('Could not connect: ' . mysql_error());
}
$sql = 'SELECT tutorial_id, tutorial_title, tutorial_author, submission_date FROM tutorials_tbl'; mysql_select_db('TUTORIALS'); $retval = mysql_query( $sql, $conn );
if(! $retval ) { die('Could not get data: ' . mysql_error()); } while($row = mysql_fetch_assoc($retval)) { echo "Tutorial ID :{$row['tutorial_id']} <br> ".
"Title: {$row['tutorial_title']} <br> ". "Author: {$row['tutorial_author']} <br> ".
"Submission Date : {$row['submission_date']} <br> ". "--------------------------------<br>"; } echo "Fetched data successfully\n"; mysql_close($conn);
?>
คุณยังสามารถใช้ค่าคงที่ MYSQL_NUMเป็นอาร์กิวเมนต์ที่สองของฟังก์ชัน PHP mysql_fetch_array () สิ่งนี้จะทำให้ฟังก์ชันส่งคืนอาร์เรย์ด้วยดัชนีตัวเลข
ตัวอย่าง
ลองใช้ตัวอย่างต่อไปนี้เพื่อแสดงระเบียนทั้งหมดจากตาราง tutorials_tbl โดยใช้อาร์กิวเมนต์ MYSQL_NUM
<?php
$dbhost = 'localhost:3036'; $dbuser = 'root';
$dbpass = 'rootpassword'; $conn = mysql_connect($dbhost, $dbuser, $dbpass); if(! $conn ) {
die('Could not connect: ' . mysql_error());
}
$sql = 'SELECT tutorial_id, tutorial_title, tutorial_author, submission_date FROM tutorials_tbl'; mysql_select_db('TUTORIALS'); $retval = mysql_query( $sql, $conn );
if(! $retval ) { die('Could not get data: ' . mysql_error()); } while($row = mysql_fetch_array($retval, MYSQL_NUM)) { echo "Tutorial ID :{$row[0]} <br> ".
"Title: {$row[1]} <br> ". "Author: {$row[2]} <br> ".
"Submission Date : {$row[3]} <br> ". "--------------------------------<br>"; } echo "Fetched data successfully\n"; mysql_close($conn);
?>
ทั้งสามตัวอย่างข้างต้นจะให้ผลลัพธ์เดียวกัน
การปล่อยหน่วยความจำ
เป็นแนวทางปฏิบัติที่ดีในการปล่อยหน่วยความจำเคอร์เซอร์ในตอนท้ายของแต่ละคำสั่ง SELECT ซึ่งสามารถทำได้โดยใช้ฟังก์ชัน PHPmysql_free_result(). โปรแกรมต่อไปนี้เป็นตัวอย่างเพื่อแสดงวิธีการใช้งาน
ตัวอย่าง
ลองใช้ตัวอย่างต่อไปนี้ -
<?php
$dbhost = 'localhost:3036'; $dbuser = 'root';
$dbpass = 'rootpassword'; $conn = mysql_connect($dbhost, $dbuser, $dbpass); if(! $conn ) {
die('Could not connect: ' . mysql_error());
}
$sql = 'SELECT tutorial_id, tutorial_title, tutorial_author, submission_date FROM tutorials_tbl'; mysql_select_db('TUTORIALS'); $retval = mysql_query( $sql, $conn );
if(! $retval ) { die('Could not get data: ' . mysql_error()); } while($row = mysql_fetch_array($retval, MYSQL_NUM)) { echo "Tutorial ID :{$row[0]} <br> ".
"Title: {$row[1]} <br> ". "Author: {$row[2]} <br> ".
"Submission Date : {$row[3]} <br> ". "--------------------------------<br>"; } mysql_free_result($retval);
echo "Fetched data successfully\n";
mysql_close($conn);
?>
ในขณะดึงข้อมูลคุณสามารถเขียนโค้ดที่ซับซ้อนได้ตามต้องการ แต่ขั้นตอนจะยังคงเหมือนที่กล่าวไว้ข้างต้น
เราได้เห็น SQL SELECTคำสั่งเพื่อดึงข้อมูลจากตาราง MySQL เราสามารถใช้ประโยคเงื่อนไขที่เรียกว่าWHERE Clauseเพื่อกรองผลลัพธ์ออก การใช้คำสั่ง WHERE นี้เราสามารถระบุเกณฑ์การเลือกเพื่อเลือกระเบียนที่ต้องการจากตาราง
ไวยากรณ์
บล็อกรหัสต่อไปนี้มีไวยากรณ์ SQL ทั่วไปของคำสั่ง SELECT พร้อมด้วยคำสั่ง WHERE เพื่อดึงข้อมูลจากตาราง MySQL -
SELECT field1, field2,...fieldN table_name1, table_name2...
[WHERE condition1 [AND [OR]] condition2.....
คุณสามารถใช้ตารางอย่างน้อยหนึ่งตารางที่คั่นด้วยเครื่องหมายจุลภาคเพื่อรวมเงื่อนไขต่างๆโดยใช้คำสั่ง WHERE แต่คำสั่ง WHERE เป็นส่วนเสริมของคำสั่ง SELECT
คุณสามารถระบุเงื่อนไขใด ๆ โดยใช้คำสั่ง WHERE
คุณสามารถระบุเงื่อนไขได้มากกว่าหนึ่งเงื่อนไขโดยใช้ AND หรือ OR ตัวดำเนินการ
คำสั่ง WHERE สามารถใช้ร่วมกับคำสั่ง DELETE หรือ UPDATE SQL เพื่อระบุเงื่อนไขได้
WHERE อนุประโยคทำงานเหมือนไฟล์ if conditionในภาษาโปรแกรมใด ๆ ประโยคนี้ใช้เพื่อเปรียบเทียบค่าที่กำหนดกับค่าฟิลด์ที่มีอยู่ในตาราง MySQL หากค่าที่กำหนดจากภายนอกเท่ากับค่าฟิลด์ที่มีอยู่ในตาราง MySQL ค่านั้นจะส่งกลับแถวนั้น
นี่คือรายการตัวดำเนินการซึ่งสามารถใช้กับไฟล์ WHERE อนุประโยค
สมมติว่าฟิลด์ A ถือ 10 และฟิลด์ B ถือ 20 จากนั้น -
ตัวดำเนินการ | คำอธิบาย | ตัวอย่าง |
---|---|---|
= | ตรวจสอบว่าค่าของตัวถูกดำเนินการทั้งสองเท่ากันหรือไม่ถ้าใช่เงื่อนไขจะกลายเป็นจริง | (A = B) ไม่เป็นความจริง |
! = | ตรวจสอบว่าค่าของตัวถูกดำเนินการทั้งสองเท่ากันหรือไม่หากค่าไม่เท่ากันเงื่อนไขจะกลายเป็นจริง | (A! = B) เป็นจริง |
> | ตรวจสอบว่าค่าของตัวถูกดำเนินการด้านซ้ายมากกว่าค่าของตัวถูกดำเนินการด้านขวาหรือไม่ถ้าใช่เงื่อนไขจะกลายเป็นจริง | (A> B) ไม่เป็นความจริง |
< | ตรวจสอบว่าค่าของตัวถูกดำเนินการด้านซ้ายน้อยกว่าค่าของตัวถูกดำเนินการด้านขวาหรือไม่ถ้าใช่เงื่อนไขจะกลายเป็นจริง | (A <B) เป็นจริง |
> = | ตรวจสอบว่าค่าของตัวถูกดำเนินการด้านซ้ายมากกว่าหรือเท่ากับค่าของตัวถูกดำเนินการด้านขวาหรือไม่ถ้าใช่เงื่อนไขจะกลายเป็นจริง | (A> = B) ไม่เป็นความจริง |
<= | ตรวจสอบว่าค่าของตัวถูกดำเนินการด้านซ้ายน้อยกว่าหรือเท่ากับค่าของตัวถูกดำเนินการด้านขวาหรือไม่ถ้าใช่เงื่อนไขจะกลายเป็นจริง | (A <= B) เป็นจริง |
WHERE clause มีประโยชน์มากเมื่อคุณต้องการดึงข้อมูลแถวที่เลือกจากตารางโดยเฉพาะเมื่อคุณใช้ MySQL Join. การเข้าร่วมจะถูกกล่าวถึงในบทอื่น
เป็นเรื่องปกติในการค้นหาเรกคอร์ดโดยใช้ไฟล์ Primary Key เพื่อให้การค้นหาเร็วขึ้น
หากเงื่อนไขที่กำหนดไม่ตรงกับเรกคอร์ดใด ๆ ในตารางแบบสอบถามจะไม่ส่งคืนแถวใด ๆ
ดึงข้อมูลจากพรอมต์คำสั่ง
สิ่งนี้จะใช้คำสั่ง SQL SELECT กับส่วนคำสั่ง WHERE เพื่อดึงข้อมูลที่เลือกจากตาราง MySQL - tutorials_tbl.
ตัวอย่าง
ตัวอย่างต่อไปนี้จะส่งคืนระเบียนทั้งหมดจากไฟล์ tutorials_tbl ตารางที่ชื่อผู้แต่งคือ Sanjay.
root@host# mysql -u root -p password;
Enter password:*******
mysql> use TUTORIALS;
Database changed
mysql> SELECT * from tutorials_tbl WHERE tutorial_author = 'Sanjay';
+-------------+----------------+-----------------+-----------------+
| tutorial_id | tutorial_title | tutorial_author | submission_date |
+-------------+----------------+-----------------+-----------------+
| 3 | JAVA Tutorial | Sanjay | 2007-05-21 |
+-------------+----------------+-----------------+-----------------+
1 rows in set (0.01 sec)
mysql>
เว้นแต่จะดำเนินการก LIKEการเปรียบเทียบสตริงการเปรียบเทียบไม่คำนึงถึงขนาดตัวพิมพ์ คุณสามารถทำให้กรณีการค้นหาของคุณมีความละเอียดอ่อนโดยใช้ไฟล์BINARY คีย์เวิร์ดดังนี้ -
root@host# mysql -u root -p password;
Enter password:*******
mysql> use TUTORIALS;
Database changed
mysql> SELECT * from tutorials_tbl \
WHERE BINARY tutorial_author = 'sanjay';
Empty set (0.02 sec)
mysql>
การดึงข้อมูลโดยใช้สคริปต์ PHP
คุณสามารถใช้คำสั่ง SQL SELECT เดียวกันกับ WHERE CLAUSE ในฟังก์ชัน PHP mysql_query(). ฟังก์ชันนี้ใช้เพื่อดำเนินการคำสั่ง SQL และฟังก์ชัน PHP อื่นในภายหลังmysql_fetch_array()สามารถใช้เพื่อดึงข้อมูลที่เลือกทั้งหมด ฟังก์ชันนี้ส่งคืนแถวเป็นอาร์เรย์เชื่อมโยงอาร์เรย์ตัวเลขหรือทั้งสองอย่าง ฟังก์ชันนี้จะส่งกลับค่า FALSE หากไม่มีแถวเพิ่มเติม
ตัวอย่าง
ตัวอย่างต่อไปนี้จะส่งคืนระเบียนทั้งหมดจากไฟล์ tutorials_tbl ตารางที่ชื่อผู้แต่งคือ Sanjay -
<?php
$dbhost = 'localhost:3036';
$dbuser = 'root'; $dbpass = 'rootpassword';
$conn = mysql_connect($dbhost, $dbuser, $dbpass);
if(! $conn ) { die('Could not connect: ' . mysql_error()); } $sql = 'SELECT tutorial_id, tutorial_title,
tutorial_author, submission_date
FROM tutorials_tbl
WHERE tutorial_author = "Sanjay"';
mysql_select_db('TUTORIALS');
$retval = mysql_query( $sql, $conn ); if(! $retval ) {
die('Could not get data: ' . mysql_error());
}
while($row = mysql_fetch_array($retval, MYSQL_ASSOC)) {
echo "Tutorial ID :{$row['tutorial_id']} <br> ". "Title: {$row['tutorial_title']} <br> ".
"Author: {$row['tutorial_author']} <br> ". "Submission Date : {$row['submission_date']} <br> ".
"--------------------------------<br>";
}
echo "Fetched data successfully\n";
mysql_close($conn);
?>
อาจมีข้อกำหนดที่จำเป็นต้องแก้ไขข้อมูลที่มีอยู่ในตาราง MySQL คุณสามารถทำได้โดยใช้ SQLUPDATEคำสั่ง สิ่งนี้จะแก้ไขค่าฟิลด์ใด ๆ ของตาราง MySQL
ไวยากรณ์
บล็อกรหัสต่อไปนี้มีไวยากรณ์ SQL ทั่วไปของคำสั่ง UPDATE เพื่อแก้ไขข้อมูลในตาราง MySQL -
UPDATE table_name SET field1 = new-value1, field2 = new-value2
[WHERE Clause]
- คุณสามารถอัปเดตฟิลด์หนึ่งหรือหลายฟิลด์พร้อมกัน
- คุณสามารถระบุเงื่อนไขใด ๆ โดยใช้คำสั่ง WHERE
- คุณสามารถอัปเดตค่าในตารางเดียวได้ในแต่ละครั้ง
คำสั่ง WHERE มีประโยชน์มากเมื่อคุณต้องการอัปเดตแถวที่เลือกในตาราง
การอัปเดตข้อมูลจากพรอมต์คำสั่ง
สิ่งนี้จะใช้คำสั่ง SQL UPDATE กับส่วนคำสั่ง WHERE เพื่ออัปเดตข้อมูลที่เลือกในตาราง MySQL tutorials_tbl.
ตัวอย่าง
ตัวอย่างต่อไปนี้จะอัปเดตไฟล์ tutorial_title ฟิลด์สำหรับบันทึกที่มี tutorial_id เป็น 3
root@host# mysql -u root -p password;
Enter password:*******
mysql> use TUTORIALS;
Database changed
mysql> UPDATE tutorials_tbl
-> SET tutorial_title = 'Learning JAVA'
-> WHERE tutorial_id = 3;
Query OK, 1 row affected (0.04 sec)
Rows matched: 1 Changed: 1 Warnings: 0
mysql>
การอัปเดตข้อมูลโดยใช้สคริปต์ PHP
คุณสามารถใช้คำสั่ง SQL UPDATE โดยมีหรือไม่มี WHERE CLAUSE ในฟังก์ชัน PHP - mysql_query(). ฟังก์ชันนี้จะดำเนินการคำสั่ง SQL ในลักษณะเดียวกันกับที่เรียกใช้ที่พรอมต์ mysql>
ตัวอย่าง
ตัวอย่างต่อไปนี้เพื่ออัปเดต tutorial_title ฟิลด์สำหรับบันทึกที่มี tutorial_id เป็น 3
<?php
$dbhost = 'localhost:3036';
$dbuser = 'root'; $dbpass = 'rootpassword';
$conn = mysql_connect($dbhost, $dbuser, $dbpass);
if(! $conn ) { die('Could not connect: ' . mysql_error()); } $sql = 'UPDATE tutorials_tbl
SET tutorial_title="Learning JAVA"
WHERE tutorial_id=3';
mysql_select_db('TUTORIALS');
$retval = mysql_query( $sql, $conn ); if(! $retval ) {
die('Could not update data: ' . mysql_error());
}
echo "Updated data successfully\n";
mysql_close($conn);
?>
หากคุณต้องการลบบันทึกจากตาราง MySQL คุณสามารถใช้คำสั่ง SQL DELETE FROM. คุณสามารถใช้คำสั่งนี้ที่พรอมต์ mysql> เช่นเดียวกับในสคริปต์ใด ๆ เช่น PHP
ไวยากรณ์
บล็อกโค้ดต่อไปนี้มีไวยากรณ์ SQL ทั่วไปของคำสั่ง DELETE เพื่อลบข้อมูลจากตาราง MySQL
DELETE FROM table_name [WHERE Clause]
หากไม่ได้ระบุคำสั่ง WHERE ระเบียนทั้งหมดจะถูกลบออกจากตาราง MySQL ที่กำหนด
คุณสามารถระบุเงื่อนไขใด ๆ โดยใช้คำสั่ง WHERE
คุณสามารถลบระเบียนในตารางเดียวได้ในแต่ละครั้ง
คำสั่ง WHERE มีประโยชน์มากเมื่อคุณต้องการลบแถวที่เลือกในตาราง
การลบข้อมูลจากพรอมต์คำสั่ง
สิ่งนี้จะใช้คำสั่ง SQL DELETE กับส่วนคำสั่ง WHERE เพื่อลบข้อมูลที่เลือกลงในตาราง MySQL - tutorials_tbl.
ตัวอย่าง
ตัวอย่างต่อไปนี้จะลบบันทึกออกจาก tutorial_tbl ซึ่งมี tutorial_id เป็น 3
root@host# mysql -u root -p password;
Enter password:*******
mysql> use TUTORIALS;
Database changed
mysql> DELETE FROM tutorials_tbl WHERE tutorial_id=3;
Query OK, 1 row affected (0.23 sec)
mysql>
การลบข้อมูลโดยใช้สคริปต์ PHP
คุณสามารถใช้คำสั่ง SQL DELETE โดยมีหรือไม่มี WHERE CLAUSE ในฟังก์ชัน PHP - mysql_query(). ฟังก์ชันนี้จะดำเนินการคำสั่ง SQL ในลักษณะเดียวกับที่เรียกใช้ที่พรอมต์ mysql>
ตัวอย่าง
ลองใช้ตัวอย่างต่อไปนี้เพื่อลบบันทึกออกจาก tutorial_tbl ซึ่งมี tutorial_id เป็น 3
<?php
$dbhost = 'localhost:3036';
$dbuser = 'root'; $dbpass = 'rootpassword';
$conn = mysql_connect($dbhost, $dbuser, $dbpass);
if(! $conn ) { die('Could not connect: ' . mysql_error()); } $sql = 'DELETE FROM tutorials_tbl WHERE tutorial_id = 3';
mysql_select_db('TUTORIALS');
$retval = mysql_query( $sql, $conn ); if(! $retval ) {
die('Could not delete data: ' . mysql_error());
}
echo "Deleted data successfully\n";
mysql_close($conn);
?>
เราได้เห็น SQL SELECTคำสั่งเพื่อดึงข้อมูลจากตาราง MySQL นอกจากนี้เรายังสามารถใช้ประโยคเงื่อนไขที่เรียกว่าWHERE อนุประโยคเพื่อเลือกระเบียนที่ต้องการ
คำสั่ง WHERE ที่มีเครื่องหมาย 'เท่ากับ' (=) ทำงานได้ดีเมื่อเราต้องการจับคู่แบบตรงทั้งหมด เช่นถ้า "tutorial_author = 'Sanjay'" แต่อาจมีข้อกำหนดที่เราต้องการกรองผลลัพธ์ทั้งหมดโดยที่ชื่อ tutorial_author ควรมี "jay" สิ่งนี้สามารถจัดการได้โดยใช้SQL LIKE Clause พร้อมกับคำสั่ง WHERE
หากใช้คำสั่ง SQL LIKE ร่วมกับอักขระ% มันจะทำงานเหมือนอักขระเมตา (*) เช่นเดียวกับใน UNIX ในขณะที่แสดงรายการไฟล์หรือไดเรกทอรีทั้งหมดที่พร้อมท์คำสั่ง หากไม่มีอักขระ% ประโยค LIKE จะเหมือนกับไฟล์equal to ลงนามพร้อมกับ WHERE clause
ไวยากรณ์
บล็อกโค้ดต่อไปนี้มีไวยากรณ์ SQL ทั่วไปของคำสั่ง SELECT พร้อมกับประโยค LIKE เพื่อดึงข้อมูลจากตาราง MySQL
SELECT field1, field2,...fieldN table_name1, table_name2...
WHERE field1 LIKE condition1 [AND [OR]] filed2 = 'somevalue'
คุณสามารถระบุเงื่อนไขใด ๆ โดยใช้คำสั่ง WHERE
คุณสามารถใช้ประโยค LIKE ร่วมกับคำสั่ง WHERE ได้
คุณสามารถใช้ประโยค LIKE แทนไฟล์ equals to ลงชื่อ.
เมื่อใช้ LIKE ร่วมกับเครื่องหมาย% มันจะทำงานเหมือนการค้นหาอักขระเมตา
คุณสามารถระบุได้มากกว่าหนึ่งเงื่อนไขโดยใช้ AND หรือ OR ตัวดำเนินการ
คำสั่ง WHERE ... LIKE สามารถใช้ร่วมกับคำสั่ง DELETE หรือ UPDATE SQL เพื่อระบุเงื่อนไขได้
ใช้ประโยค LIKE ที่ Command Prompt
สิ่งนี้จะใช้คำสั่ง SQL SELECT กับคำสั่ง WHERE ... LIKE เพื่อดึงข้อมูลที่เลือกจากตาราง MySQL - tutorials_tbl.
ตัวอย่าง
ตัวอย่างต่อไปนี้จะส่งคืนระเบียนทั้งหมดจากไฟล์ tutorials_tbl ตารางที่ชื่อผู้แต่งลงท้ายด้วย jay -
root@host# mysql -u root -p password;
Enter password:*******
mysql> use TUTORIALS;
Database changed
mysql> SELECT * from tutorials_tbl
-> WHERE tutorial_author LIKE '%jay';
+-------------+----------------+-----------------+-----------------+
| tutorial_id | tutorial_title | tutorial_author | submission_date |
+-------------+----------------+-----------------+-----------------+
| 3 | JAVA Tutorial | Sanjay | 2007-05-21 |
+-------------+----------------+-----------------+-----------------+
1 rows in set (0.01 sec)
mysql>
ใช้ LIKE clause ใน PHP Script
คุณสามารถใช้ไวยากรณ์ที่คล้ายกันของ WHERE ... LIKE clause ในฟังก์ชัน PHP - mysql_query(). ฟังก์ชันนี้ใช้เพื่อดำเนินการคำสั่ง SQL และฟังก์ชัน PHP อื่นในภายหลัง -mysql_fetch_array() สามารถใช้เพื่อดึงข้อมูลที่เลือกทั้งหมดหากใช้คำสั่ง WHERE ... LIKE พร้อมกับคำสั่ง SELECT
แต่ถ้ามีการใช้คำสั่ง WHERE ... LIKE กับคำสั่ง DELETE หรือ UPDATE ก็ไม่จำเป็นต้องเรียกใช้ฟังก์ชัน PHP อีก
ตัวอย่าง
ลองใช้ตัวอย่างต่อไปนี้เพื่อส่งคืนระเบียนทั้งหมดจากไฟล์ tutorials_tbl ตารางที่มีชื่อผู้แต่ง jay -
<?php
$dbhost = 'localhost:3036';
$dbuser = 'root'; $dbpass = 'rootpassword';
$conn = mysql_connect($dbhost, $dbuser, $dbpass);
if(! $conn ) { die('Could not connect: ' . mysql_error()); } $sql = 'SELECT tutorial_id, tutorial_title,
tutorial_author, submission_date
FROM tutorials_tbl
WHERE tutorial_author LIKE "%jay%"';
mysql_select_db('TUTORIALS');
$retval = mysql_query( $sql, $conn ); if(! $retval ) {
die('Could not get data: ' . mysql_error());
}
while($row = mysql_fetch_array($retval, MYSQL_ASSOC)) {
echo "Tutorial ID :{$row['tutorial_id']} <br> ". "Title: {$row['tutorial_title']} <br> ".
"Author: {$row['tutorial_author']} <br> ". "Submission Date : {$row['submission_date']} <br> ".
"--------------------------------<br>";
}
echo "Fetched data successfully\n";
mysql_close($conn);
?>
เราได้เห็น SQL SELECTคำสั่งเพื่อดึงข้อมูลจากตาราง MySQL เมื่อคุณเลือกแถวเซิร์ฟเวอร์ MySQL มีอิสระที่จะส่งคืนตามลำดับใด ๆ เว้นแต่คุณจะสั่งเป็นอย่างอื่นโดยบอกวิธีจัดเรียงผลลัพธ์ แต่คุณจัดเรียงชุดผลลัพธ์โดยการเพิ่มไฟล์ORDER BY ประโยคที่ตั้งชื่อคอลัมน์หรือคอลัมน์ที่คุณต้องการเรียงลำดับ
ไวยากรณ์
บล็อกรหัสต่อไปนี้เป็นไวยากรณ์ SQL ทั่วไปของคำสั่ง SELECT พร้อมกับคำสั่ง ORDER BY เพื่อจัดเรียงข้อมูลจากตาราง MySQL
SELECT field1, field2,...fieldN table_name1, table_name2...
ORDER BY field1, [field2...] [ASC [DESC]]
คุณสามารถจัดเรียงผลลัพธ์ที่ส่งคืนในฟิลด์ใดก็ได้หากฟิลด์นั้นถูกแสดงรายการ
คุณสามารถจัดเรียงผลลัพธ์ได้มากกว่าหนึ่งฟิลด์
คุณสามารถใช้คีย์เวิร์ด ASC หรือ DESC เพื่อให้ได้ผลลัพธ์จากน้อยไปมากหรือมากไปหาน้อย โดยค่าเริ่มต้นจะเรียงลำดับจากน้อยไปมาก
คุณสามารถใช้คำสั่ง WHERE ... LIKE ได้ตามปกติเพื่อวางเงื่อนไข
ใช้คำสั่ง ORDER BY ที่ Command Prompt
สิ่งนี้จะใช้คำสั่ง SQL SELECT กับไฟล์ ORDER BY อนุประโยคเพื่อดึงข้อมูลจากตาราง MySQL - tutorials_tbl.
ตัวอย่าง
ลองใช้ตัวอย่างต่อไปนี้ซึ่งจะส่งคืนผลลัพธ์ตามลำดับจากน้อยไปหามาก
root@host# mysql -u root -p password;
Enter password:*******
mysql> use TUTORIALS;
Database changed
mysql> SELECT * from tutorials_tbl ORDER BY tutorial_author ASC
+-------------+----------------+-----------------+-----------------+
| tutorial_id | tutorial_title | tutorial_author | submission_date |
+-------------+----------------+-----------------+-----------------+
| 2 | Learn MySQL | Abdul S | 2007-05-24 |
| 1 | Learn PHP | John Poul | 2007-05-24 |
| 3 | JAVA Tutorial | Sanjay | 2007-05-06 |
+-------------+----------------+-----------------+-----------------+
3 rows in set (0.42 sec)
mysql>
ตรวจสอบชื่อผู้แต่งทั้งหมดที่อยู่ในลำดับจากน้อยไปมาก
การใช้ ORDER BY clause ภายใน PHP Script
คุณสามารถใช้ไวยากรณ์ที่คล้ายกันของคำสั่ง ORDER BY ในฟังก์ชัน PHP - mysql_query(). ฟังก์ชันนี้ใช้เพื่อดำเนินการคำสั่ง SQL และฟังก์ชัน PHP อื่นในภายหลังmysql_fetch_array() สามารถใช้เพื่อดึงข้อมูลที่เลือกทั้งหมด
ตัวอย่าง
ลองใช้ตัวอย่างต่อไปนี้ซึ่งจะส่งคืนผลลัพธ์ตามลำดับจากมากไปหาน้อยของผู้เขียนบทช่วยสอน
<?php
$dbhost = 'localhost:3036';
$dbuser = 'root'; $dbpass = 'rootpassword';
$conn = mysql_connect($dbhost, $dbuser, $dbpass);
if(! $conn ) { die('Could not connect: ' . mysql_error()); } $sql = 'SELECT tutorial_id, tutorial_title,
tutorial_author, submission_date
FROM tutorials_tbl
ORDER BY tutorial_author DESC';
mysql_select_db('TUTORIALS');
$retval = mysql_query( $sql, $conn ); if(! $retval ) {
die('Could not get data: ' . mysql_error());
}
while($row = mysql_fetch_array($retval, MYSQL_ASSOC)) {
echo "Tutorial ID :{$row['tutorial_id']} <br> ". "Title: {$row['tutorial_title']} <br> ".
"Author: {$row['tutorial_author']} <br> ". "Submission Date : {$row['submission_date']} <br> ".
"--------------------------------<br>";
}
echo "Fetched data successfully\n";
mysql_close($conn);
?>
ในบทก่อนหน้านี้เราได้รับข้อมูลจากทีละตาราง สิ่งนี้ดีพอสำหรับการใช้งานง่ายๆ แต่ในการใช้งาน MySQL ในโลกแห่งความเป็นจริงส่วนใหญ่คุณมักจะต้องได้รับข้อมูลจากหลายตารางในแบบสอบถามเดียว
คุณสามารถใช้หลายตารางในแบบสอบถาม SQL เดียวของคุณ การเข้าร่วมใน MySQL หมายถึงการรวมสองตารางขึ้นไปเป็นตารางเดียว
คุณสามารถใช้ JOINS ในคำสั่ง SELECT, UPDATE และ DELETE เพื่อเข้าร่วมตาราง MySQL เราจะเห็นตัวอย่างของ LEFT JOIN ซึ่งแตกต่างจาก MySQL JOIN แบบธรรมดา
ใช้ Joins ที่ Command Prompt
สมมติว่าเรามีสองตาราง tcount_tbl และ tutorials_tblใน TUTORIALS ลองดูตัวอย่างด้านล่าง -
ตัวอย่าง
ตัวอย่างต่อไปนี้ -
root@host# mysql -u root -p password;
Enter password:*******
mysql> use TUTORIALS;
Database changed
mysql> SELECT * FROM tcount_tbl;
+-----------------+----------------+
| tutorial_author | tutorial_count |
+-----------------+----------------+
| mahran | 20 |
| mahnaz | NULL |
| Jen | NULL |
| Gill | 20 |
| John Poul | 1 |
| Sanjay | 1 |
+-----------------+----------------+
6 rows in set (0.01 sec)
mysql> SELECT * from tutorials_tbl;
+-------------+----------------+-----------------+-----------------+
| tutorial_id | tutorial_title | tutorial_author | submission_date |
+-------------+----------------+-----------------+-----------------+
| 1 | Learn PHP | John Poul | 2007-05-24 |
| 2 | Learn MySQL | Abdul S | 2007-05-24 |
| 3 | JAVA Tutorial | Sanjay | 2007-05-06 |
+-------------+----------------+-----------------+-----------------+
3 rows in set (0.00 sec)
mysql>
ตอนนี้เราสามารถเขียนแบบสอบถาม SQL เพื่อรวมสองตารางนี้ได้ แบบสอบถามนี้จะเลือกผู้เขียนทั้งหมดจากตารางtutorials_tbl และจะรับจำนวนบทเรียนที่สอดคล้องกันจากไฟล์ tcount_tbl.
mysql> SELECT a.tutorial_id, a.tutorial_author, b.tutorial_count
-> FROM tutorials_tbl a, tcount_tbl b
-> WHERE a.tutorial_author = b.tutorial_author;
+-------------+-----------------+----------------+
| tutorial_id | tutorial_author | tutorial_count |
+-------------+-----------------+----------------+
| 1 | John Poul | 1 |
| 3 | Sanjay | 1 |
+-------------+-----------------+----------------+
2 rows in set (0.01 sec)
mysql>
การใช้ Joins ใน PHP Script
คุณสามารถใช้แบบสอบถาม SQL ที่กล่าวถึงข้างต้นในสคริปต์ PHP คุณจะต้องส่งแบบสอบถาม SQL ไปยังฟังก์ชัน PHP เท่านั้นmysql_query() จากนั้นคุณจะดึงผลลัพธ์ตามปกติ
ตัวอย่าง
ตัวอย่างต่อไปนี้ -
<?php
$dbhost = 'localhost:3036';
$dbuser = 'root'; $dbpass = 'rootpassword';
$conn = mysql_connect($dbhost, $dbuser, $dbpass);
if(! $conn ) { die('Could not connect: ' . mysql_error()); } $sql = 'SELECT a.tutorial_id, a.tutorial_author, b.tutorial_count
FROM tutorials_tbl a, tcount_tbl b
WHERE a.tutorial_author = b.tutorial_author';
mysql_select_db('TUTORIALS');
$retval = mysql_query( $sql, $conn ); if(! $retval ) {
die('Could not get data: ' . mysql_error());
}
while($row = mysql_fetch_array($retval, MYSQL_ASSOC)) {
echo "Author:{$row['tutorial_author']} <br> ". "Count: {$row['tutorial_count']} <br> ".
"Tutorial ID: {$row['tutorial_id']} <br> ". "--------------------------------<br>"; } echo "Fetched data successfully\n"; mysql_close($conn);
?>
MySQL ซ้ายเข้าร่วม
การเข้าร่วม MySQL ที่เหลือจะแตกต่างจากการเข้าร่วมแบบธรรมดา MySQL LEFT JOIN ให้การพิจารณาเป็นพิเศษกับตารางทางด้านซ้าย
ถ้าฉันทำ LEFT JOINฉันได้รับระเบียนทั้งหมดที่ตรงกันในลักษณะเดียวกันและในส่วนเพิ่มเติมฉันได้รับบันทึกพิเศษสำหรับแต่ละระเบียนที่ไม่ตรงกันในตารางด้านซ้ายของการเข้าร่วมดังนั้นจึงมั่นใจได้ (ในตัวอย่างของฉัน) ว่า AUTHOR ทุกคนได้รับการกล่าวถึง
ตัวอย่าง
ลองใช้ตัวอย่างต่อไปนี้เพื่อทำความเข้าใจ LEFT JOIN
root@host# mysql -u root -p password;
Enter password:*******
mysql> use TUTORIALS;
Database changed
mysql> SELECT a.tutorial_id, a.tutorial_author, b.tutorial_count
-> FROM tutorials_tbl a LEFT JOIN tcount_tbl b
-> ON a.tutorial_author = b.tutorial_author;
+-------------+-----------------+----------------+
| tutorial_id | tutorial_author | tutorial_count |
+-------------+-----------------+----------------+
| 1 | John Poul | 1 |
| 2 | Abdul S | NULL |
| 3 | Sanjay | 1 |
+-------------+-----------------+----------------+
3 rows in set (0.02 sec)
คุณจะต้องฝึกฝนให้มากขึ้นเพื่อทำความคุ้นเคยกับ JOINS นี่เป็นแนวคิดที่ซับซ้อนเล็กน้อยใน MySQL / SQL และจะชัดเจนยิ่งขึ้นในขณะที่ทำตัวอย่างจริง
เราได้เห็น SQL SELECT พร้อมกับคำสั่ง WHERE clause เพื่อดึงข้อมูลจากตาราง MySQL แต่เมื่อเราพยายามให้เงื่อนไขซึ่งเปรียบเทียบฟิลด์หรือค่าคอลัมน์กับ NULLมันทำงานไม่ถูกต้อง
เพื่อจัดการกับสถานการณ์ดังกล่าว MySQL มีตัวดำเนินการสามตัว -
IS NULL - ตัวดำเนินการนี้จะคืนค่าจริงหากค่าของคอลัมน์เป็น NULL
IS NOT NULL - ตัวดำเนินการนี้จะคืนค่าจริงหากค่าของคอลัมน์ไม่ใช่ NULL
<=> - ตัวดำเนินการนี้เปรียบเทียบค่าซึ่ง (ไม่เหมือนตัวดำเนินการ =) เป็นจริงแม้จะเป็นค่า NULL สองค่า
เงื่อนไขที่เกี่ยวข้องกับ NULL เป็นเงื่อนไขพิเศษ คุณไม่สามารถใช้ =NULL หรือ! = NULLเพื่อค้นหาค่า NULL ในคอลัมน์ การเปรียบเทียบดังกล่าวมักจะล้มเหลวเสมอเพราะไม่สามารถบอกได้ว่าจริงหรือไม่ บางครั้งแม้แต่ NULL = NULL ก็ล้มเหลว
หากต้องการค้นหาคอลัมน์ที่เป็นหรือไม่เป็นโมฆะให้ใช้ IS NULL หรือ IS NOT NULL.
ใช้ค่า NULL ที่ Command Prompt
สมมติว่ามีโต๊ะที่เรียก tcount_tbl ในฐานข้อมูล TUTORIALS และประกอบด้วยสองคอลัมน์คือ tutorial_author และ tutorial_countโดยที่ NULL tutorial_count ระบุว่าไม่ทราบค่า
ตัวอย่าง
ลองดูตัวอย่างต่อไปนี้ -
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
-> );
Query OK, 0 rows affected (0.05 sec)
mysql> INSERT INTO tcount_tbl
-> (tutorial_author, tutorial_count) values ('mahran', 20);
mysql> INSERT INTO tcount_tbl
-> (tutorial_author, tutorial_count) values ('mahnaz', NULL);
mysql> INSERT INTO tcount_tbl
-> (tutorial_author, tutorial_count) values ('Jen', NULL);
mysql> INSERT INTO tcount_tbl
-> (tutorial_author, tutorial_count) values ('Gill', 20);
mysql> SELECT * from tcount_tbl;
+-----------------+----------------+
| tutorial_author | tutorial_count |
+-----------------+----------------+
| mahran | 20 |
| mahnaz | NULL |
| Jen | NULL |
| Gill | 20 |
+-----------------+----------------+
4 rows in set (0.00 sec)
mysql>
คุณจะเห็นว่า = และ != ไม่ทำงานกับค่า NULL ดังต่อไปนี้ -
mysql> SELECT * FROM tcount_tbl WHERE tutorial_count = NULL;
Empty set (0.00 sec)
mysql> SELECT * FROM tcount_tbl WHERE tutorial_count != NULL;
Empty set (0.01 sec)
หากต้องการค้นหาระเบียนที่คอลัมน์ tutorial_count เป็นหรือไม่ใช่ NULL ควรเขียนแบบสอบถามดังที่แสดงในโปรแกรมต่อไปนี้
mysql> SELECT * FROM tcount_tbl
-> WHERE tutorial_count IS NULL;
+-----------------+----------------+
| tutorial_author | tutorial_count |
+-----------------+----------------+
| mahnaz | NULL |
| Jen | NULL |
+-----------------+----------------+
2 rows in set (0.00 sec)
mysql> SELECT * from tcount_tbl
-> WHERE tutorial_count IS NOT NULL;
+-----------------+----------------+
| tutorial_author | tutorial_count |
+-----------------+----------------+
| mahran | 20 |
| Gill | 20 |
+-----------------+----------------+
2 rows in set (0.00 sec)
การจัดการค่า NULL ในสคริปต์ PHP
คุณสามารถใช้ไฟล์ if...else เงื่อนไขในการเตรียมแบบสอบถามตามค่า NULL
ตัวอย่าง
ตัวอย่างต่อไปนี้ใช้ tutorial_count จากภายนอกแล้วเปรียบเทียบกับค่าที่มีอยู่ในตาราง
<?php
$dbhost = 'localhost:3036'; $dbuser = 'root';
$dbpass = 'rootpassword'; $conn = mysql_connect($dbhost, $dbuser, $dbpass); if(! $conn ) {
die('Could not connect: ' . mysql_error());
}
if( isset($tutorial_count )) { $sql = 'SELECT tutorial_author, tutorial_count
FROM tcount_tbl
WHERE tutorial_count = $tutorial_count'; } else { $sql = 'SELECT tutorial_author, tutorial_count
FROM tcount_tbl
WHERE tutorial_count IS $tutorial_count'; } mysql_select_db('TUTORIALS'); $retval = mysql_query( $sql, $conn );
if(! $retval ) { die('Could not get data: ' . mysql_error()); } while($row = mysql_fetch_array($retval, MYSQL_ASSOC)) { echo "Author:{$row['tutorial_author']} <br> ".
"Count: {$row['tutorial_count']} <br> ". "--------------------------------<br>"; } echo "Fetched data successfully\n"; mysql_close($conn);
?>
คุณได้เห็นรูปแบบ MySQL ที่ตรงกับไฟล์ LIKE ...%. MySQL รองรับการจับคู่รูปแบบประเภทอื่นโดยยึดตามนิพจน์ทั่วไปและไฟล์REGEXPตัวดำเนินการ หากคุณรู้จัก PHP หรือ PERL คุณจะเข้าใจได้ง่ายมากเพราะการจับคู่นี้เหมือนกับการเขียนสคริปต์นิพจน์ทั่วไป
ต่อไปนี้เป็นตารางรูปแบบซึ่งสามารถใช้ร่วมกับ REGEXP ตัวดำเนินการ
รูปแบบ | รูปแบบตรงกับอะไร |
---|---|
^ | จุดเริ่มต้นของสตริง |
$ | สิ้นสุดสตริง |
. | อักขระเดี่ยวใด ๆ |
[... ] | อักขระใด ๆ ที่อยู่ระหว่างวงเล็บเหลี่ยม |
[^ ... ] | อักขระใด ๆ ที่ไม่อยู่ระหว่างวงเล็บเหลี่ยม |
p1 | p2 | p3 | การสลับ; จับคู่รูปแบบ p1, p2 หรือ p3 ใด ๆ |
* | อินสแตนซ์ขององค์ประกอบก่อนหน้าตั้งแต่ศูนย์ขึ้นไป |
+ | อย่างน้อยหนึ่งอินสแตนซ์ขององค์ประกอบก่อนหน้า |
{n} | n อินสแตนซ์ขององค์ประกอบก่อนหน้า |
{ม., n} | m ถึง n อินสแตนซ์ขององค์ประกอบก่อนหน้า |
ตัวอย่าง
จากตารางด้านบนคุณสามารถกำหนดประเภทของแบบสอบถาม SQL เพื่อตอบสนองความต้องการของคุณ ที่นี่ฉันแสดงรายชื่อบางส่วนเพื่อความเข้าใจของคุณ
พิจารณาว่าเรามีตารางที่เรียกว่า person_tbl และมีฟิลด์ที่เรียกว่า name -
ค้นหาชื่อทั้งหมดที่ขึ้นต้นด้วย 'st' -
mysql> SELECT name FROM person_tbl WHERE name REGEXP '^st';
ค้นหาชื่อทั้งหมดที่ลงท้ายด้วย 'ok' -
mysql> SELECT name FROM person_tbl WHERE name REGEXP 'ok$';
ค้นหาชื่อทั้งหมดที่มี 'mar' -
mysql> SELECT name FROM person_tbl WHERE name REGEXP 'mar';
ค้นหาชื่อทั้งหมดที่ขึ้นต้นด้วยสระและลงท้ายด้วย 'ok' -
mysql> SELECT FirstName FROM intque.person_tbl WHERE FirstName REGEXP '^[aeiou].*ok$';
ธุรกรรมคือกลุ่มตามลำดับของการดำเนินการจัดการฐานข้อมูลซึ่งดำเนินการราวกับว่าเป็นหน่วยงานเดียว กล่าวอีกนัยหนึ่งการทำธุรกรรมจะไม่สมบูรณ์จนกว่าการดำเนินการแต่ละอย่างภายในกลุ่มจะประสบความสำเร็จ หากการดำเนินการใด ๆ ภายในธุรกรรมล้มเหลวธุรกรรมทั้งหมดจะล้มเหลว
ในทางปฏิบัติคุณจะรวมคิวรี SQL จำนวนมากไว้ในกลุ่มและคุณจะดำเนินการทั้งหมดร่วมกันเป็นส่วนหนึ่งของธุรกรรม
คุณสมบัติของธุรกรรม
ธุรกรรมมีคุณสมบัติมาตรฐานสี่ประการดังต่อไปนี้ซึ่งโดยปกติจะอ้างถึงด้วยตัวย่อ 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แต่ขึ้นอยู่กับการติดตั้งของคุณว่ารองรับตารางทั้งสองประเภทนี้หรือไม่
MySQL ALTER คำสั่งมีประโยชน์มากเมื่อคุณต้องการเปลี่ยนชื่อตารางฟิลด์ตารางใด ๆ หรือถ้าคุณต้องการเพิ่มหรือลบคอลัมน์ที่มีอยู่ในตาราง
เริ่มต้นด้วยการสร้างตารางที่เรียกว่า testalter_tbl.
root@host# mysql -u root -p password;
Enter password:*******
mysql> use TUTORIALS;
Database changed
mysql> create table testalter_tbl
-> (
-> i INT,
-> c CHAR(1)
-> );
Query OK, 0 rows affected (0.05 sec)
mysql> SHOW COLUMNS FROM testalter_tbl;
+-------+---------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| i | int(11) | YES | | NULL | |
| c | char(1) | YES | | NULL | |
+-------+---------+------+-----+---------+-------+
2 rows in set (0.00 sec)
การวางการเพิ่มหรือการเปลี่ยนตำแหน่งคอลัมน์
หากคุณต้องการวางคอลัมน์ที่มีอยู่ i จากตาราง MySQL ด้านบนคุณจะใช้ไฟล์ DROP อนุประโยคพร้อมกับ ALTER คำสั่งดังแสดงด้านล่าง -
mysql> ALTER TABLE testalter_tbl DROP i;
ก DROP อนุประโยคจะไม่ทำงานหากคอลัมน์นั้นเหลือเพียงคอลัมน์เดียวในตาราง
ในการเพิ่มคอลัมน์ให้ใช้ ADD และระบุนิยามคอลัมน์ คำสั่งต่อไปนี้เรียกคืนไฟล์i คอลัมน์ไปที่ testalter_tbl -
mysql> ALTER TABLE testalter_tbl ADD i INT;
หลังจากออกคำสั่งนี้ testalter จะมีคอลัมน์สองคอลัมน์ที่เหมือนกันเมื่อคุณสร้างตารางครั้งแรก แต่จะไม่มีโครงสร้างเหมือนกัน เนื่องจากมีคอลัมน์ใหม่ที่ถูกเพิ่มที่ส่วนท้ายของตารางโดยค่าเริ่มต้น ดังนั้นแม้ว่าi เดิมเป็นคอลัมน์แรกใน mytbl ตอนนี้เป็นคอลัมน์สุดท้าย
mysql> SHOW COLUMNS FROM testalter_tbl;
+-------+---------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| c | char(1) | YES | | NULL | |
| i | int(11) | YES | | NULL | |
+-------+---------+------+-----+---------+-------+
2 rows in set (0.00 sec)
ในการระบุว่าคุณต้องการให้คอลัมน์อยู่ในตำแหน่งใดตำแหน่งหนึ่งภายในตารางให้ใช้ FIRST เพื่อทำให้เป็นคอลัมน์แรกหรือ AFTER col_name เพื่อระบุว่าควรวางคอลัมน์ใหม่หลัง col_name
ลองทำดังต่อไปนี้ ALTER TABLE งบใช้ SHOW COLUMNS หลังจากแต่ละคนเพื่อดูว่าแต่ละคนมีผลอย่างไร -
ALTER TABLE testalter_tbl DROP i;
ALTER TABLE testalter_tbl ADD i INT FIRST;
ALTER TABLE testalter_tbl DROP i;
ALTER TABLE testalter_tbl ADD i INT AFTER c;
ตัวระบุ FIRST และ AFTER ใช้งานได้กับส่วนคำสั่ง ADD เท่านั้น ซึ่งหมายความว่าหากคุณต้องการเปลี่ยนตำแหน่งคอลัมน์ที่มีอยู่ภายในตารางก่อนอื่นคุณต้องDROP มันแล้ว ADD ที่ตำแหน่งใหม่
การแก้ไข (การเปลี่ยน) นิยามคอลัมน์หรือชื่อ
หากต้องการเปลี่ยนนิยามของคอลัมน์ให้ใช้ MODIFY หรือ CHANGE อนุประโยคพร้อมกับคำสั่ง ALTER
ตัวอย่างเช่นการเปลี่ยนคอลัมน์ c จาก CHAR (1) ถึง CHAR (10) คุณสามารถใช้คำสั่งต่อไปนี้ -
mysql> ALTER TABLE testalter_tbl MODIFY c CHAR(10);
ด้วย CHANGEไวยากรณ์แตกต่างกันเล็กน้อย หลังจากคำหลัก CHANGE คุณตั้งชื่อคอลัมน์ที่คุณต้องการเปลี่ยนจากนั้นระบุคำจำกัดความใหม่ซึ่งรวมถึงชื่อใหม่
ลองใช้ตัวอย่างต่อไปนี้ -
mysql> ALTER TABLE testalter_tbl CHANGE i j BIGINT;
หากตอนนี้คุณใช้ CHANGE เพื่อแปลงไฟล์ j จาก BIGINT กลับไปยัง INT โดยไม่ต้องเปลี่ยนชื่อคอลัมน์คำสั่งจะเป็นดังที่แสดงด้านล่าง -
mysql> ALTER TABLE testalter_tbl CHANGE j j INT;
The Effect of ALTER TABLE on Null and Default Value Attributes- เมื่อคุณแก้ไขหรือเปลี่ยนคอลัมน์คุณยังสามารถระบุได้ว่าคอลัมน์นั้นสามารถมีค่า NULL ได้หรือไม่และค่าเริ่มต้นคืออะไร ในความเป็นจริงถ้าคุณไม่ทำเช่นนี้ MySQL จะกำหนดค่าสำหรับแอตทริบิวต์เหล่านี้โดยอัตโนมัติ
บล็อกโค้ดต่อไปนี้เป็นตัวอย่างโดยที่ไฟล์ NOT NULL คอลัมน์จะมีค่าเป็น 100 โดยค่าเริ่มต้น
mysql> ALTER TABLE testalter_tbl
-> MODIFY j BIGINT NOT NULL DEFAULT 100;
หากคุณไม่ใช้คำสั่งด้านบน MySQL จะเติมค่า NULL ในคอลัมน์ทั้งหมด
การแก้ไข (เปลี่ยนแปลง) ค่าเริ่มต้นของคอลัมน์
คุณสามารถเปลี่ยนค่าเริ่มต้นสำหรับคอลัมน์ใดก็ได้โดยใช้ไฟล์ ALTER คำสั่ง
ลองดูตัวอย่างต่อไปนี้
mysql> ALTER TABLE testalter_tbl ALTER i SET DEFAULT 1000;
mysql> SHOW COLUMNS FROM testalter_tbl;
+-------+---------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| c | char(1) | YES | | NULL | |
| i | int(11) | YES | | 1000 | |
+-------+---------+------+-----+---------+-------+
2 rows in set (0.00 sec)
คุณสามารถลบข้อ จำกัด เริ่มต้นจากคอลัมน์ใดก็ได้โดยใช้คำสั่ง DROP พร้อมกับ ALTER คำสั่ง
mysql> ALTER TABLE testalter_tbl ALTER i DROP DEFAULT;
mysql> SHOW COLUMNS FROM testalter_tbl;
+-------+---------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| c | char(1) | YES | | NULL | |
| i | int(11) | YES | | NULL | |
+-------+---------+------+-----+---------+-------+
2 rows in set (0.00 sec)
การแก้ไข (การเปลี่ยนแปลง) ประเภทตาราง
คุณสามารถใช้ประเภทตารางได้โดยใช้ไฟล์ TYPEอนุประโยคพร้อมกับคำสั่ง ALTER ลองใช้ตัวอย่างต่อไปนี้เพื่อเปลี่ยนไฟล์testalter_tbl ถึง MYISAM ประเภทตาราง
หากต้องการทราบประเภทของตารางปัจจุบันให้ใช้ไฟล์ SHOW TABLE STATUS คำให้การ.
mysql> ALTER TABLE testalter_tbl TYPE = MYISAM;
mysql> SHOW TABLE STATUS LIKE 'testalter_tbl'\G
*************************** 1. row ****************
Name: testalter_tbl
Type: MyISAM
Row_format: Fixed
Rows: 0
Avg_row_length: 0
Data_length: 0
Max_data_length: 25769803775
Index_length: 1024
Data_free: 0
Auto_increment: NULL
Create_time: 2007-06-03 08:04:36
Update_time: 2007-06-03 08:04:36
Check_time: NULL
Create_options:
Comment:
1 row in set (0.00 sec)
การเปลี่ยนชื่อ (การแก้ไข) ตาราง
ในการเปลี่ยนชื่อตารางให้ใช้ไฟล์ RENAME ตัวเลือกของ ALTER TABLE คำให้การ.
ลองใช้ตัวอย่างต่อไปนี้เพื่อเปลี่ยนชื่อ testalter_tbl ถึง alter_tbl.
mysql> ALTER TABLE testalter_tbl RENAME TO alter_tbl;
คุณสามารถใช้คำสั่ง ALTER เพื่อสร้างและวางคำสั่ง INDEX บนไฟล์ MySQL เราจะพูดถึงรายละเอียดเกี่ยวกับคำสั่งนี้ในบทถัดไป
ดัชนีฐานข้อมูลคือโครงสร้างข้อมูลที่ช่วยเพิ่มความเร็วของการดำเนินการในตาราง ดัชนีสามารถสร้างได้โดยใช้คอลัมน์อย่างน้อยหนึ่งคอลัมน์ซึ่งเป็นพื้นฐานสำหรับทั้งการค้นหาแบบสุ่มอย่างรวดเร็วและการจัดลำดับการเข้าถึงบันทึกอย่างมีประสิทธิภาพ
ในขณะที่สร้างดัชนีควรพิจารณาว่าจะใช้คอลัมน์ใดในการสร้างแบบสอบถาม SQL และสร้างดัชนีอย่างน้อยหนึ่งรายการในคอลัมน์เหล่านั้น
ในทางปฏิบัติดัชนียังเป็นตารางประเภทหนึ่งซึ่งเก็บคีย์หลักหรือฟิลด์ดัชนีและตัวชี้ไปยังแต่ละระเบียนลงในตารางจริง
ผู้ใช้ไม่สามารถมองเห็นดัชนีได้พวกเขาใช้เพื่อเร่งความเร็วในการสืบค้นและจะถูกใช้โดย Database Search Engine เพื่อค้นหาบันทึกอย่างรวดเร็ว
คำสั่ง INSERT และ UPDATE ใช้เวลามากขึ้นในตารางที่มีดัชนีในขณะที่คำสั่ง SELECT กลายเป็นตารางอย่างรวดเร็ว เหตุผลก็คือในขณะที่ทำการแทรกหรืออัปเดตฐานข้อมูลจำเป็นต้องแทรกหรืออัปเดตค่าดัชนีด้วย
ดัชนีที่เรียบง่ายและไม่เหมือนใคร
คุณสามารถสร้างดัชนีเฉพาะบนตาราง ดัชนีที่ไม่ซ้ำกันหมายความว่าสองแถวไม่สามารถมีค่าดัชนีเดียวกันได้ นี่คือไวยากรณ์ในการสร้างดัชนีบนตาราง
CREATE UNIQUE INDEX index_name ON table_name ( column1, column2,...);
คุณสามารถใช้คอลัมน์อย่างน้อยหนึ่งคอลัมน์เพื่อสร้างดัชนี
ตัวอย่างเช่นเราสามารถสร้างดัชนีบน tutorials_tbl โดยใช้ tutorial_author.
CREATE UNIQUE INDEX AUTHOR_INDEX ON tutorials_tbl (tutorial_author)
คุณสามารถสร้างดัชนีอย่างง่ายบนตาราง เพียงแค่ละเว้นUNIQUEคำหลักจากแบบสอบถามเพื่อสร้างดัชนีอย่างง่าย ดัชนีอย่างง่ายช่วยให้สามารถสร้างค่าที่ซ้ำกันในตารางได้
หากคุณต้องการจัดทำดัชนีค่าในคอลัมน์โดยเรียงลำดับจากมากไปหาน้อยคุณสามารถเพิ่มคำสงวน DESC หลังชื่อคอลัมน์ได้
mysql> CREATE UNIQUE INDEX AUTHOR_INDEX ON tutorials_tbl (tutorial_author DESC)
แก้ไขคำสั่งเพื่อเพิ่มและวาง INDEX
มีคำสั่งสี่ประเภทสำหรับการเพิ่มดัชนีลงในตาราง -
ALTER TABLE tbl_name ADD PRIMARY KEY (column_list) - คำสั่งนี้เพิ่มไฟล์ PRIMARY KEYซึ่งหมายความว่าค่าที่จัดทำดัชนีจะต้องไม่ซ้ำกันและไม่สามารถเป็น NULL ได้
ALTER TABLE tbl_name ADD UNIQUE index_name (column_list) - คำสั่งนี้สร้างดัชนีที่ค่าต้องไม่ซ้ำกัน (ยกเว้นค่า NULL ซึ่งอาจปรากฏหลายครั้ง)
ALTER TABLE tbl_name ADD INDEX index_name (column_list) - เพิ่มดัชนีธรรมดาที่ค่าใด ๆ อาจปรากฏมากกว่าหนึ่งครั้ง
ALTER TABLE tbl_name ADD FULLTEXT index_name (column_list) - สิ่งนี้สร้างดัชนี FULLTEXT พิเศษที่ใช้สำหรับวัตถุประสงค์ในการค้นหาข้อความ
บล็อกโค้ดต่อไปนี้เป็นตัวอย่างในการเพิ่มดัชนีในตารางที่มีอยู่
mysql> ALTER TABLE testalter_tbl ADD INDEX (c);
คุณสามารถลด INDEX ใดก็ได้โดยใช้ DROP อนุประโยคพร้อมกับคำสั่ง ALTER
ลองใช้ตัวอย่างต่อไปนี้เพื่อดร็อปดัชนีที่สร้างไว้ด้านบน
mysql> ALTER TABLE testalter_tbl DROP INDEX (c);
คุณสามารถวาง INDEX ใดก็ได้โดยใช้คำสั่ง DROP พร้อมกับคำสั่ง ALTER
แก้ไขคำสั่งเพื่อเพิ่มและวางคีย์หลัก
คุณสามารถเพิ่มคีย์หลักได้ในลักษณะเดียวกัน แต่ตรวจสอบให้แน่ใจว่าคีย์หลักทำงานบนคอลัมน์ซึ่งไม่ใช่ค่าว่าง
บล็อกโค้ดต่อไปนี้เป็นตัวอย่างในการเพิ่มคีย์หลักในตารางที่มีอยู่ สิ่งนี้จะทำให้คอลัมน์ไม่เป็นโมฆะก่อนจากนั้นจึงเพิ่มเป็นคีย์หลัก
mysql> ALTER TABLE testalter_tbl MODIFY i INT NOT NULL;
mysql> ALTER TABLE testalter_tbl ADD PRIMARY KEY (i);
คุณสามารถใช้คำสั่ง ALTER เพื่อวางคีย์หลักดังนี้ -
mysql> ALTER TABLE testalter_tbl DROP PRIMARY KEY;
ในการวางดัชนีที่ไม่ใช่คีย์หลักคุณต้องระบุชื่อดัชนี
การแสดงข้อมูล INDEX
คุณสามารถใช้ไฟล์ SHOW INDEXคำสั่งเพื่อแสดงรายการดัชนีทั้งหมดที่เกี่ยวข้องกับตาราง เอาต์พุตรูปแบบแนวตั้ง (ระบุโดย \ G) มักจะมีประโยชน์กับคำสั่งนี้เพื่อหลีกเลี่ยงการตัดกันเป็นเส้นยาว -
ลองใช้ตัวอย่างต่อไปนี้ -
mysql> SHOW INDEX FROM table_name\G
........
ตารางชั่วคราวอาจมีประโยชน์มากในบางกรณีเพื่อเก็บข้อมูลชั่วคราว สิ่งที่สำคัญที่สุดที่ควรทราบสำหรับตารางชั่วคราวคือตารางเหล่านั้นจะถูกลบเมื่อเซสชันไคลเอ็นต์ปัจจุบันสิ้นสุดลง
ตารางชั่วคราวคืออะไร?
มีการเพิ่มตารางชั่วคราวใน MySQL เวอร์ชัน 3.23 หากคุณใช้ MySQL เวอร์ชันเก่ากว่า 3.23 คุณจะไม่สามารถใช้ตารางชั่วคราวได้ แต่คุณสามารถใช้ได้Heap Tables.
ตามที่ระบุไว้ก่อนหน้านี้ตารางชั่วคราวจะคงอยู่ตราบเท่าที่เซสชันยังมีชีวิตอยู่ หากคุณรันโค้ดในสคริปต์ PHP ตารางชั่วคราวจะถูกทำลายโดยอัตโนมัติเมื่อสคริปต์ทำงานเสร็จสิ้น หากคุณเชื่อมต่อกับเซิร์ฟเวอร์ฐานข้อมูล MySQL ผ่านโปรแกรมไคลเอนต์ MySQL ตารางชั่วคราวจะมีอยู่จนกว่าคุณจะปิดไคลเอนต์หรือทำลายตารางด้วยตนเอง
ตัวอย่าง
โปรแกรมต่อไปนี้เป็นตัวอย่างที่แสดงการใช้งานตารางชั่วคราว สามารถใช้รหัสเดียวกันในสคริปต์ PHP โดยใช้ไฟล์mysql_query() ฟังก์ชัน
mysql> CREATE TEMPORARY TABLE SalesSummary (
-> product_name VARCHAR(50) NOT NULL
-> , total_sales DECIMAL(12,2) NOT NULL DEFAULT 0.00
-> , avg_unit_price DECIMAL(7,2) NOT NULL DEFAULT 0.00
-> , total_units_sold INT UNSIGNED NOT NULL DEFAULT 0
);
Query OK, 0 rows affected (0.00 sec)
mysql> INSERT INTO SalesSummary
-> (product_name, total_sales, avg_unit_price, total_units_sold)
-> VALUES
-> ('cucumber', 100.25, 90, 2);
mysql> SELECT * FROM SalesSummary;
+--------------+-------------+----------------+------------------+
| product_name | total_sales | avg_unit_price | total_units_sold |
+--------------+-------------+----------------+------------------+
| cucumber | 100.25 | 90.00 | 2 |
+--------------+-------------+----------------+------------------+
1 row in set (0.00 sec)
เมื่อคุณออกไฟล์ SHOW TABLESจากนั้นตารางชั่วคราวของคุณจะไม่ปรากฏในรายการ ตอนนี้ถ้าคุณจะออกจากเซสชัน MySQL จากนั้นคุณจะออกไฟล์SELECTจากนั้นคุณจะพบว่าไม่มีข้อมูลในฐานข้อมูล แม้แต่โต๊ะชั่วคราวของคุณก็ไม่มีอยู่จริง
การวางตารางชั่วคราว
ตามค่าเริ่มต้นตารางชั่วคราวทั้งหมดจะถูกลบโดย MySQL เมื่อการเชื่อมต่อฐานข้อมูลของคุณถูกยกเลิก หากคุณต้องการลบระหว่างนั้นคุณสามารถทำได้โดยการออกไฟล์DROP TABLE คำสั่ง
โปรแกรมต่อไปนี้เป็นตัวอย่างในการวางตารางชั่วคราว -
mysql> CREATE TEMPORARY TABLE SalesSummary (
-> product_name VARCHAR(50) NOT NULL
-> , total_sales DECIMAL(12,2) NOT NULL DEFAULT 0.00
-> , avg_unit_price DECIMAL(7,2) NOT NULL DEFAULT 0.00
-> , total_units_sold INT UNSIGNED NOT NULL DEFAULT 0
);
Query OK, 0 rows affected (0.00 sec)
mysql> INSERT INTO SalesSummary
-> (product_name, total_sales, avg_unit_price, total_units_sold)
-> VALUES
-> ('cucumber', 100.25, 90, 2);
mysql> SELECT * FROM SalesSummary;
+--------------+-------------+----------------+------------------+
| product_name | total_sales | avg_unit_price | total_units_sold |
+--------------+-------------+----------------+------------------+
| cucumber | 100.25 | 90.00 | 2 |
+--------------+-------------+----------------+------------------+
1 row in set (0.00 sec)
mysql> DROP TABLE SalesSummary;
mysql> SELECT * FROM SalesSummary;
ERROR 1146: Table 'TUTORIALS.SalesSummary' doesn't exist
อาจมีสถานการณ์เมื่อคุณต้องการสำเนาตารางและ CREATE TABLE ... SELECT ไม่เหมาะกับวัตถุประสงค์ของคุณเนื่องจากสำเนาต้องมีดัชนีเดียวกันค่าเริ่มต้นและอื่น ๆ
คุณสามารถจัดการกับสถานการณ์นี้ได้โดยทำตามขั้นตอนด้านล่าง -
ใช้ SHOW CREATE TABLE เพื่อรับคำสั่ง CREATE TABLE ที่ระบุโครงสร้างของตารางต้นทางดัชนีและทั้งหมด
แก้ไขคำสั่งเพื่อเปลี่ยนชื่อตารางเป็นตารางโคลนและดำเนินการคำสั่ง วิธีนี้คุณจะมีตารางโคลนที่แน่นอน
ถ้าคุณต้องการคัดลอกเนื้อหาในตารางด้วยให้ออกคำสั่ง INSERT INTO ... SELECT ด้วย
ตัวอย่าง
ลองใช้ตัวอย่างต่อไปนี้เพื่อสร้างตารางโคลนสำหรับ tutorials_tbl.
Step 1 - รับโครงสร้างที่สมบูรณ์เกี่ยวกับตาราง
mysql> SHOW CREATE TABLE tutorials_tbl \G;
*************************** 1. row ***************************
Table: tutorials_tbl
Create Table: CREATE TABLE `tutorials_tbl` (
`tutorial_id` int(11) NOT NULL auto_increment,
`tutorial_title` varchar(100) NOT NULL default '',
`tutorial_author` varchar(40) NOT NULL default '',
`submission_date` date default NULL,
PRIMARY KEY (`tutorial_id`),
UNIQUE KEY `AUTHOR_INDEX` (`tutorial_author`)
) TYPE = MyISAM
1 row in set (0.00 sec)
ERROR:
No query specified
Step 2 - เปลี่ยนชื่อตารางนี้และสร้างตารางใหม่
mysql> CREATE TABLE clone_tbl (
-> tutorial_id int(11) NOT NULL auto_increment,
-> tutorial_title varchar(100) NOT NULL default '',
-> tutorial_author varchar(40) NOT NULL default '',
-> submission_date date default NULL,
-> PRIMARY KEY (tutorial_id),
-> UNIQUE KEY AUTHOR_INDEX (tutorial_author)
-> ) TYPE = MyISAM;
Query OK, 0 rows affected (1.80 sec)
Step 3- หลังจากดำเนินการขั้นตอนที่ 2 คุณจะสร้างตารางโคลนในฐานข้อมูลของคุณ หากคุณต้องการคัดลอกข้อมูลจากตารางเก่าคุณสามารถทำได้โดยใช้คำสั่ง INSERT INTO ... SELECT
mysql> INSERT INTO clone_tbl (tutorial_id,
-> tutorial_title,
-> tutorial_author,
-> submission_date)
-> SELECT tutorial_id,tutorial_title,
-> tutorial_author,submission_date
-> FROM tutorials_tbl;
Query OK, 3 rows affected (0.07 sec)
Records: 3 Duplicates: 0 Warnings: 0
สุดท้ายคุณจะมีตารางโคลนที่แน่นอนตามที่คุณต้องการ
การรับและใช้ MySQL Metadata
มีข้อมูลสามประเภทที่คุณต้องการจาก MySQL
Information about the result of queries - รวมถึงจำนวนบันทึกที่ได้รับผลกระทบจากคำสั่ง SELECT, UPDATE หรือ DELETE
Information about the tables and databases - รวมถึงข้อมูลที่เกี่ยวข้องกับโครงสร้างของตารางและฐานข้อมูล
Information about the MySQL server - ซึ่งรวมถึงสถานะของเซิร์ฟเวอร์ฐานข้อมูลหมายเลขเวอร์ชัน ฯลฯ
เป็นเรื่องง่ายมากที่จะรับข้อมูลทั้งหมดนี้ที่พรอมต์ MySQL แต่ในขณะที่ใช้ PERL หรือ PHP API เราจำเป็นต้องเรียก API ต่างๆอย่างชัดเจนเพื่อรับข้อมูลทั้งหมดนี้
การได้รับจำนวนแถวที่ได้รับผลกระทบจากการค้นหา
ตอนนี้มาดูวิธีการรับข้อมูลนี้
ตัวอย่าง PERL
ในสคริปต์ DBI จำนวนแถวที่ได้รับผลกระทบจะถูกส่งกลับโดย do( ) หรือโดย execute( ) คำสั่งขึ้นอยู่กับว่าคุณดำเนินการสืบค้นอย่างไร
# Method 1
# execute $query using do( )
my $count = $dbh->do ($query); # report 0 rows if an error occurred printf "%d rows were affected\n", (defined ($count) ? $count : 0); # Method 2 # execute query using prepare( ) plus execute( ) my $sth = $dbh->prepare ($query);
my $count = $sth->execute ( );
printf "%d rows were affected\n", (defined ($count) ? $count : 0);
ตัวอย่าง PHP
ใน PHP เรียกใช้ไฟล์ mysql_affected_rows( ) ฟังก์ชันเพื่อค้นหาจำนวนแถวที่คิวรีเปลี่ยนแปลง
$result_id = mysql_query ($query, $conn_id); # report 0 rows if the query failed $count = ($result_id ? mysql_affected_rows ($conn_id) : 0);
print ("$count rows were affected\n");
รายชื่อตารางและฐานข้อมูล
มันง่ายมากที่จะลงรายการฐานข้อมูลทั้งหมดและตารางที่มีให้กับเซิร์ฟเวอร์ฐานข้อมูล ผลลัพธ์ของคุณอาจเป็นnull หากคุณไม่มีสิทธิ์เพียงพอ
นอกเหนือจากวิธีการที่แสดงในบล็อกโค้ดต่อไปนี้คุณสามารถใช้ได้ SHOW TABLES หรือ SHOW DATABASES แบบสอบถามเพื่อรับรายการตารางหรือฐานข้อมูลทั้งใน PHP หรือใน PERL
ตัวอย่าง PERL
# Get all the tables available in current database.
my @tables = $dbh->tables ( );
foreach $table (@tables ){ print "Table Name $table\n";
}
ตัวอย่าง PHP
<?php
$con = mysql_connect("localhost", "userid", "password"); if (!$con) {
die('Could not connect: ' . mysql_error());
}
$db_list = mysql_list_dbs($con);
while ($db = mysql_fetch_object($db_list)) {
echo $db->Database . "<br />"; } mysql_close($con);
?>
รับข้อมูลเมตาของเซิร์ฟเวอร์
มีคำสั่งที่สำคัญบางอย่างใน MySQL ซึ่งสามารถเรียกใช้งานได้ที่พรอมต์ MySQL หรือโดยใช้สคริปต์ใด ๆ เช่น PHP เพื่อรับข้อมูลสำคัญต่างๆเกี่ยวกับเซิร์ฟเวอร์ฐานข้อมูล
ซีเนียร์ | คำสั่งและคำอธิบาย |
---|---|
1 | SELECT VERSION( ) สตริงเวอร์ชันเซิร์ฟเวอร์ |
2 | SELECT DATABASE( ) ชื่อฐานข้อมูลปัจจุบัน (ว่างเปล่าถ้าไม่มี) |
3 | SELECT USER( ) ชื่อผู้ใช้ปัจจุบัน |
4 | SHOW STATUS ตัวบ่งชี้สถานะเซิร์ฟเวอร์ |
5 | SHOW VARIABLES ตัวแปรการกำหนดค่าเซิร์ฟเวอร์ |
ลำดับคือชุดของจำนวนเต็ม 1, 2, 3, ... ที่สร้างขึ้นตามความต้องการเฉพาะ ลำดับมักใช้ในฐานข้อมูลเนื่องจากแอ็พพลิเคชันจำนวนมากต้องการให้แต่ละแถวในตารางมีค่าที่ไม่ซ้ำกันและลำดับเป็นวิธีที่ง่ายในการสร้าง
บทนี้อธิบายถึงวิธีการใช้ลำดับใน MySQL
ใช้คอลัมน์ AUTO_INCREMENT
วิธีที่ง่ายที่สุดใน MySQL ในการใช้ Sequences คือการกำหนดคอลัมน์เป็น AUTO_INCREMENT และฝากสิ่งที่เหลือให้ MySQL ดูแล
ตัวอย่าง
ลองดูตัวอย่างต่อไปนี้ สิ่งนี้จะสร้างตารางและหลังจากนั้นจะแทรกแถวสองสามแถวในตารางนี้ซึ่งไม่จำเป็นต้องให้ ID บันทึกเนื่องจาก MySQL จะเพิ่มขึ้นอัตโนมัติ
mysql> CREATE TABLE insect
-> (
-> id INT UNSIGNED NOT NULL AUTO_INCREMENT,
-> PRIMARY KEY (id),
-> name VARCHAR(30) NOT NULL, # type of insect
-> date DATE NOT NULL, # date collected
-> origin VARCHAR(30) NOT NULL # where collected
);
Query OK, 0 rows affected (0.02 sec)
mysql> INSERT INTO insect (id,name,date,origin) VALUES
-> (NULL,'housefly','2001-09-10','kitchen'),
-> (NULL,'millipede','2001-09-10','driveway'),
-> (NULL,'grasshopper','2001-09-10','front yard');
Query OK, 3 rows affected (0.02 sec)
Records: 3 Duplicates: 0 Warnings: 0
mysql> SELECT * FROM insect ORDER BY id;
+----+-------------+------------+------------+
| id | name | date | origin |
+----+-------------+------------+------------+
| 1 | housefly | 2001-09-10 | kitchen |
| 2 | millipede | 2001-09-10 | driveway |
| 3 | grasshopper | 2001-09-10 | front yard |
+----+-------------+------------+------------+
3 rows in set (0.00 sec)
รับค่า AUTO_INCREMENT
LAST_INSERT_ID( )เป็นฟังก์ชัน SQL ดังนั้นคุณสามารถใช้งานได้จากภายในไคลเอนต์ใด ๆ ที่เข้าใจวิธีการออกคำสั่ง SQL มิฉะนั้นสคริปต์ PERL และ PHP จะมีฟังก์ชันพิเศษในการดึงค่าที่เพิ่มขึ้นโดยอัตโนมัติของบันทึกล่าสุด
ตัวอย่าง PERL
ใช้ mysql_insertid แอตทริบิวต์เพื่อรับไฟล์ AUTO_INCREMENTค่าที่สร้างโดยแบบสอบถาม แอ็ตทริบิวต์นี้สามารถเข้าถึงได้ผ่านทางที่จับฐานข้อมูลหรือหมายเลขอ้างอิงคำสั่งขึ้นอยู่กับวิธีที่คุณออกแบบสอบถาม
ตัวอย่างต่อไปนี้อ้างอิงผ่านตัวจัดการฐานข้อมูล
$dbh->do ("INSERT INTO insect (name,date,origin) VALUES('moth','2001-09-14','windowsill')"); my $seq = $dbh->{mysql_insertid};
ตัวอย่าง PHP
หลังจากออกแบบสอบถามที่สร้างค่า AUTO_INCREMENT ให้ดึงค่าโดยเรียกใช้ mysql_insert_id( ) คำสั่ง
mysql_query ("INSERT INTO insect (name,date,origin)
VALUES('moth','2001-09-14','windowsill')", $conn_id);
$seq = mysql_insert_id ($conn_id);
การเปลี่ยนหมายเลขลำดับที่มีอยู่
อาจมีบางกรณีที่คุณลบระเบียนจำนวนมากออกจากตารางและคุณต้องการเรียงลำดับระเบียนทั้งหมดใหม่ ซึ่งสามารถทำได้โดยใช้เคล็ดลับง่ายๆ แต่คุณควรระมัดระวังในการทำเช่นนั้นหากโต๊ะของคุณมีการเชื่อมต่อกับโต๊ะอื่น
หากคุณพิจารณาแล้วว่าการจัดเรียงคอลัมน์ใหม่ของ AUTO_INCREMENT เป็นสิ่งที่หลีกเลี่ยงไม่ได้วิธีการทำก็คือการปล่อยคอลัมน์ออกจากตารางจากนั้นเพิ่มอีกครั้ง
ตัวอย่างต่อไปนี้แสดงวิธีการเปลี่ยนหมายเลข id values ในตารางโดยใช้เทคนิคนี้
mysql> ALTER TABLE insect DROP id;
mysql> ALTER TABLE insect
-> ADD id INT UNSIGNED NOT NULL AUTO_INCREMENT FIRST,
-> ADD PRIMARY KEY (id);
เริ่มต้นลำดับที่ค่าเฉพาะ
ตามค่าเริ่มต้น MySQL จะเริ่มลำดับจาก 1 แต่คุณสามารถระบุหมายเลขอื่น ๆ ได้เช่นกันในขณะที่สร้างตาราง
โปรแกรมต่อไปนี้เป็นตัวอย่างที่แสดงให้เห็นว่า MySQL จะเริ่มต้นลำดับจาก 100 อย่างไร
mysql> CREATE TABLE insect
-> (
-> id INT UNSIGNED NOT NULL AUTO_INCREMENT = 100,
-> PRIMARY KEY (id),
-> name VARCHAR(30) NOT NULL, # type of insect
-> date DATE NOT NULL, # date collected
-> origin VARCHAR(30) NOT NULL # where collected
);
หรือคุณสามารถสร้างตารางจากนั้นตั้งค่าลำดับเริ่มต้นด้วย ALTER TABLE คำสั่ง
mysql> ALTER TABLE t AUTO_INCREMENT = 100;
โดยทั่วไปตารางหรือชุดผลลัพธ์บางครั้งจะมีระเบียนที่ซ้ำกัน ส่วนใหญ่จะอนุญาต แต่บางครั้งก็จำเป็นต้องหยุดบันทึกที่ซ้ำกัน จำเป็นต้องระบุระเบียนที่ซ้ำกันและลบออกจากตาราง บทนี้จะอธิบายถึงวิธีการป้องกันไม่ให้เกิดระเบียนที่ซ้ำกันในตารางและวิธีการลบระเบียนที่ซ้ำกันที่มีอยู่แล้ว
การป้องกันไม่ให้รายการที่ซ้ำกันเกิดขึ้นในตาราง
คุณสามารถใช้ไฟล์ PRIMARY KEY หรือก UNIQUE จัดทำดัชนีบนตารางที่มีเขตข้อมูลที่เหมาะสมเพื่อหยุดการบันทึกซ้ำ
ให้เรายกตัวอย่าง - ตารางต่อไปนี้ไม่มีดัชนีหรือคีย์หลักดังกล่าวดังนั้นจึงอนุญาตให้มีระเบียนที่ซ้ำกันสำหรับ first_name และ last_name.
CREATE TABLE person_tbl (
first_name CHAR(20),
last_name CHAR(20),
sex CHAR(10)
);
ในการป้องกันไม่ให้หลายระเบียนที่มีค่าชื่อและนามสกุลเดียวกันถูกสร้างขึ้นในตารางนี้ให้เพิ่มไฟล์ PRIMARY KEYตามความหมายของมัน เมื่อคุณทำเช่นนี้คุณจำเป็นต้องประกาศคอลัมน์ที่จัดทำดัชนีไว้ด้วยNOT NULLเพราะก PRIMARY KEY ไม่อนุญาต NULL ค่า -
CREATE TABLE person_tbl (
first_name CHAR(20) NOT NULL,
last_name CHAR(20) NOT NULL,
sex CHAR(10),
PRIMARY KEY (last_name, first_name)
);
การมีดัชนีที่ไม่ซ้ำกันในตารางโดยปกติจะทำให้เกิดข้อผิดพลาดหากคุณแทรกระเบียนลงในตารางที่ทำซ้ำระเบียนที่มีอยู่ในคอลัมน์หรือคอลัมน์ที่กำหนดดัชนี
ใช้ INSERT IGNORE มากกว่าคำสั่ง INSERTคำสั่ง หากระเบียนไม่ซ้ำกับระเบียนที่มีอยู่ MySQL จะแทรกตามปกติ หากเรกคอร์ดซ้ำกันแสดงว่าไฟล์IGNORE คีย์เวิร์ดบอกให้ MySQL ทิ้งโดยไม่ทำให้เกิดข้อผิดพลาด
ตัวอย่างต่อไปนี้ไม่มีข้อผิดพลาดและในเวลาเดียวกันก็จะไม่แทรกระเบียนที่ซ้ำกันด้วย
mysql> INSERT IGNORE INTO person_tbl (last_name, first_name)
-> VALUES( 'Jay', 'Thomas');
Query OK, 1 row affected (0.00 sec)
mysql> INSERT IGNORE INTO person_tbl (last_name, first_name)
-> VALUES( 'Jay', 'Thomas');
Query OK, 0 rows affected (0.00 sec)
ใช้ REPLACEคำสั่งแทนที่จะเป็นคำสั่ง INSERT หากเร็กคอร์ดใหม่จะถูกแทรกเช่นเดียวกับ INSERT หากเป็นข้อมูลที่ซ้ำกันระเบียนใหม่จะแทนที่ระเบียนเก่า
mysql> REPLACE INTO person_tbl (last_name, first_name)
-> VALUES( 'Ajay', 'Kumar');
Query OK, 1 row affected (0.00 sec)
mysql> REPLACE INTO person_tbl (last_name, first_name)
-> VALUES( 'Ajay', 'Kumar');
Query OK, 2 rows affected (0.00 sec)
ควรเลือกคำสั่ง INSERT IGNORE และ REPLACE ตามพฤติกรรมการจัดการซ้ำที่คุณต้องการให้มีผล คำสั่ง INSERT IGNORE เก็บชุดแรกของระเบียนที่ซ้ำกันและทิ้งส่วนที่เหลือ คำสั่ง REPLACE เก็บชุดสุดท้ายของรายการที่ซ้ำกันและลบรายการก่อนหน้านี้ออก
อีกวิธีหนึ่งในการบังคับใช้ความเป็นเอกลักษณ์คือการเพิ่มไฟล์ UNIQUE ดัชนีแทนที่จะเป็นคีย์หลักไปยังตาราง
CREATE TABLE person_tbl (
first_name CHAR(20) NOT NULL,
last_name CHAR(20) NOT NULL,
sex CHAR(10)
UNIQUE (last_name, first_name)
);
การนับและการระบุรายการที่ซ้ำกัน
ต่อไปนี้เป็นแบบสอบถามเพื่อนับระเบียนที่ซ้ำกันด้วย first_name และ last_name ในตาราง
mysql> SELECT COUNT(*) as repetitions, last_name, first_name
-> FROM person_tbl
-> GROUP BY last_name, first_name
-> HAVING repetitions > 1;
แบบสอบถามนี้จะแสดงรายการของระเบียนที่ซ้ำกันทั้งหมดในตาราง person_tbl โดยทั่วไปในการระบุชุดของค่าที่ซ้ำกันให้ทำตามขั้นตอนด้านล่าง
พิจารณาว่าคอลัมน์ใดมีค่าที่อาจซ้ำกัน
แสดงรายการคอลัมน์เหล่านั้นในรายการการเลือกคอลัมน์พร้อมกับ COUNT(*).
แสดงรายการคอลัมน์ในไฟล์ GROUP BY อนุประโยคเช่นกัน
เพิ่ม HAVING ประโยคที่กำจัดค่าที่ไม่ซ้ำกันโดยกำหนดให้การนับกลุ่มมีค่ามากกว่าหนึ่ง
การกำจัดรายการที่ซ้ำกันออกจากผลการสืบค้น
คุณสามารถใช้ไฟล์ DISTINCT คำสั่งพร้อมกับคำสั่ง SELECT เพื่อค้นหาระเบียนเฉพาะที่มีอยู่ในตาราง
mysql> SELECT DISTINCT last_name, first_name
-> FROM person_tbl
-> ORDER BY last_name;
อีกทางเลือกหนึ่งของคำสั่ง DISTINCT คือการเพิ่ม GROUP BY clause ที่ตั้งชื่อคอลัมน์ที่คุณกำลังเลือก สิ่งนี้มีผลในการลบรายการที่ซ้ำกันและเลือกเฉพาะชุดค่าผสมที่ไม่ซ้ำกันในคอลัมน์ที่ระบุ
mysql> SELECT last_name, first_name
-> FROM person_tbl
-> GROUP BY (last_name, first_name);
การลบรายการที่ซ้ำกันโดยใช้การเปลี่ยนตาราง
หากคุณมีระเบียนที่ซ้ำกันในตารางและคุณต้องการลบระเบียนที่ซ้ำกันทั้งหมดออกจากตารางนั้นให้ทำตามขั้นตอนที่ระบุด้านล่าง
mysql> CREATE TABLE tmp SELECT last_name, first_name, sex
-> FROM person_tbl;
-> GROUP BY (last_name, first_name);
mysql> DROP TABLE person_tbl;
mysql> ALTER TABLE tmp RENAME TO person_tbl;
วิธีง่ายๆในการลบระเบียนที่ซ้ำกันออกจากตารางคือการเพิ่ม INDEX หรือ PRIMARY KEY ลงในตารางนั้น แม้ว่าตารางนี้จะมีอยู่แล้ว แต่คุณสามารถใช้เทคนิคนี้เพื่อลบระเบียนที่ซ้ำกันและคุณจะปลอดภัยในอนาคตเช่นกัน
mysql> ALTER IGNORE TABLE person_tbl
-> ADD PRIMARY KEY (last_name, first_name);
หากคุณรับข้อมูลผู้ใช้ผ่านหน้าเว็บและแทรกลงในฐานข้อมูล MySQL มีโอกาสที่คุณจะเปิดกว้างสำหรับปัญหาด้านความปลอดภัยที่เรียกว่า SQL Injection. บทนี้จะสอนวิธีช่วยป้องกันไม่ให้เหตุการณ์นี้เกิดขึ้นและช่วยให้สคริปต์และคำสั่ง MySQL ของคุณปลอดภัย
การฉีด SQL มักเกิดขึ้นเมื่อคุณขอให้ผู้ใช้ป้อนข้อมูลเช่นชื่อของพวกเขาและแทนที่จะเป็นชื่อพวกเขาให้คำสั่ง MySQL แก่คุณซึ่งคุณจะเรียกใช้ฐานข้อมูลของคุณโดยไม่รู้ตัว
อย่าเชื่อถือข้อมูลที่ผู้ใช้ให้มาประมวลผลข้อมูลนี้หลังจากการตรวจสอบความถูกต้องเท่านั้น ตามกฎแล้วสิ่งนี้ทำได้โดยการจับคู่รูปแบบ ในตัวอย่างต่อไปนี้ชื่อผู้ใช้ถูก จำกัด ไว้ที่อักขระที่เป็นตัวอักษรและตัวเลขคละกันบวกขีดล่างและมีความยาวระหว่าง 8 ถึง 20 อักขระให้แก้ไขกฎเหล่านี้ตามต้องการ
if (preg_match("/^\w{8,20}$/", $_GET['username'], $matches)) { $result = mysql_query("SELECT * FROM users WHERE username = $matches[0]");
} else {
echo "username not accepted";
}
เพื่อแสดงให้เห็นถึงปัญหานี้ให้พิจารณาข้อความที่ตัดตอนมาต่อไปนี้
// supposed input
$name = "Qadir'; DELETE FROM users;";
mysql_query("SELECT * FROM users WHERE name = '{$name}'");
การเรียกใช้ฟังก์ชันควรจะดึงข้อมูลจากตารางผู้ใช้โดยที่คอลัมน์ชื่อตรงกับชื่อที่ผู้ใช้ระบุ ภายใต้สถานการณ์ปกติ $ name จะมีเฉพาะอักขระที่เป็นตัวเลขและตัวอักษรและอาจเว้นวรรค แต่ที่นี่โดยการต่อท้ายข้อความค้นหาใหม่ทั้งหมด$nameการโทรไปยังฐานข้อมูลกลายเป็นหายนะ การสอบถาม DELETE ที่แทรกจะลบระเบียนทั้งหมดจากผู้ใช้
โชคดีถ้าคุณใช้ MySQL ไฟล์ mysql_query()ฟังก์ชันไม่อนุญาตให้มีการซ้อนคิวรีหรือเรียกใช้การสืบค้นหลายรายการในการเรียกฟังก์ชันเดียว หากคุณพยายามซ้อนคิวรีการโทรล้มเหลว
อย่างไรก็ตามส่วนขยายฐานข้อมูล PHP อื่น ๆ เช่น SQLite และ PostgreSQLดำเนินการค้นหาแบบเรียงซ้อนอย่างมีความสุขดำเนินการค้นหาทั้งหมดที่มีให้ในสตริงเดียวและสร้างปัญหาด้านความปลอดภัยที่ร้ายแรง
การป้องกัน SQL Injection
คุณสามารถจัดการอักขระ Escape ทั้งหมดได้อย่างชาญฉลาดในภาษาสคริปต์เช่น PERL และ PHP ส่วนขยาย MySQL สำหรับ PHP มีฟังก์ชันmysql_real_escape_string() เพื่อหลีกเลี่ยงอักขระอินพุตที่พิเศษสำหรับ MySQL
if (get_magic_quotes_gpc()) {
$name = stripslashes($name); } $name = mysql_real_escape_string($name); mysql_query("SELECT * FROM users WHERE name = '{$name}'");
ชอบความไม่แน่ใจ
ในการจัดการกับปัญหา LIKE กลไกการหลีกเลี่ยงที่กำหนดเองต้องแปลงอักขระ% และ _ ที่ผู้ใช้จัดหาให้เป็นตัวอักษร ใช้addcslashes()ซึ่งเป็นฟังก์ชันที่ให้คุณระบุช่วงอักขระที่จะหลบหนี
$sub = addcslashes(mysql_real_escape_string("%something_"), "%_"); // $sub == \%something\_
mysql_query("SELECT * FROM messages WHERE subject LIKE '{$sub}%'");
วิธีที่ง่ายที่สุดในการส่งออกข้อมูลตารางไปยังไฟล์ข้อความคือการใช้ไฟล์ SELECT...INTO OUTFILE คำสั่งที่ส่งออกผลลัพธ์แบบสอบถามไปยังไฟล์บนโฮสต์เซิร์ฟเวอร์โดยตรง
การส่งออกข้อมูลด้วยคำสั่ง SELECT ... INTO OUTFILE
ไวยากรณ์สำหรับคำสั่งนี้รวมปกติ SELECT คำสั่งด้วย INTO OUTFILE filenameในตอนท้าย รูปแบบเอาต์พุตเริ่มต้นจะเหมือนกับคำสั่ง LOAD DATA ดังนั้นคำสั่งต่อไปนี้จะส่งออกไฟล์tutorials_tbl ตารางเป็น /tmp/tutorials.txt เป็นไฟล์ที่คั่นด้วยแท็บบรรทัดสิ้นสุดการฟีด
mysql> SELECT * FROM tutorials_tbl
-> INTO OUTFILE '/tmp/tutorials.txt';
คุณสามารถเปลี่ยนรูปแบบผลลัพธ์โดยใช้ตัวเลือกต่างๆเพื่อระบุวิธีการอ้างอิงและคั่นคอลัมน์และเรกคอร์ด ในการส่งออกตาราง tutorial_tbl ในรูปแบบ CSV ด้วยบรรทัดที่สิ้นสุด CRLF ให้ใช้รหัสต่อไปนี้
mysql> SELECT * FROM passwd INTO OUTFILE '/tmp/tutorials.txt'
-> FIELDS TERMINATED BY ',' ENCLOSED BY '"'
-> LINES TERMINATED BY '\r\n';
SELECT ... INTO OUTFILE มีคุณสมบัติดังต่อไปนี้ -
ไฟล์เอาต์พุตถูกสร้างขึ้นโดยตรงโดยเซิร์ฟเวอร์ MySQL ดังนั้นชื่อไฟล์ควรระบุตำแหน่งที่คุณต้องการให้เขียนไฟล์บนโฮสต์เซิร์ฟเวอร์ ไม่มีคำสั่งในเวอร์ชันท้องถิ่นที่คล้ายคลึงกับLOCAL เวอร์ชันของ LOAD DATA.
คุณต้องมีไฟล์ MySQL FILE สิทธิ์ในการเรียกใช้ไฟล์ SELECT ... INTO คำให้การ.
ไฟล์เอาต์พุตต้องไม่มีอยู่แล้ว ซึ่งจะป้องกันไม่ให้ MySQL คัดลอกไฟล์ที่อาจมีความสำคัญ
คุณควรมีบัญชีเข้าสู่ระบบบนโฮสต์เซิร์ฟเวอร์หรือวิธีการบางอย่างในการดึงไฟล์จากโฮสต์นั้น มิฉะนั้นไฟล์SELECT ... INTO OUTFILE คำสั่งมักจะไม่มีค่าสำหรับคุณ
ภายใต้ UNIX ไฟล์จะถูกสร้างขึ้น world readableและเป็นของเซิร์ฟเวอร์ MySQL ซึ่งหมายความว่าแม้ว่าคุณจะสามารถอ่านไฟล์ได้ แต่คุณอาจไม่สามารถลบไฟล์ได้
การส่งออกตารางเป็นข้อมูลดิบ
mysqldumpโปรแกรมใช้เพื่อคัดลอกหรือสำรองตารางและฐานข้อมูล มันสามารถเขียนผลลัพธ์ของตารางเป็นไฟล์Raw Datafile หรือเป็นชุดของ INSERT คำสั่งที่สร้างระเบียนใหม่ในตาราง
ในการถ่ายโอนข้อมูลตารางเป็นดาต้าไฟล์คุณต้องระบุไฟล์ --tab ตัวเลือกที่ระบุไดเร็กทอรีที่คุณต้องการให้เซิร์ฟเวอร์ MySQL เขียนไฟล์
ตัวอย่างเช่นในการถ่ายโอนไฟล์ tutorials_tbl ตารางจาก TUTORIALS ฐานข้อมูลไปยังไฟล์ในรูปแบบ /tmp ไดเร็กทอรีให้ใช้คำสั่งดังที่แสดงด้านล่าง
$ mysqldump -u root -p --no-create-info \
--tab=/tmp tutorials tutorials_tbl
password ******
การส่งออกสารบัญตารางหรือคำจำกัดความในรูปแบบ SQL
ในการส่งออกตารางในรูปแบบ SQL ไปยังไฟล์ให้ใช้คำสั่งที่แสดงด้านล่าง
$ mysqldump -u root -p TUTORIALS tutorials_tbl > dump.txt
password ******
นี่จะเป็นการสร้างไฟล์ที่มีเนื้อหาดังที่แสดงด้านล่าง
-- MySQL dump 8.23
--
-- Host: localhost Database: TUTORIALS
---------------------------------------------------------
-- Server version 3.23.58
--
-- Table structure for table `tutorials_tbl`
--
CREATE TABLE tutorials_tbl (
tutorial_id int(11) NOT NULL auto_increment,
tutorial_title varchar(100) NOT NULL default '',
tutorial_author varchar(40) NOT NULL default '',
submission_date date default NULL,
PRIMARY KEY (tutorial_id),
UNIQUE KEY AUTHOR_INDEX (tutorial_author)
) TYPE = MyISAM;
--
-- Dumping data for table `tutorials_tbl`
--
INSERT INTO tutorials_tbl
VALUES (1,'Learn PHP','John Poul','2007-05-24');
INSERT INTO tutorials_tbl
VALUES (2,'Learn MySQL','Abdul S','2007-05-24');
INSERT INTO tutorials_tbl
VALUES (3,'JAVA Tutorial','Sanjay','2007-05-06');
ในการถ่ายโอนข้อมูลหลายตารางให้ตั้งชื่อตารางทั้งหมดตามด้วยอาร์กิวเมนต์ชื่อฐานข้อมูล ในการถ่ายโอนฐานข้อมูลทั้งหมดอย่าตั้งชื่อตารางใด ๆ หลังฐานข้อมูลดังที่แสดงในบล็อกโค้ดต่อไปนี้
$ mysqldump -u root -p TUTORIALS > database_dump.txt
password ******
ในการสำรองฐานข้อมูลทั้งหมดที่มีอยู่บนโฮสต์ของคุณให้ใช้รหัสต่อไปนี้
$ mysqldump -u root -p --all-databases > database_dump.txt
password ******
ตัวเลือก - all-databases มีอยู่ในเวอร์ชัน MySQL 3.23.12 วิธีนี้สามารถใช้เพื่อใช้กลยุทธ์การสำรองฐานข้อมูล
การคัดลอกตารางหรือฐานข้อมูลไปยังโฮสต์อื่น
หากคุณต้องการคัดลอกตารางหรือฐานข้อมูลจากเซิร์ฟเวอร์ MySQL หนึ่งไปยังอีกเซิร์ฟเวอร์หนึ่งให้ใช้ไฟล์ mysqldump ด้วยชื่อฐานข้อมูลและชื่อตาราง
รันคำสั่งต่อไปนี้ที่โฮสต์ต้นทาง สิ่งนี้จะถ่ายโอนฐานข้อมูลทั้งหมดลงในdump.txt ไฟล์.
$ mysqldump -u root -p database_name table_name > dump.txt
password *****
คุณสามารถคัดลอกฐานข้อมูลทั้งหมดโดยไม่ต้องใช้ชื่อตารางเฉพาะตามที่อธิบายไว้ข้างต้น
ตอนนี้ไฟล์ ftp dump.txt บนโฮสต์อื่นและใช้คำสั่งต่อไปนี้ ก่อนรันคำสั่งนี้ตรวจสอบให้แน่ใจว่าคุณได้สร้าง database_name บนเซิร์ฟเวอร์ปลายทาง
$ mysql -u root -p database_name < dump.txt
password *****
อีกวิธีหนึ่งในการดำเนินการนี้โดยไม่ใช้ไฟล์ตัวกลางคือการส่งเอาต์พุตของ mysqldump โดยตรงผ่านเครือข่ายไปยังเซิร์ฟเวอร์ MySQL ระยะไกล หากคุณสามารถเชื่อมต่อกับเซิร์ฟเวอร์ทั้งสองจากโฮสต์ที่ฐานข้อมูลต้นทางอยู่ให้ใช้คำสั่งต่อไปนี้ (ตรวจสอบให้แน่ใจว่าคุณมีสิทธิ์เข้าถึงบนเซิร์ฟเวอร์ทั้งสองเครื่อง)
$ mysqldump -u root -p database_name \
| mysql -h other-host.com database_name
ใน mysqldump ครึ่งหนึ่งของคำสั่งจะเชื่อมต่อกับโลคัลเซิร์ฟเวอร์และเขียนเอาต์พุตการถ่ายโอนข้อมูลไปยังไพพ์ คำสั่งที่เหลืออีกครึ่งหนึ่งจะเชื่อมต่อกับเซิร์ฟเวอร์ MySQL ระยะไกลบน other-host.com มันอ่านไปป์สำหรับอินพุตและส่งแต่ละคำสั่งไปยังเซิร์ฟเวอร์ other-host.com
มีสองวิธีง่ายๆใน MySQL ในการโหลดข้อมูลลงในฐานข้อมูล MySQL จากไฟล์ที่สำรองไว้ก่อนหน้านี้
การนำเข้าข้อมูลด้วย LOAD DATA
MySQL มีคำสั่ง LOAD DATA ที่ทำหน้าที่เป็นตัวโหลดข้อมูลจำนวนมาก นี่คือตัวอย่างคำสั่งที่อ่านไฟล์dump.txt จากไดเร็กทอรีปัจจุบันของคุณและโหลดลงในตาราง mytbl ในฐานข้อมูลปัจจุบัน
mysql> LOAD DATA LOCAL INFILE 'dump.txt' INTO TABLE mytbl;
ถ้า LOCAL ไม่มีคีย์เวิร์ด MySQL จะค้นหา datafile บนโฮสต์เซิร์ฟเวอร์โดยใช้ไฟล์ looking into absolute pathnameซึ่งระบุตำแหน่งของไฟล์อย่างสมบูรณ์โดยเริ่มจากรูทของระบบไฟล์ MySQL อ่านไฟล์จากตำแหน่งที่กำหนด
โดยค่าเริ่มต้น, LOAD DATA ถือว่า datafiles มีบรรทัดที่สิ้นสุดโดย linefeeds (newlines) และค่าข้อมูลภายในบรรทัดจะถูกคั่นด้วยแท็บ
ในการระบุรูปแบบไฟล์อย่างชัดเจนให้ใช้ไฟล์ FIELDS อนุประโยคเพื่ออธิบายลักษณะของเขตข้อมูลภายในบรรทัดและก LINESอนุประโยคเพื่อระบุลำดับการสิ้นสุดบรรทัด ดังต่อไปนี้LOAD DATA คำสั่งระบุว่า datafile มีค่าที่คั่นด้วยโคลอนและบรรทัดที่สิ้นสุดโดยการส่งคืนค่าขนส่งและอักขระขึ้นบรรทัดใหม่
mysql> LOAD DATA LOCAL INFILE 'dump.txt' INTO TABLE mytbl
-> FIELDS TERMINATED BY ':'
-> LINES TERMINATED BY '\r\n';
คำสั่ง LOAD DATA ถือว่าคอลัมน์ใน datafile มีลำดับเดียวกันกับคอลัมน์ในตาราง หากไม่เป็นความจริงคุณสามารถระบุรายการเพื่อระบุว่าคอลัมน์ตารางใดที่ควรโหลดคอลัมน์ datafile สมมติว่าตารางของคุณมีคอลัมน์ a, b และ c แต่คอลัมน์ที่ต่อเนื่องกันใน datafile จะตรงกับคอลัมน์ b, c และ a
คุณสามารถโหลดไฟล์ดังที่แสดงในบล็อกโค้ดต่อไปนี้
mysql> LOAD DATA LOCAL INFILE 'dump.txt'
-> INTO TABLE mytbl (b, c, a);
การนำเข้าข้อมูลด้วย mysqlimport
MySQL ยังมีโปรแกรมยูทิลิตี้ชื่อ mysqlimport ที่ทำหน้าที่ห่อหุ้มรอบ ๆ LOAD DATA เพื่อให้คุณสามารถโหลดไฟล์อินพุตได้โดยตรงจากบรรทัดคำสั่ง
ในการโหลดข้อมูลจากไฟล์ dump.txt เป็น mytblใช้คำสั่งต่อไปนี้ที่พร้อมต์ UNIX
$ mysqlimport -u root -p --local database_name dump.txt
password *****
ถ้าคุณใช้ mysqlimportตัวเลือกบรรทัดคำสั่งให้ตัวระบุรูปแบบ mysqlimport คำสั่งที่สอดคล้องกับสองคำสั่งก่อนหน้านี้ LOAD DATA คำสั่งมีลักษณะดังที่แสดงในบล็อกรหัสต่อไปนี้
$ mysqlimport -u root -p --local --fields-terminated-by = ":" \
--lines-terminated-by = "\r\n" database_name dump.txt
password *****
ลำดับที่คุณระบุอ็อพชันไม่สำคัญสำหรับ mysqlimport ยกเว้นว่าทั้งหมดควรนำหน้าชื่อฐานข้อมูล
mysqlimport คำสั่งใช้ --columns ตัวเลือกเพื่อระบุลำดับคอลัมน์ -
$ mysqlimport -u root -p --local --columns=b,c,a \
database_name dump.txt
password *****
การจัดการคำพูดและตัวละครพิเศษ
คำสั่ง FIELDS สามารถระบุตัวเลือกรูปแบบอื่น ๆ นอกจากนี้ TERMINATED BY. โดยค่าเริ่มต้น LOAD DATA จะถือว่าค่าไม่ได้ใส่เครื่องหมายคำพูดและตีความเครื่องหมายแบ็กสแลช (\) เป็นอักขระหลีกสำหรับอักขระพิเศษ ในการระบุค่าที่อ้างถึงอักขระอย่างชัดเจนให้ใช้ENCLOSED BYคำสั่ง MySQL จะดึงอักขระนั้นออกจากส่วนท้ายของค่าข้อมูลในระหว่างการประมวลผลอินพุต หากต้องการเปลี่ยนอักขระหลีกเริ่มต้นให้ใช้ESCAPED BY.
เมื่อคุณระบุ ENCLOSED BY เพื่อระบุว่าอักขระอัญประกาศควรถูกตัดออกจากค่าข้อมูลเป็นไปได้ที่จะรวมอักขระเครื่องหมายคำพูดไว้ในค่าข้อมูลโดยการเพิ่มเป็นสองเท่าหรือโดยนำหน้าด้วยอักขระหลีก
ตัวอย่างเช่นถ้าเครื่องหมายคำพูดและอักขระหลีกคือ "และ \, ค่าที่ป้อน "a""b\"c" จะถูกตีความว่า a"b"c.
สำหรับ mysqlimportอ็อพชันบรรทัดคำสั่งที่เกี่ยวข้องสำหรับการระบุใบเสนอราคาและค่า Escape คือ --fields-enclosed-by และ --fields-escaped-by.