一、单表查询语法

 select distinct  字段1,字段2,... from  库名.表名
where 条件
group by 字段
having 筛选条件
order by 字段
limit 限制显示条数

二、关键字执行优先级

from > where >  group by > having > select > distinct > order by > limit

执行步骤:

1、from 找到表

2、 拿着where指定的约束条件,去表中取一条条记录

3、将取出的记录按group by 分组,如果没有group by 则整体为一组

4、将分组结束进行having条件筛选

5、执行select

6、distinct 去重

7、将结果按order by 排序

8、limit限制显示条数

三、简单查询

select * from employee;  #查询表employee 中所有信息

select name,salary from employee;  #查询表employee 中姓名,工资

#去重
select distinct post from employee; #查询post字段信息并去重 #通过四则运算查询
select salary*12 from employee; #查询工资乘以12 #自定义显示格式
select concat("姓名: ",name," 年薪: ", salary*12) as gongzibiao from employee; # 表头和数据都是自己定义的格式
#concat()用于连接字符串 concat_ws() 将第一个参数作为分隔符进行字符串拼接

四、where 条件

where 不能使用聚合函数

where语句可以使用的有;

1、比较运算符: = >  <  >=   <=  !=

2、逻辑运算 and     or      not   ,在多个条件中可以直接使用

3、between  a   and  b

4、in(x,  y,  z)

5、like 模糊匹配  %表示匹配一个字符,_表示匹配一个字符

#单条件查询
select name from employee where post ='sale'; #多条件查询
select name from employee where post='sale' and asalary >1000; #between and 关键字
select name from employee where salary between 1000 and 20000; # is 关键字 (用于判断是否为null)
select post from employee where post_comment is NULL; # in 关键字
select name from employee where salary in(3000,4000,8000); #like 关键字
select * from employee where name like"al%" ; # %表示匹配所有字符
select * from employee where name like"al_" ; # _表示匹配任意一个字符

五、分组group by

大前提:

分组发生字where之后,即分组是基于where之后得到的记录而进行的。

可以按照任意字段分组,但是分组完毕后,比如group by post,只能查看post字段,如果想查看

组内信息,需要借助于聚合函数。

聚合函数:

聚合函数聚合的是组的内容,如没有分组,则默认是一组

group_concat()  #字符串拼接
select group_concat(name) from meployee group by post; count() #统计个数
select count(*) from employee; max() #最大值
select max(salary) from employee ; min() #最小值
select min(salary) from employee; avg() #平均数
select avg(salary) from employee; sum() #总数
select sum(salary) from employee;

练习:

#统计各部门年龄在30岁以上员工的平均工资

select post ,avg(salary) from employee where age>=30 group by post

六、having 过滤

having的语法格式和where是一模一样的,只不过having是在分组之后进行的进一步的过滤,where不能使用聚合函数,having是可以使用聚合函数的
#!!!执行优先级从高到低:where > group by > having
#1. Where 发生在分组group by之前,因而Where中可以有任意字段,但是绝对不能使用聚合函数。 #2. Having发生在分组group by之后,因而Having中可以使用分组的字段,无法直接取到其他字段,having是可以使用聚合函数

#练习:

统计各部门年龄在30岁及以上员工的平均薪资,并且保留平均工资大于10000的部门

select  post, avg(salary)  from  employee  where  age>=30  group by  post  having avg(salary)>10000;

七、order by 排序

select  *  from   employee   order by   salary;           #按工资排序  默认是升序

select  *  from   employee   order by   salary asc;     # asc 表示升序

select  *  from   employee   order by   salary desc;   # desc 表示降序

select  *  from   employee   order by   age, salary desc    #先按年龄升序 再按工资降序排列

八、limit 限制记录条数 

可以应用于分页显示

# 练习

select  *  from   employee   order by  salary desc  limit 3;     #取三条数据

select   *  from  employee  order by   salary desc  limit 0,5 ;  #从索引0开始,取五条数据,默认第一条数据索引是0

select   *  from  employee  order by   salary desc  limit 5,5 ;   #从索引5开始,取五条数据

九、使用正则表达式

格式:

select  * from  employee where name regexp 正则表达式;

# 练习

select * from employee where name regexp ' ^jin.*[g|n]$ ' ;  #查询所有员工中名字是jin开头,n或g结尾的员工信息

####

对字符串的匹配方式:

1、精确匹配     where name ='dasab' ;

2、模糊匹配    where name like 'da%' ;

3、正则表达式   where name regexp 'b$' ;

