-
查询不重复的记录
select distinct 字段 from 表名;
1.distinct必须放在最开头
2.distinct只能使用需要去重的字段进行操作。 ----也就是说我sidtinct了name,age两个字段,我后面想根据id进行排序,是不可以的,因为只能name,age两个字段进行操作.
3.distinct去重多个字段时,含义是:几个字段 同时重复 时才会被 过滤。 -
查询和排序
select * from 表名 [where 条件] [ order by field1 [desc/asc],field2 [desc/asc]... ];
eg:select *from student order by age desc;//查询学生表并按年龄降序排列。 desc代表降序,asc代表升序
1.desc 降序排列,asc 升序排列
2.order by 后面可以跟多个不同的排序字段,每个排序字段都可以有不同的排序顺序。
3.如果排序字段的值一样,则相同的字段按照第二个排序字段进行排序。
4.如果只有一个排序字段,则字段相同的记录将会无序排列。 -
限制
select ... [limit 起始偏移量,行数];
默认情况下起始偏移量为0
-
聚合查询
select 字段 聚合函数 from 表名 [where 条件] [group by field1,field2...] [with rollup] [having 条件];
1.常用的聚合函数有sum(求和)、count(*)(记录数)、 max(最大值)、min(最小值)
2.group by关键字 表示要进行分类聚合的字段。比如要按照部门分类统计员工数量,部门就应该写在group by 后面。
3.with rollup 是可选语法,表明是否对分类聚合后的结果进行再汇总
4.having 关键字表示对分类后的结果再进行条件过滤。 -
表连接
表连接分为内连接和外连接,主要区别为,内连接只会选中表内互相匹配的记录,外连接会选中其他不匹配的记录,其中外连接包括左连接和右连接,左连接包含左右左表中的记录,右连接表示包含所有右表中的记录。这是一个左连接的SQL语句 select 左表字段, 右表字段 from 左表 left join 右表 on 左表字段=右表字段 SELECT a.runoob_id, a.runoob_author, b.runoob_count FROM runoob_tbl a INNER JOIN tcount_tbl b ON a.runoob_author = b.runoob_author; 查询runoob_tbl 表和tcount_tbl 表中 runoob_author 想对应的字段。
-
子查询
select * from emp where deptno in(select deptno from dept)
-
分组查询
分组查询一般伴随着常用函数sum count svg等使用 SELECT 字段, COUNT(*) FROM 表名 GROUP BY 字段; 将数据表按照指定的字段进行分组,需要注意的是:group by 只能分组前面已经出现的字段 WITH ROLLUP WITH ROLLUP 可以实现在分组统计数据基础上再进行相同的统计(SUM,AVG,COUNT…)。 SELECT 字段, SUM(字段) as 别名 FROM 表名 GROUP BY 字段WITH ROLLUP; 讲数据表按指定字段进行分组,在统计某个字段的总和
-
UNION 操作符
UNION 操作符用于连接两个以上的 SELECT 语句的结果组合到一个结果集合中。多个 SELECT 语句会删除重复的数据。 SELECT 字段 FROM A表 UNION SELECT 字段 FROM B表 ORDER BY 字段; union 会删除重复的值,如果出现多次,则会自动忽略,
UNION ALL UNION ALL 与UNION 不同的是会显示出所有的值, SELECT 字段 FROM A表 UNION ALL SELECT 字段 FROM B表 ORDER BY 字段; 显示所有值。
带有 WHERE 的 SQL UNION ALL 带有where的也会显示所有的值,和平时使用的where一致。
-
ORDER BY 排序
你可以使用任何字段来作为排序的条件,从而返回排序后的查询结果。
你可以设定多个字段来排序。
你可以使用 ASC 或 DESC 关键字来设置查询结果是按升序或降序排列。 默认情况下,它是按升序排列。
你可以添加 WHERE…LIKE 子句来设置条件。SELECT * from 表名 ORDER BY 字段 ASC; DESC 为降序,ASC为升序, 没啥可说的
-
NULL值
IS NULL 如果当前值的null 返回true IS NOT NULL 如果当前值不为null 返回true 注意: NULL值 不可以用 = 或者 != 错误写法:SELECT * FROM 表名 WHERE 字段 = NULL; SELECT * FROM runoob_test_tbl WHERE runoob_count IS NULL;
-
正则
REGEXP SELECT name FROM person_tbl WHERE name REGEXP '^st'; 查找name字段中以'st'为开头的所有数据 SELECT name FROM person_tbl WHERE name REGEXP 'ok$'; 查找name字段中以'ok'为结尾的所有数据 SELECT name FROM person_tbl WHERE name REGEXP 'mar'; 查找name字段中包含'mar'字符串的所有数据
MySQL随笔回顾
最新推荐文章于 2023-11-27 21:58:32 发布