【MySQL】MySQL 表的增删改查(进阶)

2024-08-26 17:36

本文主要是介绍【MySQL】MySQL 表的增删改查(进阶),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

欢迎关注个人主页:逸狼


创造不易,可以点点赞吗~

如有错误,欢迎指出~



目录

约束类型 

not null 非空

unique 唯一

default 指定默认值

primary key 主键

foreign key 外键

check字句  检查

表设计

确定实体  

实体之间的关系

聚合查询

聚合函数

count  计算列的行数

sum  计算列的和

group by 分组查询

搭配条件使用group by

分组之前的条件  用where

分组之后的条件  用having

同时包含 

联合查询(多表查询)

内连接  外连接 和 自连接

内连接

外连接 

左外连接

右外连接

​编辑

自连接

练习 

多表查询的步骤

多表查询 使用join

自连接 练习 

子查询

合并查询

union

union all 


约束类型 

not null 非空

指示某列不能存储 NULL 值。

unique 唯一

保证某列的每行必须有唯一的值。

default 指定默认值

规定没有给列赋值时的默认值。

primary key 主键

not null 和 unique 的结合。确保某列(或两个列多个列的结合)有唯一标 识,有助于更容易更快速地找到表中的一个特定的记录。 大部分情况下,都是用数字作为主键(当然有时候会使用是字符串).

 但是数据库 允许把多个列共同作为一个主键(联合主键)

mysql 提供" 自增主键" 自动分配(auto_increment) 主键,自增主键只针对 int/ bigint 整数.

foreign key 外键

保证一个表中的数据匹配另一个表中的值的参照完整性。

 父表约束子表,子表也会对父表反向约束~

若要删除父子表,  确保先删除 子表,在删除 父表 

check字句  检查

保证列中的值符合指定的条件。对于MySQL数据库,对CHECK子句进行分析,但是忽略 CHECK子句。(MySQL不支持check,但是写了check 不会报错 ,检测条件不会生效)

表设计

根据实际需求, 创建几个表, 每个表有哪些列,以及多个表之间有哪些联系 (即确定 需求中的"实体" 和"联系")

确定实体  

针对"实体" 抽象出其 特点,提取出需要用到的关键信息,

有几个实体,一般就会有几个表,每个实体用一个表来表示 

实体之间的关系

  1. 一对一关系, 如:一个学生对应一个学号,一个学号只能属于一个学生
  2. 一对多关系, 如:一个学生只能属于一个班级,但一个班级可以包含多个学生
  3. 多对多关系, 如:一个学生可以选多个课程,一门课程也可以被多个学生选择
  4. 没关系

聚合查询

聚合函数

count  计算列的行数

下图myql语句是 先执行select * from exam_result , 根据第一句的结果再执行count

结果中包含null ,可能会对上面的结果 产生影响(会把null也算在结果中) 但select 列名,遇到空值 不会进行计数.

sum  计算列的和

需要确保该列是数字用于计算

null和其他数值进行各种运算,结果都为null,  但sum会跳过null,不参与计算.

若是字符串,会出问题

avg() ,max() ,min() 等函数同理~

group by 分组查询

使用group by 指定一个列,会把列的值相同行归到一组

在上图的基础上排个序

搭配条件使用group by

分组之前的条件  用where

查询每个岗位的平均薪资,但是除去张三

分组之后的条件  用having

查询每个岗位的平均薪资,排除平均薪资超过5w的记录

同时包含 

查询每个岗位的平均薪资,排除张三,也排除平均薪资超过5w的记录

联合查询(多表查询)

笛卡尔积:将两个表按照一定的规律 排列组合

如图先创建两个表,一个学生表,一个班级表,它们通过classId联系在一起

内连接  外连接 和 自连接

 mysql支持内连接和 外连接,下面用两个表举例

内连接

内连接查询结果 只包含两个表 同时具备的数据

也可以使用 inner join 来写 内连接,其中inner 可以省略 

外连接 

左外连接

以左表为基准,确保左表的每个记录都出现在最终结果中,若左表的记录在右表中 没有对应的记录,就会把右表相关字段填成 null

右外连接

 mysql不支持 全外连接~

自连接

自己和自己进行 笛卡尔积,本质上是 把 行关系转换成 列 关系 

如果发现 要查询的条件 是针对两行 而不是两列时 就可以考虑使用 自连接

但是自连接的时候 ,表非常大, 此时的连接开销会非常大,容易把数据库 搞挂

练习 

