Mysql数据库之常用sql语句进阶与总结

 更新时间:2019年11月27日 11:18:58   作者:HMMHMH  
这篇文章主要介绍了Mysql数据库之常用sql语句,总结分析了MySQL数据库常用的查询、条件查询、排序、连接查询、子查询等相关操作技巧,需要的朋友可以参考下

本文实例讲述了Mysql数据库之常用sql语句。分享给大家供大家参考,具体如下:

前面讲述了Mysql sql基本语句。这里继续总结一下SQL语句的进阶内容。

SQL语句进阶

1.查询字段:

————查询所有字段

select * from 表名;

————查询指定字段

select 字段名,字段名… from 表名;

————多数据表连接查询时

select 表名.字段名,表名.字段名 … from 表名;

————使用as给表起别名

select 表别名.字段名 from 表名 as 表别名;

————消除重复行(distinct)

select distinct 字段名 from 表名;

2.条件查询:

————比较运算符(>,<,=,!=)

select * from 表名 where age >18; 

(<>也表示!=)

————逻辑运算符(and,or,not)

select * from 表名 where age>18 and age<28;(18

3.排序:

————升序 

select * from 表名 order by asc;(默认为升需asc,可以省略asc)

————降序

select * from 表名 order by desc;

4.聚合函数:

————总数count

select count(*) from 表名;

————最大值max

select max(age) from 表名;

————最小值min

select min(age) from 表名;

————求和sum

select sum(age) from 表名;

————求平均值avg

select avg(age) from 表名;

————四舍五入保留小数round

select round(avg(age),2) from 表名;(查询平均年龄,四舍五入保留两位小数)

5.分组(重点):

————分组group by

select gender count(*) from 表名 group by gender;(按性别分组,查询性别与人数)

————分组查询(聚合函数,group_concat(),having)

select gender avg(age) from 表名 group by gender;(查询每种性别的平均年龄)

select gender group_concat(name) from 表名 group by gender;(group_concat(name)查看分组姓名)

select gender count() from 表名 group by gender having count()>2(having类似where,过滤条件,having只能用于group by,where用于表数据)

————汇总with rollup

select gender count(*) from 表名 group by gender with rollup;(最后新增一行,显示汇总结果)

6.分页:

————查询前n个数据(limit一般写在最好,表示对操作后的数据显示)

select * from 表名 limit n;

————分页显示

select * from 表名 limit 0,3;(每页显示3个,第1个页面) 
select * from 表名 limit 3,3;(每页显示3个,第2个页面) 
select * from 表名 limit 6,3;(每页显示3个,第3个页面)

7.连接查询(重点):

————inner join…on(内连接)

select * from 表名1 inner join 表名2 on 表名1.cls_id=表名2.id;(将表1cls.id和表2id相同的连接在一起) 
select 表名1.字段名1,表名2.字段名.2 from 表名1 inner jion 表明2 on 条件;

————left/right join…on(左/右/外连接)

select * from 表名1 left/right join 表名2 on 表名1.cls_id=表名2.id;(查询的结果为两个表匹配到的数据和左表特有的数据,对于左/右表中不存在的数据使用null填充)

8.子查询:

————标量子查询(子查询返回的结果是一个数据(一行一列))

select * from 表名 where age > (select avg(age) from 表名);

————列子查询(返回的结果是一列(一列多行))

select name from 表名1 where id in (select cls_id from 表名2);

————行子查询(返回的结果是一行(一行多列))

select * from 表名 where (height,age) = (select max(height),max(age) from 表名);

更多关于MySQL相关内容感兴趣的读者可查看本站专题:《MySQL查询技巧大全》、《MySQL常用函数大汇总》、《MySQL日志操作技巧大全》、《MySQL事务操作技巧汇总》、《MySQL存储过程技巧大全》及《MySQL数据库锁相关技巧汇总

希望本文所述对大家MySQL数据库计有所帮助。

相关文章

  • mysql数据库之索引详细介绍

    mysql数据库之索引详细介绍

    大家好,本篇文章主要讲的是mysql数据库之索引详细介绍,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览
    2021-12-12
  • 一文说透什么是MySQL的预编译

    一文说透什么是MySQL的预编译

    这篇文章主要介绍了一文说透什么是MySQL的预编译,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-11-11
  • MySQL数据库大小写敏感的问题

    MySQL数据库大小写敏感的问题

    今天小编就为大家分享一篇关于MySQL数据库大小写敏感的问题,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-03-03
  • MySQL redo死锁问题排查及解决过程分析

    MySQL redo死锁问题排查及解决过程分析

    被告知在多实例场景下 MySQL Server hang 住,无法测试下去,原生版本不存在这个问题,而新版本上出现了这个问题,不禁心头一颤,心中不禁感到奇怪,还好现场环境还在,为排查问题提供了一个好的环境,随即便投入到紧张的问题排查过程当中
    2016-10-10
  • Mysql及Navicat中设置字段自动填充当前时间及修改时间实现

    Mysql及Navicat中设置字段自动填充当前时间及修改时间实现

    这篇文章主要给大家介绍了关于Mysql及Navicat中设置字段自动填充当前时间及修改时间实现的相关资料,文中通过实例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2023-07-07
  • 一文带你了解MySQL中的锁机制

    一文带你了解MySQL中的锁机制

    锁是计算机协调多个进程或线程并发访问某一资源的机制(避免争抢)。本文就来通过几个简单的实力为大家详细讲讲MySQL中的锁机制吧
    2023-02-02
  • Mysql数据库清理binlog日志命令详解

    Mysql数据库清理binlog日志命令详解

    这篇文章主要给大家介绍了Mysql数据库清理binlog日志命令的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Mysql具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-09-09
  • 与MSSQL对比学习MYSQL的心得(一)--基本语法

    与MSSQL对比学习MYSQL的心得(一)--基本语法

    最开始接触的数据库为MSSQL,不过最近项目需求,仔细学习了下MYSQL,下面就对比MSSQL,把MYSQL的学习心得分享给大家
    2014-06-06
  • MySQL中的运算符使用实例展示

    MySQL中的运算符使用实例展示

    请问,什么是最好的参考文档,我的答案是:真实可行的样例语句。
    2010-12-12
  • mysql中判断记录是否存在方法比较

    mysql中判断记录是否存在方法比较

    把数据写入到数据库的时,常常会碰到先要检测要插入的记录是否存在,然后决定是否要写入。
    2011-07-07

最新评论