对课上SQL使用技巧示例补充

一:用UPDATE批量更新score is null的记录

通过 RAND() 生成符合要求的成绩,百万级数据几秒内就能完成,完全不用手动操作。

关键:必须加 WHERE score is null,只更新空值,不覆盖已有成绩

方案1:快速填随机数

sql 复制代码
UPDATE t_course_selection
SET score = ROUND(RAND() * 100, 1)  -- 保留1位小数,生成0.0~100.0的随机数
--如果整数
-- SET score = FLOOR(RAND() * 101)  -- 生成0~100的整数(RAND()生成0~1随机数,*101后向下取整)
WHERE score IS NULL;

效果:

方案2:模拟真实学生成绩分布

sql 复制代码
UPDATE t_course_selection
SET score = CASE
    -- 5%概率:0-60分(不及格)
    WHEN RAND() < 0.05 THEN ROUND(RAND() * 60, 1)
    -- 80%概率:60-90分(中等,大部分学生)
    WHEN RAND() < 0.85 THEN ROUND(60 + RAND() * 30, 1)
    -- 15%概率:90-100分(高分段)
    ELSE ROUND(90 + RAND() * 10, 1)
END
WHERE score IS NULL;

二:一键清空所有 score 成绩(保留字段结构,所有记录设为 NULL)

1. 【必做】先备份数据(防止误操作不可逆)

sql 复制代码
CREATE TABLE t_course_selection_bak AS SELECT * FROM t_course_selection;

2.批量清空所有 score 成绩

sql 复制代码
UPDATE t_course_selection SET score = NULL;

执行成功显示为null

3.【验证】确认清空成功

sql 复制代码
SELECT COUNT(*) AS 总记录数, COUNT(score) AS 非空成绩数 FROM t_course_selection;

三:COUNT查询数据是否存在优化

比如我想判断课号是'A1LSC27'课程是否存在

方案一:课程开设的数量

SELECT COUNT(*) FROM t_courseinfo WHERE CourseNumber = 'A1LSC27'

技能证书课程有18个老师开设,但是只是想看看有没有这门课,可以用

方案二:课程是否开设

sql 复制代码
--不读实际数剧 只返回常量 1,不访问列存储;最多返回 1 条记录(找到即停)
SELECT 1 FROM t_courseinfo WHERE CourseNumber = 'A1LSC27' LIMIT 1

四、小表驱动大表

"从学生主表中,查出所有在特殊学生名单里的人" ------ 相当于用一份"小名单"去大表中"挑人"。SQL如下:

sql 复制代码
SELECT * FROM student WHERE id 
IN (SELECT stu_id FROM special_student)

special_student 表通常存储特殊标记的学生(如:贫困生、特长生、留学生、获奖学生等)

内层子查询(先执行):SELECT stu_id FROM special_student,子查询语句的数据量很少,所以查询速度会很快!

|------|-------------------------------------|
| 作用 | 从 special_student 表中提取所有学生的 ID |
| 返回结果 | 一组 stu_id 值,例如:[1, 3, 5, 8, 10] |

外层主查询

|-------------------|----------------------------|
| SELECT * | 返回 student 表的所有列(完整学生信息) |
| WHERE id IN (...) | 筛选条件:只保留 id 在子查询结果中的记录 |

五、字符串字段优化

加引号 = 按字符串匹配 → 走索引 = 飞快

不加引号 = 隐式类型转换 → 索引失效 = 全表扫描 = 很慢

  • number = 200000929(不加引号)→ 数据库要把每一行的 number 都转成数字 再对比→ 索引失效,必须扫完整张百万表→ 慢!

  • number = '200000929'(加引号)→ 直接字符串匹配索引直接命中

  • 字段是 varchar/char → 值必须加引号
  • 字段是 int/bigint → 值不加引号
  • 类型不匹配 → 索引必失效 → 查询必变慢
相关推荐
m0_74065322几秒前
Redis如何查询附近的人_利用GEORADIUS指令进行Geo范围搜索
jvm·数据库·python
Jetev1 分钟前
宝塔面板如何实现网站重定向_配置301永久跳转与域名更换
jvm·数据库·python
精益数智小屋3 分钟前
物料管理系统软件有什么用?物料管理系统软件功能详解
大数据·数据库·人工智能·自动化·精益工程
2401_833033623 分钟前
c++如何解析二进制协议中的可选字段与默认值读取逻辑实现【实战】
jvm·数据库·python
Francek Chen4 分钟前
【大数据存储与管理】云数据库:02 云数据库产品
大数据·数据库·分布式·云计算·云数据库
ChoSeitaku5 分钟前
13.MySQL使用C语言链接及图形化界面
数据库·mysql
倔强的石头1067 分钟前
【Linux 指南】文件系统系列(二):核心抽象层 —— 块 、分区 、inode 从原理到实操
linux·服务器·数据库
m0_5913647310 分钟前
CSS 背景图滑动切换:纯 CSS 实现右进左出轮播效果
jvm·数据库·python
2401_8242226910 分钟前
Python测试代码如何实现自解释_使用pytest描述性命名规范
jvm·数据库·python
woxihuan12345613 分钟前
MySQL 中高效存储与查询时间数据的最佳实践
jvm·数据库·python