【MySQL】表的增删改查(强化)

作者主页:paper jie_博客

本文作者:大家好,我是paper jie,感谢你阅读本文,欢迎一建三连哦。

本文录入于《MySQL》专栏,本专栏是针对于大学生,编程小白精心打造的。笔者用重金(时间和精力)打造,将MySQL基础知识一网打尽,希望可以帮到读者们哦。

其他专栏:《算法详解》《C语言》《javaSE》《数据结构》等

内容分享:本期将会分享MySQL表的增删改查的一些奇淫巧技

目录

数据库的约束

约束类型

null约束

unique: 唯一约束 

default: 默认值约束

primary key: 主键约束

foreign key: 外键约束

check约束(MySQL中不使用它)

表的设计

三大范式

一对一

一对多

多对多

新增

查询

聚合查询

聚合函数

group by 子句

having

联合查询

初始化数据

内连接

外连接

自连接

子查询

合并查询


数据库的约束

约束类型

not null: 表示某列不可以存放null

unique: 保证某列的每行必须是唯一值

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

primary key: 主键, 保证某列有唯一的标记,且不能为null

foreign key: 外键, 保证一个表的数据匹配另一个表的值的参照完整性,与匹配表对应

check: 保证列中的值符合指定的条件,但MySQL数据库堆check子句进行分析的时候会忽略它

null约束

 创建表的时候,指定列不能为空:

 create table student(id int is not null, name varchar(20));

unique: 唯一约束 

创建表的时候,指定列是唯一的,不重复的:

 create table student(id int unique, name varchar(20));

default: 默认值约束

创建表的时候,指定列为空,则插入指定默认值:

create table student(id int, name varchar(20) default '无名氏');

primary key: 主键约束

指定列为主键:

create table student(id int primary key, mame varchar(20));

自增主键: auto_increment, 插入对应数据不给值时,使用最大值+1

 create table student(id int primary key auto_increment, mame varchar(20));

foreign key: 外键约束

外键用于关键其他的表的主键:

注意: 外键约束关键的表的对应列得有主键约束才能使用foreign key

create table student(id int primary key auto_increment, mame varchar(20));
create table score(id int, name varchar(20), student_id int,  foreign key (student_id) references student(id));

check约束(MySQL中不使用它)

MySQL使用会忽略check:

create table student(id int, name varchar(30), check(id = 1 or id = 3));

表的设计

三大范式

一对一

 

一对多

多对多

新增

将一张表已有的数据复制到另一张表中,复制的字段类型需要在被复制表中有的类型

语法:

insert into 表名1(类型1,类型2....) select 类型1, 类型2.... from 表名2; 

栗子:

insert into student1(id,name) select id, name from student2;

查询

聚合查询

聚合函数

一般常用的函数有sum, avg, max, min, count:

函数作用
sum返回查询的行的数据之和,需要是数字
avg返回查询的行的数据的平均值,需要是数字
max返回查询的行的数据的最大值,需要是数字
min返回查询的行的数据的最小值,需要是数字
count返回查询的行数

栗子:

mysql> select * from student;
+----+-------+------------+------------------+----------+
| id | sn    | name       | qq_mail          | class_id |
+----+-------+------------+------------------+----------+
|  2 | 09982 | 黑旋风李逵 | xuanfeng@qq.com  |        1 |
|  3 | 00835 | 菩提老祖   | NULL             |        1 |
|  4 | 00391 | 白素贞     | NULL             |        1 |
|  5 | 00031 | 许仙       | xuxian@qq.com    |        1 |
|  6 | 00054 | 不想毕业   | NULL             |        1 |
|  7 | 51234 | 好好说话   | say@qq.com       |        2 |
|  8 | 83223 | tellme     | NULL             |        2 |
|  9 | 09527 | 老外学中文 | foreigner@qq.com |        2 |
+----+-------+------------+------------------+----------+

sum:

mysql> select sum(id) from student;
+---------+
| sum(id) |
+---------+
|      44 |
+---------+

avg:

mysql> select avg(id) from student;
+---------+
| avg(id) |
+---------+
|  5.5000 |
+---------+

max:

mysql> select max(id) from student;
+---------+
| max(id) |
+---------+
|       9 |
+---------+

