Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> MySQL

รักษาลำดับที่กำหนดเองของ ID ที่ส่งผ่านใน MySQL


เพื่อรักษาลำดับของ ID ที่กำหนดเอง ให้ใช้คำสั่ง ORDER BY CASE ให้เราสร้างตารางก่อน -

mysql> สร้างตาราง DemoTable1550 -> ( -> Id int, -> Name varchar(20) -> ); ตกลง ตกลง 0 แถวได้รับผลกระทบ (0.61 วินาที)

แทรกระเบียนบางส่วนในตารางโดยใช้คำสั่ง insert -

mysql> แทรกลงในค่า DemoTable1550 (101,'Chris'); แบบสอบถามตกลง, 1 แถวได้รับผลกระทบ (0.10 วินาที) mysql> แทรกลงในค่า DemoTable1550 (110, 'Bob'); แบบสอบถามตกลง 1 แถวได้รับผลกระทบ (0.29 วินาที )mysql> แทรกลงในค่า DemoTable1550 (105, 'Carol'); แบบสอบถามตกลง, 1 แถวได้รับผลกระทบ (0.12 วินาที) mysql> แทรกลงในค่า DemoTable1550 (109, 'ไมค์'); แบบสอบถามตกลง 1 แถวได้รับผลกระทบ (0.17 วินาที) 

แสดงระเบียนทั้งหมดจากตารางโดยใช้คำสั่ง select -

mysql> เลือก * จาก DemoTable1550;

สิ่งนี้จะสร้างผลลัพธ์ต่อไปนี้ -

<ก่อนหน้า>+------+-------+| รหัส | ชื่อ |+------+-------+| 101 | คริส || 110 | บ๊อบ || 105 | แครอล || 109 | ไมค์ |+------+-------+4 แถวในชุด (0.00 วินาที)

นี่คือแบบสอบถามเพื่อรักษาลำดับของรหัสที่ส่งผ่าน -

mysql> เลือก * จาก DemoTable1550 -> โดยที่ Id IN (109,101,110) -> เรียงลำดับตามกรณี Id -> เมื่อ 109 จากนั้น 1001 -> เมื่อ 101 จากนั้น 1002 -> เมื่อ 110 จากนั้น 1003 -> สิ้นสุด;

สิ่งนี้จะสร้างผลลัพธ์ต่อไปนี้ -

<ก่อนหน้า>+------+-------+| รหัส | ชื่อ |+------+-------+| 109 | ไมค์ || 101 | คริส || 110 | Bob |+------+-------+3 แถวในชุด (0.00 วินาที)