MySQL中SQL命令语句条件查询实例详解

 更新时间:2022年11月08日 10:54:50   作者:学无止境我爱学习  
SELECT语句可以通过WHERE条件来设定查询条件,查询结果是满足查询条件的记录,下面这篇文章主要给大家介绍了关于MySQL中SQL命令语句条件查询的相关资料,需要的朋友可以参考下

一、聚合函数

聚合函数:又叫组函数,用来对表中的数据进行统计和计算,结合group by分组使用,用于统计和计算分组数据

常用聚合函数

  • count(col):求指定列的总行数
  • max(col):求指定列的最大值
  • min(col):求指定列的最小值
  • sum(col):求指定列的和
  • avg(col):求指定列的平均值(不计null值)
    • ifnull(字段名,指定值):判断指定字段是否为null,若为空则使用指定值替换

二、分组查询

分组查询:将查询结果按指定字段进行分组,字段中数据相等的分为一组

语法:group by 列名 [having 条件表达式][with rollup]

  • 列名:指按指定字段的值进行分组
  • having 条件表达式:用来过滤分组后的数据
  • with rollup:在所有记录最后加上一条记录,显示select查询时聚合函数的统计和计算结果

group by:用于单个或多个字段分组

group_concat(字段名):统计每个分组指定字段的信息集合,每个信息间用逗号分隔

group by结合聚合函数使用

group by结合having使用

having作用:与where类似,用来过滤分组数据,只能用于group by

group by结合with rollup使用

with rollup作用:在记录最后新增一行,显示select查询时聚合函数的统计和计算结果

三、连接查询

连接查询:能够实现多个表之间的查询,适合查询的字段数据来自不同的表的情况

内连接:查询两个表中符合条件的共有记录,根据连接查询条件取出两个表中的交集
内连接查询语法:select 字段 from 表1 inner join 表2 on 表1.字段1=表2.字段2;
    inner join:内连接查询关键字
    on:连接查询条件
 
左连接:以左表为主根据条件查询右表数据,若右表数据不存在则用null填充
左连接查询语法:select 字段 from 表1 left join 表2 on 表1.字段1=表2.字段2;
    left join:左连接查询关键字
    on:连接查询条件
    表1为左表,表2为右表
 
右连接:以右表为主根据条件查询左表数据,若左表数据不存在则用null值填充
右连接查询语法:select 字段 from 表1 right join 表2 on 表1.字段1=表2.字段2;
    right join:右连接查询关键字
    on:连接查询条件
    表1为左表,表2为右表
 
自连接:左表与右表为同一个表,根据连接查询条件查询两个表中数据,必须对表起别名
自连接查询语法:select 字段 from 表名 as 别名1 inner join 表名 as 别名2 on 别名1.字段1=别名2.字段2;
自连接查询就是把一张表模拟成左右两张表,然后进行连表查询,是一种特殊的连接方式,连接的表还是本身这张表 

四、子查询

子查询:在select语句中嵌入另一个select语句,被嵌入的select称为子查询语句,外部select称为主查询 

子查询与主查询关系

  • 子查询是嵌入在主查询中的
  • 子查询辅助主查询,用来充当条件或数据源
  • 子查询可以独立存在,是一条完整的select语句

五、数据库设计三范式及E-R模型

范式:对设计数据库提出的一些规范,共有8范式,一般只需遵循3范式 

  • 第一范式(1NF):强调列的原子性,即列不能再细分为其他列
  • 第二范式(2NF):满足1NF,另有两部分内容
    • 表必须有一个主键
    • 非主键字段必须完全依赖于主键,不能只依赖与主键一部分
  • 第三范式(3NF):满足 2NF,另外非主键列必须直接依赖于主键,不能存在传递依赖。即不能存在:非主键列 A 依赖于非主键列 B,非主键列 B 依赖于主键的情况

