时间:2021-07-01 10:21:17 帮助过:17人阅读
select @@global.sql_mode;
select 字段,字段 from 表名 where 条件 group by 分组 having 筛选 order by 排序 limit 限制
比较运算 > < >= <= <> !=
值在 80-100 之间 包含 80 100
between 80 and 100;
值 是 80,90,100 的
in(80,90,100)
相反的
not in(80,90,100)
模糊查询
like '张%' % 通配符 包含一个或多个 // 查询姓张的人
like '程咬_' _ 包含一个字符
经过分组之后只能查看当前字段,如果想查看组内信息需要借助于聚合函数
聚合函数
max() 求最大值
min() 求最小值
avg() 求平均值
sum() 求和
count() 求总个数
拼接分组后的内容
group_concat(name)
order by age ASC; 默认升序
order by age desc; 降序排列
限制查询次数
limit 0, 5 ; 0 表示起始索引 5 表示显示条数
交叉连接
select * from table_1,table_2; 生成笛卡尔积
内连接
只获取匹配的数据
select 表名.列名, 表名.列名 from 表1 inner join 表2 on 条件(表1.列 = 表2.列);
左连接
只显示左表所有的记录
select 表名.列名, 表名.列名 from 表1 left join 表2 on 条件(表1.列 = 表2.列);
右链接
只显示 右 表所有的记录
select 表名.列名, 表名.列名 from 表1 right join 表2 on 条件(表1.列 = 表2.列);
全外连接
左连接 union 右链接
in ; not in ; any ; all; exists; not exists;
Mysql 关键字的优先级 分组 多表联查
标签:lob mod 去重 左连接 聚合函数 拼接 sql_mod sele exists