SQL增删改操作实例分析

SQL增删改操作实例分析

插入记录

SQL增删改操作实例分析

SQL1 插入记录(一)

表exam_record结构
SQL增删改操作实例分析

 题目描述牛客后台会记录每个用户的试卷作答记录到exam_record表,现在有两个用户的作答记录详情如下:用户1001在2021年9月1日晚上10点11分12秒开始作答试卷9001,并在50分钟后提交,得了90分;用户1002在2021年9月4日上午7点1分2秒开始作答试卷9002,并在10分钟后退出了平台。试卷作答记录表exam_record中,表已建好,其结构如下,请用一条语句将这两条记录插入表中。该题最后会通过执行SELECT uid, exam_id, start_time, submit_time, score FROM exam_record;来对比结果 建表语句drop table if EXISTS exam_record;CREATE TABLE IF NOT EXISTS exam_record (id int PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',uid int NOT NULL COMMENT '用户ID',exam_id int NOT NULL COMMENT '试卷ID',start_time datetime NOT NULL COMMENT '开始时间',submit_time datetime COMMENT '提交时间',score tinyint COMMENT '得分')CHARACTER SET utf8 COLLATE utf8_general_ci;TRUNCATE exam_record; 答案insert INTO exam_record values(null,1001,9001,'2021-09-01 22:11:12','2021-09-01 23:01:12',90),(null,1002,9002,'2021-09-04 07:01:02',null,null);

SQL增删改操作实例分析

SQL2 插入记录(二)

表exam_record结构
SQL增删改操作实例分析

 题目描述现有一张试卷作答记录表exam_record,其中包含多年来的用户作答试卷记录,由于数据越来越多,维护难度越来越大,需要对数据表内容做精简,历史数据做备份。我们已经创建了一张新表exam_record_before_2021用来备份2021年之前的试题作答记录,结构和exam_record表一致,请将2021年之前的已完成了的试题作答纪录导入到该表。后台会通过执行"SELECT * FROM exam_record_before_2021;"语句来对比结果建表语句drop table if EXISTS exam_record;CREATE TABLE IF NOT EXISTS exam_record (id int PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',uid int NOT NULL COMMENT '用户ID',exam_id int NOT NULL COMMENT '试卷ID',start_time datetime NOT NULL COMMENT '开始时间',submit_time datetime COMMENT '提交时间',score tinyint COMMENT '得分')CHARACTER SET utf8 COLLATE utf8_general_ci;CREATE TABLE IF NOT EXISTS exam_record_before_2021 (id int PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',uid int NOT NULL COMMENT '用户ID',exam_id int NOT NULL COMMENT '试卷ID',start_time datetime NOT NULL COMMENT '开始时间',submit_time datetime COMMENT '提交时间',score tinyint COMMENT '得分')CHARACTER SET utf8 COLLATE utf8_general_ci;TRUNCATE exam_record;TRUNCATE exam_record_before_2021;INSERT INTO exam_record(uid,exam_id,start_time,submit_time,score) VALUES(1001, 9001, '2020-01-01 09:00:01', null, null),(1001, 9002, '2020-01-02 09:01:01', '2020-01-02 09:21:01', 70),(1001, 9002, '2020-09-02 09:00:01', null, null),(1002, 9001, '2021-05-02 10:01:01', '2021-05-02 10:30:01', 81),(1002, 9002, '2021-09-02 12:01:01', null, null); 答案INSERT INTO exam_record_before_2021SELECT NULL,uid, exam_id, start_time, submit_time, scoreFROM exam_recordWHERE submit_time < '2021-01-01 00:00:00';

SQL增删改操作实例分析

SQL3 插入记录(三)

试题信息表examination_info结构
SQL增删改操作实例分析

 题目描述现在有一套ID为9003的高难度SQL试卷,时长为一个半小时,请你将 2021-01-01 00:00:00 作为发布时间插入到试题信息表examination_info,不管该ID试卷是否存在,都要插入成功,请尝试插入它。后台会通过执行 SELECT exam_id,tag,difficulty,duration,release_time FROM examination_info 语句来对比结果。 建表语句drop table if EXISTS examination_info;CREATE TABLE IF NOT EXISTS examination_info (id int PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',exam_id int UNIQUE NOT NULL COMMENT '试卷ID',tag varchar(32) COMMENT '类别标签',difficulty varchar(8) COMMENT '难度',duration int NOT NULL COMMENT '时长(分钟数)',release_time datetime COMMENT '发布时间')CHARACTER SET utf8 COLLATE utf8_bin;TRUNCATE examination_info;INSERT INTO examination_info(exam_id,tag,difficulty,duration,release_time) VALUES(9001, 'SQL', 'hard', 60, '2020-01-01 10:00:00'),(9002, '算法', 'easy', 60, '2020-01-01 10:00:00'),(9003, 'SQL', 'medium', 60, '2020-01-02 10:00:00'),(9004, '算法', 'hard', 80, '2020-01-01 10:00:00'); 答案replace into examination_info(id,exam_id,tag,difficulty,duration,release_time)values(null,9003,'SQL','hard',90,'2021-01-01 00:00:00');

SQL增删改操作实例分析

2 更新记录

SQL4 更新记录(一)

现有一张试卷信息表examination_info,表结构如下图所示:
SQL增删改操作实例分析

 题目描述请把examination_info表中tag为PYTHON的tag字段全部修改为Python。后台会通过执行'SELECT exam_id,tag,difficulty,duration,release_time FROM examination_info;'语句来对比结果。 建表语句drop table if EXISTS examination_info;CREATE TABLE IF NOT EXISTS examination_info (id int PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',exam_id int UNIQUE NOT NULL COMMENT '试卷ID',tag varchar(32) COMMENT '类别标签',difficulty varchar(8) COMMENT '难度',duration int NOT NULL COMMENT '时长',release_time datetime COMMENT '发布时间')CHARACTER SET utf8 COLLATE utf8_bin;TRUNCATE examination_info;INSERT INTO examination_info(exam_id,tag,difficulty,duration,release_time) VALUES(9001, 'SQL', 'hard', 60, '2020-01-01 10:00:00'),(9002, 'python', 'easy', 60, '2020-01-01 10:00:00'),(9003, 'Python', 'medium', 80, '2020-01-01 10:00:00'),(9004, 'PYTHON', 'hard', 80, '2020-01-01 10:00:00'); 答案UPDATE examination_infoset tag ='Python' WHERE tag='PYTHON';

SQL增删改操作实例分析

SQL5 更新记录(二)

作答记录表exam_record表结构
SQL增删改操作实例分析

 题目描述现有一张试卷作答记录表exam_record,其中包含多年来的用户作答试卷记录,submit_time为 完成时间请把exam_record表中2021年9月1日之前开始作答的未完成记录全部改为被动完成,即:将完成时间改为'2099-01-01 00:00:00',分数改为0。 建表语句drop table if EXISTS exam_record;CREATE TABLE IF NOT EXISTS exam_record (id int PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',uid int NOT NULL COMMENT '用户ID',exam_id int NOT NULL COMMENT '试卷ID',start_time datetime NOT NULL COMMENT '开始时间',submit_time datetime COMMENT '提交时间',score tinyint COMMENT '得分')CHARACTER SET utf8 COLLATE utf8_general_ci;INSERT INTO exam_record(uid,exam_id,start_time,submit_time,score) VALUES(1001, 9001, '2020-01-02 09:01:01', '2020-01-02 09:21:01', 80),(1001, 9002, '2021-09-01 09:01:01', '2021-09-01 09:21:01', 90),(1002, 9001, '2021-08-02 19:01:01', null, null),(1002, 9002, '2021-09-05 19:01:01', '2021-09-05 19:40:01', 89),(1003, 9001, '2021-09-02 12:01:01', null, null),(1003, 9002, '2021-09-01 12:01:01', null, null); 答案UPDATE exam_recordset submit_time='2099-01-01 00:00:00',    score=0WHERE start_time<'2021-09-01' and submit_time is null;

SQL增删改操作实例分析

3 删除记录

SQL6 删除记录(一)

作答记录表exam_record表结构,start_time是试卷开始时间,submit_time 是交卷,即结束时间
SQL增删改操作实例分析

 题目描述现有一张试卷作答记录表exam_record,其中包含多年来的用户作答试卷记录,start_time是试卷开始时间submit_time 是交卷,即结束时间请删除exam_record表中作答时间小于5分钟整且分数不及格(及格线为60分)的记录;后台会执行您的SQL,然后通过 SELECT * FROM exam_record; 语句来筛选出剩下的数据,与正确数据进行对比。 建表语句drop table if EXISTS exam_record;CREATE TABLE IF NOT EXISTS exam_record (id int PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',uid int NOT NULL COMMENT '用户ID',exam_id int NOT NULL COMMENT '试卷ID',start_time datetime NOT NULL COMMENT '开始时间',submit_time datetime COMMENT '提交时间',score tinyint COMMENT '得分')CHARACTER SET utf8 COLLATE utf8_general_ci;TRUNCATE exam_record;INSERT INTO exam_record(uid, exam_id, start_time, submit_time, score) VALUES(1001, 9001, '2020-01-01 22:11:12', '2020-01-01 23:16:12', 50),(1001, 9002, '2020-01-02 09:01:01', '2020-01-02 09:06:00', 58),(1002, 9001, '2021-05-02 10:01:01', '2021-05-02 10:05:58', 60),(1002, 9002, '2021-06-02 19:01:01', '2021-06-02 19:05:01', 54),(1003, 9001, '2021-09-05 19:01:01', '2021-09-05 19:40:01', 49),(1003, 9001, '2021-09-05 19:01:01', '2021-09-05 19:15:01', 70),(1003, 9001, '2021-09-06 19:01:01', '2021-09-06 19:05:01', 80),(1003, 9002, '2021-09-09 07:01:02', null, null); 答案delete from exam_recordwhere timestampdiff(minute,start_time,submit_time) < 5 and score < 60;

SQL增删改操作实例分析

SQL7 删除记录(二)

作答记录表exam_record结构如下:
SQL增删改操作实例分析

 题目描述现有一张试卷作答记录表exam_record,其中包含多年来的用户作答试卷记录,start_time是试卷开始时间submit_time 是交卷时间,即结束时间,如果未完成的话,则为空请删除exam_record表中未完成作答或作答时间小于5分钟整的记录中,开始作答时间较早的3条记录。后台会通过 SELECT * FROM exam_record 语句来对比结果。 建表语句drop table if EXISTS exam_record;CREATE TABLE IF NOT EXISTS exam_record (id int PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',uid int NOT NULL COMMENT '用户ID',exam_id int NOT NULL COMMENT '试卷ID',start_time datetime NOT NULL COMMENT '开始时间',submit_time datetime COMMENT '提交时间',score tinyint COMMENT '得分')CHARACTER SET utf8 COLLATE utf8_general_ci;TRUNCATE exam_record;INSERT INTO exam_record(uid, exam_id, start_time, submit_time, score) VALUES(1001, 9001, '2020-01-01 22:11:12', '2020-01-01 23:16:12', 50),(1001, 9002, '2020-01-02 09:01:01', '2020-01-02 09:06:00', 58),(1001, 9002, '2020-01-02 09:01:01', '2020-01-02 09:05:01', 58),(1002, 9001, '2021-05-02 10:01:01', '2021-05-02 10:06:58', 60),(1002, 9002, '2021-06-02 19:01:01', null, null),(1003, 9001, '2021-09-05 19:01:01', null, null),(1003, 9001, '2021-09-05 19:01:01', null, null),(1003, 9002, '2021-09-09 07:01:02', null, null); 答案delete from exam_recordwhere timestampdiff(minute, start_time, submit_time) < 5or submit_time is nullorder by start_timelimit 3;

SQL增删改操作实例分析

SQL8 删除记录(三)

试卷作答记录表exam_record表结构
SQL增删改操作实例分析

 题目描述现有一张试卷作答记录表exam_record,其中包含多年来的用户作答试卷记录,请删除exam_record表中所有记录,并重置自增主键。后台会通过SELECT table_rows, auto_increment FROM information_schema.tables WHERE table_name='exam_record'语句来对比输出结果 建表语句drop table if EXISTS exam_record;CREATE TABLE IF NOT EXISTS exam_record (id int PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',uid int NOT NULL COMMENT '用户ID',exam_id int NOT NULL COMMENT '试卷ID',start_time datetime NOT NULL COMMENT '开始时间',submit_time datetime COMMENT '提交时间',score tinyint COMMENT '得分')CHARACTER SET utf8 COLLATE utf8_general_ci;TRUNCATE exam_record;INSERT INTO exam_record(uid, exam_id, start_time, submit_time, score) VALUES(1001, 9001, '2020-01-01 22:11:12', '2020-01-01 23:16:12', 50),(1001, 9002, '2020-01-02 09:01:01', '2020-01-02 09:06:00', 58); 答案TRUNCATE table  exam_record;

SQL增删改操作实例分析

感谢各位的阅读,以上就是“SQL增删操作实例分析”的内容了,经过本文的学习后,相信大家对SQL增删改操作实例分析这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

文章标题:SQL增删改操作实例分析,发布者:亿速云,转载请注明出处:https://worktile.com/kb/p/27733

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
亿速云的头像亿速云认证作者
上一篇 2022年9月21日 上午12:10
下一篇 2022年9月21日 上午12:11

相关推荐

  • SpringBoot统一返回格式怎么实现

    1. 直接返回结果 先看一下最基本的例子,直接将结果原封不动返回: @Data@AllArgsConstructor@JsonIgnoreProperties(ignoreUnknown = true)public class TestVo { private static final long s…

    2022年8月31日
    68500
  • CDR最新版本里面图片排版如何调间距

    CDR最新版本里面图片排版调间距的方法: 名列前茅步,选中你需要排版的图片。 第二步,点击上方工具栏的“对象”按钮。 第三步,在下拉菜单中点击“对齐与分布” 第四步,点击右边的“对齐与分布”选项打开。 第五步,点击图示位置的“对象间距”在下方就可以手动调间距了。 关于“CDR最新版本里面图片排版如何…

    2022年9月24日
    84200
  • css样式中calc的含义是什么

    在css中,calc是计算的意思;calc可以理解为一个函数function,是calculate的缩写,用来指定一个元素的长度,calc可以给元素做计算,使用指定的单位值计算出长度值,语法为“元素{长度属性:calc(表达式)}”。 本教程操作环境:windows10系统、CSS3&&am…

    2022年9月15日
    78400
  • php判断数组中指定值是不是最后一个元素

    两种判断方法:1、利用end()函数和“===”运算符,获取数组最后一个元素的值,比较该元素值是否为指定值即可,语法“end($arr===”指定值”)”,如果相等则是,反之则不是。2、利用array_pop()函数和“===”运算符,语法“array_pop($arr===…

    2022年9月16日
    68700
  • 电脑黑白打印机打印图片底色黑如何解决

    解决方法 方法一: 1、首先在“Photoshop”中打开想要打印的图片。 2、打开后,点击左上角“图像”,选择“自动色调” 3、软件会自动为你调整背景色,如果还是觉得黑,可以继续调节。 4、继续点击“图像”,打开“调整”下的“色阶”选项。 5、打开后,按住图示位置的滑块,向左滑动。(根据预览情况自…

    2022年9月24日
    1.3K00
  • 怎么用vue实现动态路由

    1、什么是动态路由? 动态路由,动态即不是写死的,是可变的。我们可以根据自己不同的需求加载不同的路由,做到不同的实现及页面的渲染。动态的路由存储可分为两种,一种是将路由存储到前端。另一种则是将路由存储到数据库。动态路由的使用一般结合角色权限控制一起使用。 总结: 1)路由可变,不是写死的,动态加载 …

    2022年9月15日
    91800
  • mysql查询慢的因素有哪些

    数据库查询流程 我们先来看下,一条查询语句下来,会经历哪些流程。 比如我们有一张数据库表 CREATE TABLE `user` ( `id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT ‘主键’, `name` varchar(100) NOT…

    2022年9月2日
    63300
  • 知识库是什么

    知识库是关于产品、服务、部门或主题的自助式在线信息库。为了让大家更好的了解知识库是什么这个问题,下面我们将会围绕:1、企业知识库是什么;2、企业为什么需要知识库;3、知识库的好处有哪些;三点进行展开。 知识库中的数据可以来自任何地方。通常,精通相关主题的贡献者会给知识库增加或扩展内容。内容可以是从你…

    2022年3月18日
    72300
  • windows谷歌浏览器开发者模式如何打开

    谷歌浏览器开发者模式打开方法: 1、点击右上角的图标先。 2、随后选择更多工具中的“开发者工具”。 3、随后即可进入“开发者模式”。 4、点击上方的选项可以设置开发者工具的位置。 关于“windows谷歌浏览器开发者模式如何打开”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“windows…

    2022年9月8日
    3.4K00
  • Thinkphp5.0对数据库的操作方法有哪些

    基本使用 查询操作 Db::query(‘select * from think_user where id=?’,[8]); 写入操作 Db::execute(‘insert into think_user (id, name) values (?, ?)’,[8,’thinkphp’]); 查询…

    2022年9月26日
    60000
注册PingCode 在线客服
站长微信
站长微信
电话联系

400-800-1024

工作日9:30-21:00在线

分享本页
返回顶部