min:

mysql> select min(id) from student;
+---------+
| min(id) |
+---------+
|       2 |
+---------+

count: 

mysql> select count(*) from student;
+----------+
| count(*) |
+----------+
|        8 |
+----------+

注意: 这里*是查询全部的行数, 括号内可以指定查询字段,字符为null的不会记录

mysql> select count(qq_mail) from student;
+----------------+
| count(qq_mail) |
+----------------+
|              4 |
+----------------+

group by 子句

select使用group by 可以指定列分组查询. 需要满足的条件有: 使用group by 进行分组查询的时候,select 指定的字段得是分组依据的字段, 其他字段要是想出现在select中得包含在聚合函数中

下面栗子中需要查询的数据:

mysql> select * from score;
+-------+------------+-----------+
| score | student_id | course_id |
+-------+------------+-----------+
|    70 |          1 |         1 |
|    98 |          1 |         3 |
|    33 |          1 |         5 |
|    98 |          1 |         6 |
|    60 |          2 |         1 |
|    59 |          2 |         5 |
|    33 |          3 |         1 |
|    68 |          3 |         3 |
|    99 |          3 |         5 |
|    67 |          4 |         1 |
|    23 |          4 |         3 |
|    56 |          4 |         5 |
|    72 |          4 |         6 |
|    81 |          5 |         1 |
|    37 |          5 |         5 |
|    56 |          6 |         2 |
|    43 |          6 |         4 |
|    79 |          6 |         6 |
|    80 |          7 |         2 |
|    92 |          7 |         6 |
+-------+------------+-----------+

栗子:

mysql> select student_id, sum(score) from score group by student_id;
+------------+------------+
| student_id | sum(score) |
+------------+------------+
|          1 |        299 |
|          2 |        119 |
|          3 |        200 |
|          4 |        218 |
|          5 |        118 |
|          6 |        178 |
|          7 |        172 |
+------------+------------+

having

分组后需要对结果进行筛选,不能使用where语句,需要使用having

栗子:

mysql> select student_id, sum(score) from score group by student_id having sum(score) < 200;
+------------+------------+
| student_id | sum(score) |
+------------+------------+
|          2 |        119 |
|          5 |        118 |
|          6 |        178 |
|          7 |        172 |
+------------+------------+

联合查询

在开发中会有很多张表存放数据,这里我们就需要联合查询.联合查询就是对多张表进行笛卡尔积:

初始化数据

mysql> select * from student;
+----+-------+------------+------------------+----------+
| id | sn    | name       | qq_mail          | class_id |
+----+-------+------------+------------------+----------+
|  2 | 09982 | 黑旋风李逵 | xuanfeng@qq.com  |        1 |
|  3 | 00835 | 菩提老祖   | NULL             |        1 |
|  4 | 00391 | 白素贞     | NULL             |        1 |
|  5 | 00031 | 许仙       | xuxian@qq.com    |        1 |
|  6 | 00054 | 不想毕业   | NULL             |        1 |
|  7 | 51234 | 好好说话   | say@qq.com       |        2 |
|  8 | 83223 | tellme     | NULL             |        2 |
|  9 | 09527 | 老外学中文 | foreigner@qq.com |        2 |
+----+-------+------------+------------------+----------+
mysql> select * from classes;
+---------+-------------------+-----------------------------------------------+
| classID | name              | desc                                          |
+---------+-------------------+-----------------------------------------------+
|       1 | 计算机系2019级1班 | 学习了计算机原理、C和Java语言、数据结构和算法     |
|       2 | 中文系2019级3班   | 学习了中国传统文学                              |
|       3 | 自动化2019级5班   | 学习了机械自动化                                |
+---------+-------------------+-----------------------------------------------+
mysql> select * from score;
+-------+------------+-----------+
| score | student_id | course_id |
+-------+------------+-----------+
|    70 |          1 |         1 |
|    98 |          1 |         3 |
|    33 |          1 |         5 |
|    98 |          1 |         6 |
|    60 |          2 |         1 |
|    59 |          2 |         5 |
|    33 |          3 |         1 |
|    68 |          3 |         3 |
|    99 |          3 |         5 |
|    67 |          4 |         1 |
|    23 |          4 |         3 |
|    56 |          4 |         5 |
|    72 |          4 |         6 |
|    81 |          5 |         1 |
|    37 |          5 |         5 |
|    56 |          6 |         2 |
|    43 |          6 |         4 |
|    79 |          6 |         6 |
|    80 |          7 |         2 |
|    92 |          7 |         6 |
+-------+------------+-----------+

 