多表查询的步骤

  1. 明确要查询的信息 来自那些表
  2. 对这些表进行笛卡尔积(前提是可以进行 笛卡尔积)
  3. 指定连接条件,将有意义的数据筛选出来
  4. 根据需要进一步指定条件,对数据进行筛选(新加的条件 往往通过and 方式连接)
  5. 进一步针对查询的列 进行精简 

1. 查询“许仙”同学的 成绩

多表查询 使用join

使用join on和使用 where 本质上都是一样的,where是全部写在了一起,也是两两连接,join on 更突出筛选的过程

2. 查询所有同学的总成绩,及同学的个人信息:

select student.id,student.name,sum(score.score) from student join score

on student.id = score .student_id group by student.name;使用join实现上面功能

查询所有同学的成绩,及同学的个人信息:

使用join 实现上图效果 

自连接 练习 

显示所有“计算机原理”成绩比“Java”成绩高的成绩信息

子查询

实际上就是 两个简单查询的套娃,也叫 嵌套查询, 不建议 使用

练习:  查询与“不想毕业” 同学的同班同学:

若将其拆成 两个 查询, 显然是更方便 程序员思考

 多子行查询

此时不能使用 = > < 这样的运算符 直接比较了,但可以使用 in

例如 查询“语文”或“英文”课程的成绩信息

若分成3个sql语句

合并查询

union

该操作符用于取得两个结果集的并集。会 自动去掉结果集中的重复行。

使用or达到相同效果,但是适用范围没有union 广泛

  select * from course where id <3 or name = '英文';

union all 

该操作符用于取得两个结果集的并集。不会去掉结果集中的重复行。

这篇关于【MySQL】MySQL 表的增删改查(进阶)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1109230

相关文章

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

SQL中的外键约束

外键约束用于表示两张表中的指标连接关系。外键约束的作用主要有以下三点: 1.确保子表中的某个字段(外键)只能引用父表中的有效记录2.主表中的列被删除时,子表中的关联列也会被删除3.主表中的列更新时,子表中的关联元素也会被更新 子表中的元素指向主表 以下是一个外键约束的实例展示

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

如何去写一手好SQL

MySQL性能 最大数据量 抛开数据量和并发数,谈性能都是耍流氓。MySQL没有限制单表最大记录数,它取决于操作系统对文件大小的限制。 《阿里巴巴Java开发手册》提出单表行数超过500万行或者单表容量超过2GB,才推荐分库分表。性能由综合因素决定,抛开业务复杂度,影响程度依次是硬件配置、MySQL配置、数据表设计、索引优化。500万这个值仅供参考,并非铁律。 博主曾经操作过超过4亿行数据

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

MySQL数据库宕机,启动不起来,教你一招搞定!

作者介绍:老苏,10余年DBA工作运维经验,擅长Oracle、MySQL、PG、Mongodb数据库运维(如安装迁移,性能优化、故障应急处理等)公众号:老苏畅谈运维欢迎关注本人公众号,更多精彩与您分享。 MySQL数据库宕机,数据页损坏问题,启动不起来,该如何排查和解决,本文将为你说明具体的排查过程。 查看MySQL error日志 查看 MySQL error日志,排查哪个表(表空间

MySQL高性能优化规范

前言:      笔者最近上班途中突然想丰富下自己的数据库优化技能。于是在查阅了多篇文章后,总结出了这篇! 数据库命令规范 所有数据库对象名称必须使用小写字母并用下划线分割 所有数据库对象名称禁止使用mysql保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来) 数据库对象的命名要能做到见名识意,并且最后不要超过32个字符 临时库表必须以tmp_为前缀并以日期为后缀,备份

[MySQL表的增删改查-进阶]

🌈个人主页:努力学编程’ ⛅个人推荐: c语言从初阶到进阶 JavaEE详解 数据结构 ⚡学好数据结构,刷题刻不容缓:点击一起刷题 🌙心灵鸡汤:总有人要赢,为什么不能是我呢 💻💻💻数据库约束 🔭🔭🔭约束类型 not null: 指示某列不能存储 NULL 值unique: 保证某列的每行必须有唯一的值default: 规定没有给列赋值时的默认值.primary key:

MySQL-CRUD入门1

文章目录 认识配置文件client节点mysql节点mysqld节点 数据的添加(Create)添加一行数据添加多行数据两种添加数据的效率对比 数据的查询(Retrieve)全列查询指定列查询查询中带有表达式关于字面量关于as重命名 临时表引入distinct去重order by 排序关于NULL 认识配置文件 在我们的MySQL服务安装好了之后, 会有一个配置文件, 也就