单表查询语法:

SELECT 字段1,字段2... FROM 表名
WHERE 条件
GROUP BY field
HAVING 筛选
ORDER BY field
LIMIT 限制条数

关键字的执行顺序:

这个是非常重要的,不了解以后会有很多坑。

1.form        找到表:from

2.where        拿着where指定的约束条件,去文件/表中取出一条条记录

3.group by    将取出的一条条记录进行分组group by,如果没有group by,则整体作为一组

4.having        将分组的结果进行having过滤

5.select        执行select

6.distinct        去重

7.order by     将结果按条件排序:order by

8.limit        限制结果的显示条数

准备数据源

建立一个名为student的学生表,下面是他们的字段名及字段类型表。

create table student(
id int not null unique auto_increment,
name varchar(20) not null,
sex enum('male','female') not null default 'male',
age int(3) unsigned not null default 28,
birthday date not null,
class_id int
);

建表代码

效果图:

insert into student(name,sex,age,birthday,class_id) values
('成龙','male',48,'',1),
('歪歪','female',48,'',2),
('丫丫','female',38,'',2),
('丁丁','female',18,'',2),
('星星','female',18,'',2),
('格格','female',28,'',2),
('张野','male',28,'',3),
('程咬金','male',18,'',3),
('程咬银','female',18,'',3),
('程咬铜','male',18,'',3),
('程咬铁','female',18,'',3);

数据代码

效果图:

普通查询

# 简单查询
select * from student; # 查询表中所有记录
select name, age from student; # 查询表中的name和age字段 # 去重查询
select distinct age from student; # 去重查询表中所有人的年龄 # 查询加四则运算
select name, age-1 from student; # 这样查询出来的为两个字段,字段名分别为name和age-1,age-1字段中值为原始年龄-1
select name, age-1 as 年龄减一 from student; # 查询同上,默认的age-1字段名改成了年龄减一。 # 定义显示格式
# ----------concat()函数用于连接字符串
select concat("姓名:",name," 年龄",age+1)as 显示 from student; # ----------concat_ws()第一个参数为分隔符
select concat_ws("__",name, age) as 显示 from student; # ----------结合case语句
select
(
case
when name="成龙" then
name
when name = "丫丫" then
concat(name,"_美女")
else
concat(name,"_凡人")
end
)as new_name
from student;

where约束查询

where语句中可以使用:

  • 比较运算符:>,<,>=,<=,<>,!=
  • between 80 and 100,值在80到100之间
  • is null,判断某个字段是否为NUll不能用等号,要用is。空字符串并不是null。
  • in(10,20,30),值是10或者20或者30
  • like "张%",模糊查询,找"张"开头的。
    • %:表示任意0个或多个字符。可匹配任意类型和长度的字符
    • _:表示任意单个字符
    • [ ]:表示括号内所列字符中的一个(类似正则表达式)。
    • [^ ]:表示不在括号所列之内的单个字符。
# 单条件查询
select name from student where age>20; # 多条件查询
select name from student where age>20 and sex="male"; # 关键字between .. and ..
select name from student where age between 20 and 40; # 关键字is null
select class_id from student where class_id is null;
select class_id from student where class_id is not null; # 关键字in
select name from student where age in (18, 20, 38);
select name from student where age not in (18, 20, 38); # 模糊查询
select * from student where name like "成%";

group by 分组查询

首先要明确一点,分组是在where之后进行的。

分组是按照某个相同的字段进行归类。比如:班级,性别。

注意:

当我们进行分组之后,只能查询分组字段,想要获取组内其他相关信息,需要借助函数。

# 当我们进行分组之后,只能查询分组字段,想要获取组内其他相关信息,需要借助函数。

# GROUP BY关键字和GROUP_CONCAT()函数一起使用
select class_id, group_concat(name)as 组内名字 from student group by class_id; # GROUP BY与聚合函数一起使用
select class_id, group_concat(name)as 组内名字, count(*)as 组人数 from student group by class_id;

常用的聚合函数:

COUNT(),MAX(),MIN(), AVG(),SUM()

having过滤

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

order by 排序

# 按单列排序
select * from student order by age; # 默认升序
select * from student order by age ASC; # 升序排列
select * from student order by age DESC; # 降序排列 # 按多列排序
先按照age升序排序,如果年纪相同,则按照名字降序排序
select * from student
order by age, name desc;

注:因为ordery by 在分组之后,所以也可以用分组的聚合函数。

limit限制查询的记录数

     select * from student
LIMIT 3; #默认初始位置为0 select * from student
LIMIT 0,5; #从第0开始,即先查询出第一条,然后包含这一条在内往后查5条 select * from student
LIMIT 5,5; #从第5开始,即先查询出第6条,然后包含这一条在内往后查5条

