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

这篇具有很好参考价值的文章主要介绍了【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));

表的设计

三大范式

一对一

【MySQL】表的增删改查(强化),MySQL,mysql,数据库 

一对多

【MySQL】表的增删改查(强化),MySQL,mysql,数据库

多对多

【MySQL】表的增删改查(强化),MySQL,mysql,数据库

新增

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

语法:

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】表的增删改查(强化),MySQL,mysql,数据库

初始化数据

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 |
+----+-------+------------+------------------+----------+

合并查询

将多个类型一样的表合并文章来源地址https://www.toymoban.com/news/detail-757015.html

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

到了这里,关于【MySQL】表的增删改查(强化)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • node+vue3+mysql前后分离开发范式——实现对数据库表的增删改查

    大家好,我是yma16,本文分享关于 node+vue3+mysql前后分离开发范式——实现对数据库表的增删改查。 技术选型 前端:vite+vue3+antd 后端:node koa 数据库:mysql koa是一个现代的Node.js框架,可以用来构建Web应用程序。 Vue.js 是一款用于构建用户界面的开源JavaScript框架。Vue.js 3 是 Vu

    2024年02月20日
    浏览(38)
  • 【MySQL】表的增删改查(强化)

    作者主页: paper jie_博客 本文作者:大家好,我是paper jie,感谢你阅读本文,欢迎一建三连哦。 本文录入于《MySQL》专栏,本专栏是针对于大学生,编程小白精心打造的。笔者用重金(时间和精力)打造,将MySQL基础知识一网打尽,希望可以帮到读者们哦。 其他专栏:《算法详

    2024年02月04日
    浏览(42)
  • 【MySql】数据库的增删改查

    本篇的主要目的:对于数据库如何去增加删除查询修改 主要细节在于选项问题,编码选项 说明: 大写的表示 [] 是可选项 CHARACTER SET: 指定数据库采用的字符集 COLLATE: 指定数据库字符集的校验规则 查看当前用户数据库的列表show databases; 创建数据库create database db_name; 当

    2024年02月12日
    浏览(46)
  • 【MYSQL数据库的增删改查操作-超市管理系统】

    MYSQL数据库的增删改查 创建数据库 选择数据库 删除数据库 创建数据表 删除数据表 插入数据 更新数据 查找数据 以超市管理系统为例,包含员工表,库存表,仓库表 数据库:db_supermarket 数据表:s_employee #员工表;s_stock #库存表;s_storehouse #仓库表 插入数据之后生成表如下:

    2024年02月09日
    浏览(49)
  • 【MySQL】数据库的增删改查、备份、还原等基本操作

    大写的表示 [] 是可选项 CHARACTER SET: 指定数据库采用的字符集 COLLATE: 指定数据库字符集的校验规则 创建数据库的时候,有两个编码集: 1.数据库编码集——数据库未来存储数据 2.数据库校验集——支持数据库进行字段比较使用的编码,本质也是一种读取数据库中数据采

    2024年02月08日
    浏览(74)
  • MySql学习2:SQL分类、数据库操作、表操作、数据的增删改查

    SQL分类: DDL:数据定义语言,用来定义数据库对象(数据库、表、字段) DML:数据操作语言,用来对数据库表中的数据进行增删改 DQL:数据库查询语言,用来查询数据库表中的记录 DCL:数据控制语言,用来创建数据库用户、控制数据库的访问权限 查询所有数据库 查询当前

    2024年02月11日
    浏览(51)
  • Django学习记录:使用ORM操作MySQL数据库并完成数据的增删改查

    数据库操作 MySQL数据库+pymysql Django开发操作数据库更简单,内部提供了ORM框架。 安装第三方模块 ORM可以做的事: 1、创建、修改、删除数据库中的表(不用写SQL语句)。【无法创建数据库】 2、操作表中的数据(不用写SQL语句)。 1、自己创建数据库 1)启动MySQL服务 2)自带

    2024年02月14日
    浏览(59)
  • 【MySQL】 MySQL表的增删改查(基础)

    本节目标: CRUD : Create, Retrieve,Update,Delete 新增数据 查询数据 修改数据 删除数据 注释:在SQL中可以使用“–空格+描述”来表示注释说明 CRUD 即增加(Create)、查询(Retrieve)、更新(Update)、删除(Delete)四个单词的首字母缩写 语法格式: 创建案例如下: 代码如下: 结果如下: 代

    2024年02月07日
    浏览(45)
  • MySQL--MySQL表的增删改查(进阶)

    check 聚合查找 count sum average max min 我们这里先构造出多张表 查询lisi同学的成绩 来自student和来自score c 增加名字这一条件 查询所有同学的总成绩以及个人信息 来自score和来自student 查询所有同学的各科成绩以及个人信息 来自student,course和score 简化后的结果如下: 除了上述的

    2024年02月09日
    浏览(39)
  • MySQL--MySQL表的增删改查(基础)

    排序:ORDER BY 语法: – ASC 为升序(从小到大) – DESC 为降序(从大到小) – 默认为 ASC SELECT … FROM table_name [WHERE …] ORDER BY column [ASC|DESC], […]; *** update

    2024年02月09日
    浏览(33)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包