-
SQL中的if-else判断语句
众所周知,if-else判断在任何地方都很有用,在SQL语句中,"CASE WHEN … THEN … ELSE … END"语句可以用在增删改查各类语句中。
-
修改判断
给个情景:妇女节大回馈,2020年注册的新用户,所有成年女性账号送10元红包,其他用户送5元红包,自动充值。
示例语句如下:
-- 送红包语句 UPDATE users_info u SET u.balance = CASE WHEN u.sex ='女' and u.age > 18 THEN u.balance + 10 ELSE u.balance + 5 end WHERE u.create_time >= '2020-01-01'
-
查询判断
有个学生高考分数表,需要将等级列出来,650分以上是重点大学,600-650是一本,500-600分是二本,400-500是三本,400以下大专;
原测试数据如下:
查询语句:
SELECT *,case when total_score >= 650 THEN '重点大学' when total_score >= 600 and total_score <650 THEN '一本' when total_score >= 500 and total_score <600 THEN '二本' when total_score >= 400 and total_score <500 THEN '三本' else '大专' end as status_student from student_score;
-
指定数据快照或备份
如果想要对一个表进行快照,即复制一份当前表的数据到一个新表,可以结合CREATE TABLE和SELECT:
-- 对class_id=1(一班)的记录进行快照,并存储为新表students_of_class1: CREATE TABLE students_of_class1 SELECT * FROM student WHERE class_id=1;
新创建的表结构和SELECT使用的表结构完全一致。