E-R模型:即实体-关系模型,用来描述数据库存储数据的结构模型

  • 实体:用矩形表示,并标注实体名称
  • 属性:用椭圆表示,并标注属性名称
  • 关系:用菱形表示,并标注关系名称
    • 一对一:如人与身份证,在两个表中创建一个字段,其中一个表存储另一个表的主键值,关系是一种数据,需要通过一个字段存储在表中
    • 一对多:如学生表与班级表,在多的一方表(学生表)中创建一个字段,存储班级表的主键值
    • 多对多:如学生表、班级表、科目表,新建一张表C,这个表只有两个字段,一个用于存储A的主键值,一个用于存储B的主键值

六、外键约束

外键约束:对外键字段的值进行更新和插入时会和引用表中字段的数据进行验证,若数据不合法则更新和插入失败,能够保证数据有效性

添加和删除外键约束

已存在的字段添加外键约束:alter table 表1 add foreign key(表1中的外键) references 表2(表2主键);
                    或:alter table 从表 add foreign key(外键字段) references 主表(主键字段);
例:alter table students add foreign key(sid) references classe(id);
 
创建表添加外键约束:
create table teacher(
    id int primary key auto_increment not null,
    name varchar(10),
    sid int not null,
    foreign key(sid) references students(id)
);
 
删除外键约束:
获取外键约束名称:show create table 表名;
删除:alter table 表名 drop foreign key 外键名;

总结

到此这篇关于MySQL中SQL命令语句条件查询的文章就介绍到这了,更多相关SQL命令语句条件查询内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 在MySQL中实现二分查找的详细教程

    在MySQL中实现二分查找的详细教程

    这篇文章主要介绍了在MySQL中实现二分查找的详细教程,来自计算机研究生考试原题,需要的朋友可以参考下
    2015-05-05
  • 教你如何让spark sql写mysql的时候支持update操作

    教你如何让spark sql写mysql的时候支持update操作

    spark提供了一个枚举类,用来支撑对接数据源的操作模式,本文重点给大家介绍如何让spark sql写mysql的时候支持update操作,本文通过实例代码给大家介绍的非常详细,需要的朋友参考下吧
    2022-02-02
  • Mysql索引结合explain分析示例

    Mysql索引结合explain分析示例

    本文主要介绍了Mysql索引结合explain分析示例,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-02-02
  • Mysql CONVERT函数的具体使用

    Mysql CONVERT函数的具体使用

    本文主要介绍了Mysql CONVERT函数的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-08-08
  • 解析mysql中的auto_increment的问题

    解析mysql中的auto_increment的问题

    本篇文章是对mysql中的auto_increment的问题进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • Ubuntu自启动Mysql的三种方式

    Ubuntu自启动Mysql的三种方式

    本文给大家介绍ubuntu自启动mysql的三种方式,一种方法通过执行命令,也是最简单的方法,第二种方法是使用sysv-rc-cont工具,第三种方法是使用chkconfig工具,关于以上三种方式的详解请看下文
    2015-10-10
  • MySQL中KEY、PRIMARY KEY、UNIQUE KEY、INDEX 的区别

    MySQL中KEY、PRIMARY KEY、UNIQUE KEY、INDEX 的区别

    本文给大家分享的是mysql索引中的KEY、PRIMARY KEY、UNIQUE KEY、INDEX 的区别,即主键索引,唯一索引和普通索引的区别,希望大家能够喜欢
    2017-07-07
  • MySQL超详细实现用户管理实例

    MySQL超详细实现用户管理实例

    MySQL 是一个多用户数据库,具有功能强大的访问控制系统,可以为不同用户指定不同权限。在前面的章节中我们使用的是 root 用户,该用户是超级管理员,拥有所有权限,包括创建用户、删除用户和修改用户密码等管理权限
    2022-06-06
  • 详解MySQL的内连接和外连接

    详解MySQL的内连接和外连接

    这篇文章主要介绍了详解MySQL的内连接和外连接,mySQL包含两种联接,分别是内连接(inner join)和外连接(out join),但我们又同时听说过左连接,交叉连接等术语,本文就带大家来了解一下,需要的朋友可以参考下
    2023-05-05
  • Can''''t connect to MySQL server on localhost (10061)解决方法

    Can''''t connect to MySQL server on localhost (10061)解决方法

    Can't connect to MySQL server on 'localhost' (10061)解决方法,需要的朋友可以参考下。
    2011-03-03

最新评论