day037 mysql之单表查询的更多相关文章

  1. MySQL之单表查询 一 单表查询的语法 二 关键字的执行优先级(重点) 三 简单查询 四 WHERE约束 五 分组查询:GROUP BY 六 HAVING过滤 七 查询排序:ORDER BY 八 限制查询的记录数:LIMIT 九 使用正则表达式查询

    MySQL之单表查询 阅读目录 一 单表查询的语法 二 关键字的执行优先级(重点) 三 简单查询 四 WHERE约束 五 分组查询:GROUP BY 六 HAVING过滤 七 查询排序:ORDER B ...

  2. Mariadb/MySQL数据库单表查询基本操作及DML语句

    Mariadb/MySQL数据库单表查询基本操作及DML语句 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一数据库及表相关概述 1>.数据库操作 创建数据库: CREATE ...

  3. day 38 MySQL之单表查询

    MySQL之单表查询   阅读目录 一 单表查询的语法 二 关键字的执行优先级(重点) 三 简单查询 四 WHERE约束 五 分组查询:GROUP BY 六 HAVING过滤 七 查询排序:ORDER ...

  4. Mysql数据库单表查询

    1.单表查询语法 #查询数据的本质:mysql会到你本地的硬盘上找到对应的文件,然后打开文件,按照你的查询条件来找出你需要的数据.下面是完整的一个单表查询的语法 select * from,这个sel ...

  5. MySQL之单表查询、多表查询

    一.单表查询: 单个表的查询方法及语法顺序需要通过实际例子来熟悉 先将表数据创建下: mysql> create database singe_t1; # 建个数据库singe_t1 Query ...

  6. MySQL 的单表查询

    单表查询 语法: 一.单表查询的语法 SELECT 字段1,字段2 ,...FROM 表名 WHERE 条件 GROUP BY field HAVING 筛选 ORDER BY filed LIMIT ...

  7. 四 mysql之单表查询

    目录 一 单表查询的语法 二 关键字的执行优先级(重点) 三 简单查询 四 WHERE约束 五 分组查询:GROUP BY 1. 什么是分组?为什么要分组? 2. ONLY_FULL_GROUP_BY ...

  8. mysql(单表查询,多表查询,MySQl创建用户和授权,可视化工具Navicat的使用)

    单表查询 语法: 一.单表查询的语法 SELECT 字段1,字段2... FROM 表名 WHERE 条件 GROUP BY field HAVING 筛选 ORDER BY field LIMIT ...

  9. MySQL的单表查询

    单表查询 单表查询语法: select distinct 字段1,字段2... from 表名 where 条件 group by field having筛选 order by 关键字执行的优先级: ...

随机推荐

  1. Mock Server 入门(一)

    Mock Server 使用场景 1.开发过程中依赖一些接口,而这些接口可能有一下情况: 1)接口搭建环境比较困难:例如支付宝的支付接口,需要授权等等准备好才能进行调试 2)接口暂时还未实现时:可以便 ...

  2. 更多more 123123循环

  3. python中列表中元素的增删改查

    增: append : 默认添加到列表的最后一个位置 insert : 可以通过下标添加到列表的任意位置 extend: a.extend[b] --将b列表的元素全加入到列表b中 删; remove ...

  4. 关于.net里面的静态html页面和接口组合使用的网站

    在网站的根目录下,主要有三部分组成.①接口里面的bin文件夹②接口③html里面的页面. html里面有ajax请求接口的js代码.另外接口里面的web.config不需要拷贝到网站根目录去. 如下截 ...

  5. C# 获取 mp3文件信息【包括:文件大小、歌曲长度、歌手、专辑】

    C# 获取 mp3文件信息[包括:文件大小.歌曲长度.歌手.专辑] 第一种方式:[代码已验证] // http://bbs.csdn.net/topics/390392612   string fil ...

  6. CentOS 7 开机延迟解决办法

    遇到这种情况 , 开机延迟 ,  可以用下面的办法来查看 , 寻找到问题的源头 , 来看看到的是怎么回事 [root@DaMoWang ~]# dmesg |grep udev #显示系统的启动信息 ...

  7. 【Spark-core学习之一】 Spark初识

    环境 虚拟机:VMware 10 Linux版本:CentOS-6.5-x86_64 客户端:Xshell4 FTP:Xftp4 jdk1.8 scala-2.10.4(依赖jdk1.8) spark ...

  8. vscode格式化代码插件Beautify

    vscode格式化代码安装 VsCode 格式化代码插件搜索并安装 Beautify 格式化代码插件使用:打开要格式化的文件 —> F1 —> Beautify file —> 选择 ...

  9. [autocomplete]如果条目末尾有空格,MustMatch不起作用

    如果mustMatch被激活,我们发现,当条目最后包含一个空格时,一旦我们从列表中选择值,它将被拒绝.我们已经发现了这个问题,它在搜索事件中:在第184行,您修剪了输入的值: $.each(trimW ...

  10. <转>jmeter(二十三)分布式测试

    本博客转载自:http://www.cnblogs.com/imyalost/category/846346.html 个人感觉不错,对jmeter讲解非常详细,担心以后找不到了,所以转发出来,留着慢 ...