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

แบบสอบถาม MySQL เพื่อจัดกลุ่มแถวตามอักขระตัวเลขในฟิลด์สตริง?


สำหรับสิ่งนี้ คุณสามารถต่อ 0 กับฟิลด์สตริงโดยใช้ตัวดำเนินการ + สถานการณ์ที่นี่เหมือนกับว่าเราต้องดึงตัวเลข “9844 ” จากฟิลด์สตริง “9844Bob ”.

ให้เราสร้างตารางก่อน -

mysql> สร้างตาราง DemoTable( StudentId varchar(100)); แบบสอบถามตกลง 0 แถวได้รับผลกระทบ (0.92 วินาที)

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

mysql> แทรกลงในค่า DemoTable ('9844Bob') แบบสอบถามตกลง 1 แถวได้รับผลกระทบ (0.20 วินาที) mysql> แทรกลงในค่า DemoTable ('6375DavidMiller'); แบบสอบถามตกลง 1 แถวได้รับผลกระทบ (0.19 วินาที) mysql> แทรก ลงในค่า DemoTable ('007'); แบบสอบถามตกลง 1 แถวได้รับผลกระทบ (0.09 วินาที) mysql> แทรกลงในค่า DemoTable ('97474BobBrown'); แบบสอบถามตกลง 1 แถวได้รับผลกระทบ (0.20 วินาที) mysql> แทรกลงในค่า DemoTable ('9844Bob56Taylor ');แบบสอบถามตกลง ได้รับผลกระทบ 1 แถว (0.16 วินาที)

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

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

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

<ก่อนหน้า>+-----------------+| รหัสนักศึกษา |+-----------------+| 9844บ๊อบ || 6375เดวิดมิลเลอร์ || 007 || 97474บ๊อบบราวน์ || 9844Bob56Taylor |+-----------------+5 แถวในชุด (0.00 วินาที)

ต่อไปนี้เป็นแบบสอบถามเพื่อจัดกลุ่มแถวตามอักขระตัวเลขในช่องสตริง -

mysql> เลือก StudentId,0+StudentId เป็น GroupValue จาก DemoTable

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

<ก่อนหน้า>+-----------------+-----------+| รหัสนักศึกษา | GroupValue |+-------------------------------------+| 9844บ๊อบ | 9844 || 6375DavidMiller | 6375 || 007 | 7 || 97474บ๊อบบราวน์ | 97474 || 9844Bob56Taylor | 9844 |+-----------+-----------+5 แถวในชุด, 4 คำเตือน (0.00 วินาที)