mysql> select * from course;
+----+--------------+
| id | name         |
+----+--------------+
|  1 | Java         |
|  2 | 中国传统文化 |
|  3 | 计算机原理   |
|  4 | 语文         |
|  5 | 高阶数学     |
|  6 | 英文         |
+----+--------------+

内连接

使用方式: 

select 字段 from 表1 别名1 [inner] join 表2 别名2 on 连接条件 and 其他条件;
select 字段 from 表1 别名1,表2 别名2 where 连接条件 and 其他条件;

mysql> select * from student,score where student.id = score.student_id and student.name = '菩提老祖';
+----+-------+----------+---------+----------+-------+------------+-----------+
| id | sn    | name     | qq_mail | class_id | score | student_id | course_id |
+----+-------+----------+---------+----------+-------+------------+-----------+
|  3 | 00835 | 菩提老祖 | NULL    |        1 |    33 |          3 |         1 |
|  3 | 00835 | 菩提老祖 | NULL    |        1 |    68 |          3 |         3 |
|  3 | 00835 | 菩提老祖 | NULL    |        1 |    99 |          3 |         5 |
+----+-------+----------+---------+----------+-------+------------+-----------+

 

mysql> select * from student join score on student.id = score.student_id and student.name = '菩提老祖';
+----+-------+----------+---------+----------+-------+------------+-----------+
| id | sn    | name     | qq_mail | class_id | score | student_id | course_id |
+----+-------+----------+---------+----------+-------+------------+-----------+
|  3 | 00835 | 菩提老祖 | NULL    |        1 |    33 |          3 |         1 |
|  3 | 00835 | 菩提老祖 | NULL    |        1 |    68 |          3 |         3 |
|  3 | 00835 | 菩提老祖 | NULL    |        1 |    99 |          3 |         5 |
+----+-------+----------+---------+----------+-------+------------+-----------+

外连接

外连接分为左外连接和右外连接.联合查询中左侧的表完全显示为左外连接,右侧完全显示为有外连接

使用方法:

-- 左外连接,表1完全显示
select 字段名 from 表名1 left join 表名2 on 连接条件;
-- 右外连接,表2完全显示
select 字段 from 表名1 right join 表名2 on 连接条件;

