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

一张存放学生学号、姓名、课程以及成绩的数据表,设计将同一学号的记录只保留一条


结果如下图所示





 我的答案:

[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`;   
阅读更多
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!
关闭
关闭