当前位置: 首页 > 编程笔记 >

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

陈季
2023-03-14
本文向大家介绍Mysql数据库之常用sql语句进阶与总结,包括了Mysql数据库之常用sql语句进阶与总结的使用技巧和注意事项,需要的朋友参考一下

本文实例讲述了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数据库计有所帮助。

 类似资料:
  • 主要内容:1 SHOW ENGINES,2 SHOW PROCESSLIST,3 SHOW STATUS LIKE ‘InnoDB_row_lock%’,4 SHOW ENGINE INNODB STATUS,5 SHOW INDEXS,6 ALTER TABLE xx ENGINE = INNODB,7 ANALYZE TABLE常见MySQL数据库优化的sql语句。 1 SHOW ENGINES 查看执行引擎以及默认引擎。 2 SHOW PROCESSLIST SHOW PROCESSLIS

  • 本文向大家介绍Mysql数据库之sql基本语句小结,包括了Mysql数据库之sql基本语句小结的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Mysql数据库之sql基本语句。分享给大家供大家参考,具体如下: SQL基本语句 1.登录退出及快捷键: (1)快捷键: ————快速回到行首 ctrl + a ————回到行末 ctrl + e ————清屏 ctrl + l ————结束 ct

  • 本文向大家介绍MySql数据库之alter表的SQL语句集合,包括了MySql数据库之alter表的SQL语句集合的使用技巧和注意事项,需要的朋友参考一下 mysql之alter表的SQL语句集合,包括增加、修改、删除字段,重命名表,添加、删除主键等。 1:删除列 ALTER TABLE 【表名字】 DROP 【列名称】 2:增加列 ALTER TABLE 【表名字】 ADD 【列名称】 INT

  • CRUD CREATE TABLE CREATE TABLE `user` ( `id` INT AUTO_INCREMENT, `name` VARCHAR (20), PRIMARY KEY (`id`) ); VARCHAR记得指定长度。 UPDATE UPDATE 表名称 SET 列名称 = 新值 WHERE 列名称 = 某值 INSERT INSERT INTO 表名称 VA

  • 本文向大家介绍Java异常处理之try...catch...语句的使用进阶,包括了Java异常处理之try...catch...语句的使用进阶的使用技巧和注意事项,需要的朋友参考一下 try就像一个网,把try{}里面的代码所抛出的异常都网住,然后把异常交给catch{}里面的代码去处理。最后执行finally之中的代码。无论try中代码有没有异常,也无论catch是否将异常捕获到,finally

  • 在 Django 中有两种操作 MySQL 数据库的方式,一种是使用原生的 SQL 语句操作 MySQL,另一种方式就是使用 Django 内置的 ORM 模型完成数据库的增删改查操作。后者是 Django 框架的一个的核心模块,它让开发者对数据库的操作更友好和优雅。 1. python 操作 MySQL 数据库 1.1 Python DB-API 在没有 Python DB-API 之前,各数据