mysql> select * from student left join score on student.id = score.student_id;
+----+-------+------------+------------------+----------+-------+------------+-----------+
| id | sn    | name       | qq_mail          | class_id | score | student_id | course_id |
+----+-------+------------+------------------+----------+-------+------------+-----------+
|  2 | 09982 | 黑旋风李逵 | xuanfeng@qq.com  |        1 |    60 |          2 |         1 |
|  2 | 09982 | 黑旋风李逵 | xuanfeng@qq.com  |        1 |    59 |          2 |         5 |
|  3 | 00835 | 菩提老祖   | NULL             |        1 |    33 |          3 |         1 |
|  3 | 00835 | 菩提老祖   | NULL             |        1 |    68 |          3 |         3 |
|  3 | 00835 | 菩提老祖   | NULL             |        1 |    99 |          3 |         5 |
|  4 | 00391 | 白素贞     | NULL             |        1 |    67 |          4 |         1 |
|  4 | 00391 | 白素贞     | NULL             |        1 |    23 |          4 |         3 |
|  4 | 00391 | 白素贞     | NULL             |        1 |    56 |          4 |         5 |
|  4 | 00391 | 白素贞     | NULL             |        1 |    72 |          4 |         6 |
|  5 | 00031 | 许仙       | xuxian@qq.com    |        1 |    81 |          5 |         1 |
|  5 | 00031 | 许仙       | xuxian@qq.com    |        1 |    37 |          5 |         5 |
|  6 | 00054 | 不想毕业   | NULL             |        1 |    56 |          6 |         2 |
|  6 | 00054 | 不想毕业   | NULL             |        1 |    43 |          6 |         4 |
|  6 | 00054 | 不想毕业   | NULL             |        1 |    79 |          6 |         6 |
|  7 | 51234 | 好好说话   | say@qq.com       |        2 |    80 |          7 |         2 |
|  7 | 51234 | 好好说话   | say@qq.com       |        2 |    92 |          7 |         6 |
|  8 | 83223 | tellme     | NULL             |        2 |  NULL |       NULL |      NULL |
|  9 | 09527 | 老外学中文 | foreigner@qq.com |        2 |  NULL |       NULL |      NULL |
+----+-------+------------+------------------+----------+-------+------------+-----------+
mysql> select * from student right join score on student.id = score.student_id;
+------+-------+------------+-----------------+----------+-------+------------+-----------+
| id   | sn    | name       | qq_mail         | class_id | score | student_id | course_id |
+------+-------+------------+-----------------+----------+-------+------------+-----------+
| NULL | NULL  | NULL       | NULL            |     NULL |    70 |          1 |         1 |
| NULL | NULL  | NULL       | NULL            |     NULL |    98 |          1 |         3 |
| NULL | NULL  | NULL       | NULL            |     NULL |    33 |          1 |         5 |
| NULL | NULL  | NULL       | NULL            |     NULL |    98 |          1 |         6 |
|    2 | 09982 | 黑旋风李逵 | xuanfeng@qq.com |        1 |    60 |          2 |         1 |
|    2 | 09982 | 黑旋风李逵 | xuanfeng@qq.com |        1 |    59 |          2 |         5 |
|    3 | 00835 | 菩提老祖   | NULL            |        1 |    33 |          3 |         1 |
|    3 | 00835 | 菩提老祖   | NULL            |        1 |    68 |          3 |         3 |
|    3 | 00835 | 菩提老祖   | NULL            |        1 |    99 |          3 |         5 |
|    4 | 00391 | 白素贞     | NULL            |        1 |    67 |          4 |         1 |
|    4 | 00391 | 白素贞     | NULL            |        1 |    23 |          4 |         3 |
|    4 | 00391 | 白素贞     | NULL            |        1 |    56 |          4 |         5 |
|    4 | 00391 | 白素贞     | NULL            |        1 |    72 |          4 |         6 |
|    5 | 00031 | 许仙       | xuxian@qq.com   |        1 |    81 |          5 |         1 |
|    5 | 00031 | 许仙       | xuxian@qq.com   |        1 |    37 |          5 |         5 |
|    6 | 00054 | 不想毕业   | NULL            |        1 |    56 |          6 |         2 |
|    6 | 00054 | 不想毕业   | NULL            |        1 |    43 |          6 |         4 |
|    6 | 00054 | 不想毕业   | NULL            |        1 |    79 |          6 |         6 |
|    7 | 51234 | 好好说话   | say@qq.com      |        2 |    80 |          7 |         2 |
|    7 | 51234 | 好好说话   | say@qq.com      |        2 |    92 |          7 |         6 |
+------+-------+------------+-----------------+----------+-------+------------+-----------+

自连接

自连接就是自己与自己连接查询.

mysql> select * from course c1, course c2 where c1.name = c2.name;
+----+--------------+----+--------------+
| id | name         | id | name         |
+----+--------------+----+--------------+
|  1 | Java         |  1 | Java         |
|  2 | 中国传统文化 |  2 | 中国传统文化 |
|  3 | 计算机原理   |  3 | 计算机原理   |
|  4 | 语文         |  4 | 语文         |
|  5 | 高阶数学     |  5 | 高阶数学     |
|  6 | 英文         |  6 | 英文         |
+----+--------------+----+--------------+

子查询

子查询是指嵌入在其他sql语句中的select语句 

mysql> select * from student where class_id = (select class_id from student where name = 'tellme');
+----+-------+------------+------------------+----------+
| id | sn    | name       | qq_mail          | class_id |
+----+-------+------------+------------------+----------+
|  7 | 51234 | 好好说话   | say@qq.com       |        2 |
|  8 | 83223 | tellme     | NULL             |        2 |
|  9 | 09527 | 老外学中文 | foreigner@qq.com |        2 |
+----+-------+------------+------------------+----------+

