MySQL随笔回顾

  • 查询不重复的记录

    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 ALLUNION 不同的是会显示出所有的值,
    SELECT 字段 FROM A表 UNION ALL SELECT 字段 FROM B表 ORDER BY 字段;
    显示所有值。
    
    带有 WHERESQL 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'字符串的所有数据
    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值