关闭

一道关于删除数据表中重复数据的笔试题

90人阅读 评论(0) 收藏 举报
一张存放学生学号、姓名、课程以及成绩的数据表,设计将同一学号的记录只保留一条


结果如下图所示





 我的答案:

[sql] view plain copy
 在CODE上查看代码片派生到我的代码片
  1. CREATE TABLE IF NOT EXISTS `student` (  
  2. `stu_no` int unsigned NOT NULL DEFAULT 0,  
  3. `stu_name` varchar(20) not null DEFAULT '',  
  4. `scheme` varchar(20) not null DEFAULT '',  
  5. `grade` int unsigned not null DEFAULT 0  
  6. )ENGINE=InnoDB DEFAULT CHARSET=utf8 ;  
  7.   
  8. INSERT INTO `student` VALUES (1001, '张三''数学', 90);  
  9. INSERT INTO `student` VALUES (1002, '李四''英语', 80);  
  10. INSERT INTO `student` VALUES (1003, '王五''语文', 100);  
  11. INSERT INTO `student` VALUES (1001, '张三''数学', 90);  
  12. INSERT INTO `student` VALUES (1002, '李四''英语', 80);  
  13. INSERT INTO `student` VALUES (1003, '王五''语文', 100);  
  14. INSERT INTO `student` VALUES (1001, '张三''数学', 90);  
  15. INSERT INTO `student` VALUES (1002, '李四''英语', 80);  
  16. INSERT INTO `student` VALUES (1003, '王五''语文', 100);  
  17.   
  18. CREATE TABLE `student_2` LIKE `student`;  
  19.   
  20. ALTER TABLE `student_2` ADD CONSTRAINT uk_stu_no UNIQUE(`stu_no`);  
  21.   
  22. INSERT IGNORE INTO `student_2` SELECT * FROM `student`;  
  23.   
  24. DROP TABLE `student`;  
  25.   
  26. ALTER TABLE `student_2` RENAME TO `student`;   

或者

[sql] view plain copy
 在CODE上查看代码片派生到我的代码片
  1. CREATE TABLE IF NOT EXISTS `student` (  
  2. `stu_no` int unsigned NOT NULL DEFAULT 0,  
  3. `stu_name` varchar(20) not null DEFAULT '',  
  4. `scheme` varchar(20) not null DEFAULT '',  
  5. `grade` int unsigned not null DEFAULT 0  
  6. )ENGINE=InnoDB DEFAULT CHARSET=utf8 ;  
  7.   
  8. INSERT INTO `student` VALUES (1001, '张三''数学', 90);  
  9. INSERT INTO `student` VALUES (1002, '李四''英语', 80);  
  10. INSERT INTO `student` VALUES (1003, '王五''语文', 100);  
  11. INSERT INTO `student` VALUES (1001, '张三''数学', 90);  
  12. INSERT INTO `student` VALUES (1002, '李四''英语', 80);  
  13. INSERT INTO `student` VALUES (1003, '王五''语文', 100);  
  14. INSERT INTO `student` VALUES (1001, '张三''数学', 90);  
  15. INSERT INTO `student` VALUES (1002, '李四''英语', 80);  
  16. INSERT INTO `student` VALUES (1003, '王五''语文', 100);  
  17.   
  18. CREATE TABLE `student_2` LIKE `student`;  
  19.   
  20. #ALTER TABLE `student_2` ADD CONSTRAINT uk_stu_no UNIQUE(`stu_no`);  
  21.   
  22. INSERT IGNORE INTO `student_2` SELECT * FROM `student` GROUP BY `stu_no`;  
  23.   
  24. DROP TABLE `student`;  
  25.   
  26. ALTER TABLE `student_2` RENAME TO `student`;   
0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:14410次
    • 积分:271
    • 等级:
    • 排名:千里之外
    • 原创:5篇
    • 转载:57篇
    • 译文:0篇
    • 评论:0条