MySQL做题笔记

1 null

null不参与比较,是否等于null要单独列出

不能使用 = null , 应该使用 is null is not null

sql 复制代码
select name 
from Customer 
where referee_id <> 2 or  referee_id is null;

2 distinct

显示不重复的数据

3 char_length()

计算字符串长度

4 left join

包含左侧的所有行,即使右侧没有对应数据

5 cross join

交叉连接

join 等价于inner join,不用关联条件的join等价于cross join.

6 datediff()

计算日期差值

7 max()

8 avg()

9 round(x,2)

x保留两位小数

10 ifnull(a,b)

ifnull(a,b) a如果为null,就返回b

avg(action = 'confirmed') :

AVG(判断条件) = "判断条件"为True的记录数 / 总记录数

if(判断条件,1,0) : 满足返回1,不满足返回0

11 <> 替代 !=

12 mod(a,b) a%b

13 sum(a*b)

每一行分别计算a*b,然后计算和

14 count()

select count(1) from users : 统计user中非null的行数

select count(distinct player_id ) from activity:统计player_id不重复的行数

count()作用:

统计符合条件的记录中,指定的条件不为null的数量

效率:

count(*)>count(1)>count(主键字段)>count(字段)

如果是count(1):

1永远满足,结果是总行数

count(if(state = 'approved', 1, null)):

count()中也可包含表达式,统计行数时,不满足条件要设为null,而不是0

15 if()

if(rating < 3, 1, 0)

sum(if(rating < 3, 1, 0)) 统计所有rating<3的行数

16 date_format()

date_format(date, '%Y-%m') 格式化日期,按照2018-02形式显示

相关推荐
左左右右左右摇晃1 分钟前
K8s笔记整理
笔记
Rhystt12 分钟前
斑马问题|离散数学|爱因斯坦的谜题你能解开吗?
经验分享·笔记
ouliten20 分钟前
C++笔记:std::numeric_limits
c++·笔记
承渊政道22 分钟前
C++学习之旅【C++伸展树介绍以及红黑树的实现】
开发语言·c++·笔记·b树·学习·visual studio
m0_6356474829 分钟前
Qt开发与MySQL数据库教程(二)——MySQL常用命令以及示例
java·开发语言·数据库·mysql
予枫的编程笔记30 分钟前
【面试专栏 | MySQL】MySQL事务底层实现拆解:Redo/Undo Log+锁+MVCC,一文讲透ACID
mysql·redo log·mvcc·数据库锁·undo log·事务原理·面试干货
程序员榴莲33 分钟前
MySQL (一):MySQL的安装与启动
数据库·mysql
IT界的老黄牛1 小时前
【IT老齐230 笔记 + 思考】金融业容灾方案“两地三中心“是什么意思?
数据库·笔记·架构
testresultstomorrow1 小时前
GitHub 代码上传与故障排除实战指南
经验分享·笔记·开源·github
prog_61031 小时前
【笔记】用cursor手搓cursor(一)
人工智能·笔记·agent