合并查询

将多个类型一样的表合并

mysql> select * from course where id < 2 union select * from course where id = 4;
+----+------+
| id | name |
+----+------+
|  1 | Java |
|  4 | 语文 |
+----+------+

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/128605.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

物奇平台耳机宕机恢复功能实现

是否需要申请加入数字音频系统研究开发交流答疑群(课题组)&#xff1f;可加我微信hezkz17, 本群提供音频技术答疑服务&#xff0c;群赠送语音信号处理降噪算法&#xff0c;蓝牙音频&#xff0c;DSP音频项目核心开发资料, 物奇平台耳机宕机恢复功能实现 一 需求与场景 1 使…

TortoiseSVN 状态图标不显示的两种解决办法

文章目录 TortoiseSVN 方式解决注册表方式解决 TortoiseSVN 方式解决 在桌面或者资源管理器中鼠标右键打开 TortoiseSVN 设置选择 Icon Overlays (图标覆盖)Status cache&#xff08;状态缓存&#xff09; 选择 ‘Shell’ 选择 Icon Overlays&#xff08;图标覆盖&#xff09;…

基于AI智能分析网关的智慧视频监控系统一站式解决方案

1、功能概述 TSINGEE智能分析网关EasyCVR智慧视频监控系统基于云-边-端一体化协同架构&#xff0c;可兼容多协议、多类型的设备接入&#xff0c;实现视频数据采集、海量视频汇聚与处理、按需调阅、全网分发、 告警消息推送、数据级联共享、AI智能分析接入等视频能力服务&#…

我敢打赌,这个架构你一定知道!

大家好&#xff0c;我是鱼皮。开发后端项目时&#xff0c;我们最常见的一种架构模式就是 分层架构 。 所谓的分层架构&#xff0c;就是把系统自上而下分为多个不同的层&#xff0c;每一层都有特定的功能和职责&#xff0c;且只和自己的直接上层与直接下层 “打交道”。 分层架…

MySQL 数据库表格创建、数据插入及获取插入的 ID:Python 教程

创建表格 要在MySQL中创建表格&#xff0c;请使用"CREATE TABLE"语句。 确保在创建连接时定义了数据库的名称。 示例创建一个名为 “customers” 的表格&#xff1a; import mysql.connectormydb mysql.connector.connect(host"localhost",user"…

LDR6023AQ-PDHUB最简外围成本低搂到底就是干

USB-C PD协议里&#xff0c;SRC和SNK双方之间通过CC通信来协商请求确定充电功率及数据传输速率。当个设备需要充电时&#xff0c;它会发送消息去给适配器请求充电&#xff0c;此时充电器会回应设备的请求&#xff0c;并告知其可提供的档位功率&#xff0c;设备端会根据适配器端…

Java集合面试题

常见的java集合&#xff1f; 主要分为三类&#xff0c;List Map Set 列表 映射 集 集合相关的接口都在 java.util中 java集合的主要关系 List 特性&#xff1a; 存储的元素有序&#xff0c;可重复 Set 特性&#xff1a;存储的元素无序&#xff0c;不可重复 Map 特性…

【Proteus仿真】【51单片机】汽车尾灯控制设计

文章目录 一、功能简介二、软件设计三、实验现象联系作者 一、功能简介 本项目使用Proteus8仿真51单片机控制器&#xff0c;使用按键、LED模块等。 主要功能&#xff1a; 系统运行后&#xff0c;系统运行后&#xff0c;系统开始运行&#xff0c;K1键控制左转向灯&#xff1b;…

外贸企业GMS认证|SD-WAN专线解决方案支持 IPv6、IPv4

IP地址是英文internet protocol的缩写&#xff0c;是网络之间互连的协议。互联网诞生后&#xff0c;很长一段时间都是使用v4版本的IP协议&#xff0c;也就是 IPv4 &#xff0c;目前全球使用互联网的人数达到了48.8亿&#xff0c;而IPv4的地址库总共约43亿个地址&#xff0c;每个…

相同的树(C++解法)

