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

จะลบค่าเดียวจากตาราง MySQL ที่มีระเบียนที่ซ้ำกันได้อย่างไร


ใช้ DELETE เพื่อลบระเบียน แต่ถ้าคุณมีระเบียนที่ซ้ำกันหลายระเบียน ให้จำกัดการลบโดยใช้ MySQL LIMIT ตามรูปแบบต่อไปนี้ -

ไวยากรณ์

ลบออกจาก yourTableName โดยที่ yourColumnName=yourValue จำกัด 1;

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

mysql> สร้างตาราง DemoTable -> ( -> จำนวน int -> ); ตกลง ตกลง 0 แถวได้รับผลกระทบ (1.38 วินาที)

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

mysql> แทรกลงในค่า DemoTable (50) แบบสอบถามตกลง 1 แถวได้รับผลกระทบ (0.23 วินาที) mysql> แทรกลงในค่า DemoTable (100) แบบสอบถามตกลง 1 แถวได้รับผลกระทบ (0.36 วินาที) mysql> แทรกลงในค่า DemoTable ( 50); แบบสอบถามตกลง 1 แถวได้รับผลกระทบ (0.59 วินาที) mysql> แทรกลงในค่า DemoTable (70); แบบสอบถามตกลง 1 แถวได้รับผลกระทบ (0.18 วินาที) mysql> แทรกลงในค่า DemoTable (90); แบบสอบถามตกลง 1 แถวได้รับผลกระทบ ( 0.13 วินาที) mysql> แทรกลงในค่า DemoTable (50) แบบสอบถามตกลง ได้รับผลกระทบ 1 แถว (0.23 วินาที)

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

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

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

<ก่อนหน้า>+---------+| จำนวน |+-------+| 50 || 100 || 50 || 70 || 90 || 50 |+--------+6 แถวในชุด (0.00 วินาที)

นี่คือแบบสอบถามเพื่อลบค่าเดียวจากตาราง -

mysql> ลบออกจาก DemoTable โดยที่ Amount=50 จำกัด 1; Query OK, 1 แถวได้รับผลกระทบ (0.39 วินาที)

ให้เราตรวจสอบบันทึกตารางอีกครั้ง -

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

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

<ก่อนหน้า>+---------+| จำนวน |+-------+| 100 || 50 || 70 || 90 || 50 |+-------+5 แถวในชุด (0.00 วินาที)