使用正则表达式查询

select * from student regexp "^成";

数据库——MySQL——单表查询的更多相关文章

  1. MySQL数据库之单表查询中关键字的执行顺序

    目录 MySQL数据库之单表查询中关键字的执行顺序 1 语法顺序 2 执行顺序 3 关键字使用语法 MySQL数据库之单表查询中关键字的执行顺序 1 语法顺序 select distinct from ...

  2. MySQL数据库语法-单表查询练习

    MySQL数据库语法-单表查询练习 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 本篇博客主要是对聚合函数和分组的练习. 一.数据表和测试数据准备 /* @author :yinz ...

  3. python 3 mysql 单表查询

    python 3 mysql 单表查询 1.准备表 company.employee 员工id id int 姓名 emp_name varchar 性别 sex enum 年龄 age int 入职 ...

  4. Mysql 单表查询-排序-分页-group by初识

    Mysql 单表查询-排序-分页-group by初识 对于select 来说, 分组聚合(((group by; aggregation), 排序 (order by** ), 分页查询 (limi ...

  5. Mysql 单表查询 子查询 关联查询

    数据准备: ## 学院表create table department( d_id int primary key auto_increment, d_name varchar(20) not nul ...

  6. Mysql 单表查询where初识

    Mysql 单表查询where初识 准备数据 -- 创建测试库 -- drop database if exists student_db; create database student_db ch ...

  7. mysql数据库之单表查询多表查询

    单表查询 前期表准备 create table emp( id int not null unique auto_increment, name varchar(20) not null, sex e ...

  8. mysql数据库之单表查询

    单标查询 单表查询语句 关键字执行的优先级 简单查询 where约束 group by 聚合函数 HAVING过滤 order by 查询排序 LIMIT限制查询的记录数 使用正则表达式查询 单表查询 ...

  9. python开发mysql:单表查询&多表查询

    一 单表查询,以下是表内容 一 having 过滤 1.1 having和where select * from emp where id > 15; 解析过程;from > where ...

随机推荐

  1. Windows与Unix思想

    Unix与Windows的思想 Unix中的哲学是"一切皆文件",这里的一切皆文件是一个广泛的概念,有一些特殊的设备文件,在/dev目录下 物理设备在Unix中就对应一个特殊的设备 ...

  2. CSS3 -webkit-transform(元素变换)

    CSS3 -webkit-transform(元素变换)   -webkit-transform:none | 类型 类型:scale:缩放,1为原始大小.scale(x).正数放大,负数缩小.属性值 ...

  3. 基于RBAC模式的权限管理系统设计概要

    很多人都知道以角色为基础的权限管理设计(RBAC),但是大部分人似懂非懂,不知道完整的权限管理系统都包括哪些内容.  在此以权限管理的使用场景来说明一下完整的权限管理内容.     一是鉴权管理,即权 ...

  4. View视图调用控制器方法

    1.@using XXX.Controllers;//引用控制器 2. var otherController = DependencyResolver.Current.GetService<U ...

  5. GUI应用程序架构的十年变迁:MVC,MVP,MVVM,Unidirectional,Clean

    十年前,Martin Fowler撰写了 GUI Architectures 一文,至今被奉为经典.本文所谈的所谓架构二字,核心即是对于对于富客户端的 代码组织/职责划分 .纵览这十年内的架构模式变迁 ...

  6. 集合之equals与hashCode方法

    一  equals equals方法是Object级的,默认对比两个对象的内存地址,很多类都重写了该方法,对比对象的实际内容,一般对比同一类对象相同属性的属性值是否相同. 二 hashCode 1.哈 ...

  7. HBase伪分布式安装(HDFS)+ZooKeeper安装+HBase数据操作+HBase架构体系

    HBase1.2.2伪分布式安装(HDFS)+ZooKeeper-3.4.8安装配置+HBase表和数据操作+HBase的架构体系+单例安装,记录了在Ubuntu下对HBase1.2.2的实践操作,H ...

  8. Hyperledger Fabric SDK use case 1

    ///////////////////////////////////////////////////////////////////////:End2endAndBackAgainIT 1.Crea ...

  9. .NET开源工作流RoadFlow-表单设计-数据表格

    数据表格即在表单中显示一个table,该table数据可以来自任意自定义的来源: 数据类型:指定表格的数据源类型 1.datatable,即.net中的System.Data.DataTable 2. ...

  10. matlab练习程序(Hilbert图像置乱)

    正好刚写了Hibert生成曲线,不如再加一篇应用的程序. 关于Hilbert图像置乱,我在网上搜的应用领域主要集中在数字水印和图像加密上,而这两个领域我都没怎么接触过. 大部分的图像置乱都是如下图的置 ...