题目 给你两棵二叉树的根节点 p 和 q &#xff0c;编写一个函数来检验这两棵树是否相同。 如果两个树在结构上相同&#xff0c;并且节点具有相同的值&#xff0c;则认为它们是相同的。 示例 1&#xff1a; 输入&#xff1a;p [1,2,3], q [1,2,3] 输出&#xff1a;true示例 …

结构体内存对齐(三板斧解决结构体的大小)

文章目录 前言一、结构体对齐规则二、结构体大小计算 - 三板斧一板斧二板斧三板斧 三、为什么存在内存对齐&#xff1f;四、修改默认对齐数 前言 我们知道&#xff0c;整型变量有自己的大小&#xff0c;浮点型变量有自己的大小&#xff0c;数组也有自己的大小&#xff0c;只要…

linux下搭建gperftools工具分析程序瓶颈

1. 先安装 unwind //使用root wget https://github.com/libunwind/libunwind/archive/v0.99.tar.gz tar -xvf v0.99.tar.gz cd libunwind-0.99 autoreconf --force -v --install ./configure make sudo make install2. 安装gperftools wget https://github.com/gp…

操作系统第一次实验——短作业优先调度算法(SJF)

一、实验目的&#xff1a; 目的&#xff1a;了解并掌握作业调度的功能&#xff0c;熟悉并掌握各种作业调度算法。 任务&#xff1a;模拟实现先来先服务或者短作业优先调度算法。 二、实验内容&#xff1a; 1、实验内容 模拟实现SJF调度。 设置作业体&#xff1a;作业名&#x…

关于mac下pycharm旧版本没删除的情况下新版本2023安装之后闪退

先说结论&#xff0c;我用的app cleaner 重新删除的pycharm &#xff0c;再重新安装即可。在此记录一下 之前安装的旧版的2020的pycharm&#xff0c;因为装不了新的插件&#xff0c;没办法就升级了。新装2023打开之后闪退&#xff0c;重启系统也不行&#xff0c;怀疑是一起破解…

类图复习:类图简单介绍

入职新公司在看新项目的代码&#xff0c;所以借助类图梳理各个类之间的关系&#xff0c;奈何知识已经还给了老师&#xff0c;不得不重新学习下类图的相关知识&#xff0c;此处将相关内容记录下方便后续使用。 文章目录 类图语法类与类的关系画类图 类图语法 语法描述public-pr…

C语言--typedef的使用

前言 在C语言中使用结构体时必须加上struct这个关键字,那有没有办法省略这个呢?要想达到这个目的就 需要用到关键字typedef,顾名思义”类型定义”。 typedef 数据类型 新的别名; 它是用来操作数据类型。其主要作用有两个: 1.给一个较长较复杂的类型取一个简单的别名。 2.给类…

MySQL其他集群类型介绍

常用的/常见的Mysql集群方案 1.MySQL Replication2.MySQL Fabric3.MySQL NDB Cluster4.MGR&#xff08;MySQL Group Replication&#xff09;5.心跳检测SAN共享存储&#xff08;heartbeat SAN&#xff09;6.心跳检测DRBD磁盘复制&#xff08;heartbeat DRBD&#xff09;7.MMM…

大桌子想传大文件

受高手指导说服务器想传大点的文件&#xff0c;得把两个地方改改 先是这里 然后这里也要改 哦。对了&#xff0c;改完之后要重启服务器。别忘了。

网络爬虫代理ip有什么好处?爬虫工作使用代理IP有哪些优势?

在爬虫工作中&#xff0c;使用代理IP有很多好处&#xff0c;可以帮助爬虫程序更加高效地完成任务。以下是使用代理IP的几个优势&#xff1a; 1. 增加匿名性 使用代理IP可以隐藏爬虫程序的真正IP地址&#xff0c;增加匿名性&#xff0c;避免被目标网站封禁。通过代理IP&#xff…

【ElasticSearch系列-07】ES的开发场景和索引分片的设置及优化

ElasticSearch系列整体栏目 内容链接地址【一】ElasticSearch下载和安装https://zhenghuisheng.blog.csdn.net/article/details/129260827【二】ElasticSearch概念和基本操作https://blog.csdn.net/zhenghuishengq/article/details/134121631【三】ElasticSearch的高级查询Quer…