『 MySQL数据库 』表的增删查改(CRUD)之表的数据插入及基本查询(上)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 『 MySQL数据库 』表的增删查改(CRUD)之表的数据插入及基本查询(上)



📂 Create(创建/新增)

对于表内数据的创建无非就是对数据的插入;

INSERT [INTO] table_name
[(column [, column] ...)]
VALUES (value_list) [, (value_list)] ...
value_list: value, [, value] ...

存在一张表为:

mysql> create table if not exists stu(
    -> id int(2) unsigned zerofill primary key comment'id并设置主键约束',
    -> sn int(5) unsigned zerofill not null unique comment'学号',
    -> name varchar(20) not null comment'姓名',
    -> email varchar(32) null comment'邮箱'
    -> );
Query OK, 0 rows affected (0.00 sec)
mysql> desc stu;
+-------+--------------------------+------+-----+---------+-------+
| Field | Type                     | Null | Key | Default | Extra |
+-------+--------------------------+------+-----+---------+-------+
| id    | int(2) unsigned zerofill | NO   | PRI | NULL    |       |
| sn    | int(5) unsigned zerofill | NO   | UNI | NULL    |       |
| name  | varchar(20)              | NO   |     | NULL    |       |
| email | varchar(32)              | YES  |     | NULL    |       |
+-------+--------------------------+------+-----+---------+-------+

📌全列插入与指定列插入📌

以该表为例,若是需要为该表插入数据,插入数据的方式分为全列插入指定列插入;

  • 全列插入
    全列插入指的是在插入数据时需要插入表中所有的字段;
    即表中有几个字段就需要根据字段个数与字段要求插入对应的数据;
mysql> insert into stu values(1,1,'Lihua','123456@xx.com'); #全列插入
Query OK, 1 row affected (0.00 sec)
mysql> select * from stu;
+----+-------+-------+---------------+
| id | sn    | name  | email         |
+----+-------+-------+---------------+
| 01 | 00001 | Lihua | 123456@xx.com |
+----+-------+-------+---------------+
1 row in set (0.00 sec)
  • 在默认的插入中使用的即为全列插入,在全列插入时values前不需要使用()来指明需要插入 的字段,只需要在values后使用()按照字段顺序插入对应数据即可;
    语法:
insert [into] table_name values (value_list) [, (value_list)] ...
  • 其中带[]的为可省略;
  • 指定列插入
    指定列插入,顾名思义是需要指定所插入的字段进行插入;
mysql> insert into stu (id,name,sn)value(2,'Zhangqian',2);#指定列插入
Query OK, 1 row affected (0.00 sec)
mysql> select * from stu;
+----+-------+-----------+---------------+
| id | sn    | name      | email         |
+----+-------+-----------+---------------+
| 01 | 00001 | Lihua     | 123456@xx.com |
| 02 | 00002 | Zhangqian | NULL          |
+----+-------+-----------+---------------+
2 rows in set (0.00 sec)
  • 如该段代码所示,这段代码演示了如何使用指定列插入,插入数据时在values前使用()指定了需要插入数据的字段,在插入数据时根据所指定字段的顺序以及对应的要求对表进行数据的插入;
    语法:
insert [into] table_name [(column [, column] ...)/*指定列*/]values (value_list) [, (value_list)] ...

📌单行数据插入与多行数据插入📌

无论是全列插入还是指定列插入都能进行对应的单行数据与多行数据插入;

这表示在MySQL中对于各种条件的混用是十分灵活的;

  • 单行数据插入
    单行数据插入即在解释全列插入与指定列插入所使用的数据插入;
    mysql> insert into stu values(1,1,'Lihua','123456@xx.com'); #单行数据插入
    这个代码中为什么叫做单行数据插入?
    在MySQL中我们将字段称之为列,对应的行即为对应的一组数据;
    这里的values(1,1,'Lihua','123456@xx.com')即为插入一行数据,该行数据根据对应的字段如上;
  • 多行数据插入
    而要进行多行数据插入则可以直接使用,(value_list)来对数据进行追加;
    示例:(这里以全列插入为例,指定列插入不再作示范)
mysql> insert into stu values(3,3,'Liqiang','112233'),(4,4,'Zhangwu','223344'),(5,5,'Liuba','445566');
Query OK, 3 rows affected (0.00 sec)
Records: 3  Duplicates: 0  Warnings: 0
mysql> select * from stu;
+----+-------+-----------+---------------+
| id | sn    | name      | email         |
+----+-------+-----------+---------------+
| 01 | 00001 | Lihua     | 123456@xx.com |
| 02 | 00002 | Zhangqian | NULL          |
| 03 | 00003 | Liqiang   | 112233        |
| 04 | 00004 | Zhangwu   | 223344        |
| 05 | 00005 | Liuba     | 445566        |
+----+-------+-----------+---------------+
5 rows in set (0.00 sec)

📌插入数据否则更新📌

INSERT ... ON DUPLICATE KEY UPDATE
column = value [, column = value] ...

插入数据否则更新这个是为了应对当在插入数据时发生的主键冲突或者唯一键冲突

当插入数据时发生主键冲突或者唯一键冲突时使用这个语法时将会将原本的数据删除并以新的数据进行插入并替换该数据;

以该表为例:

+----+-------+-----------+---------------+
| id | sn    | name      | email         |
+----+-------+-----------+---------------+
| 01 | 00001 | Lihua     | 123456@xx.com | 
| 02 | 00002 | Zhangqian | NULL          |
| 03 | 00003 | Liqiang   | 112233        |
| 04 | 00004 | Zhangwu   | 223344        |
| 05 | 00005 | Liuba     | 445566        |
+----+-------+-----------+---------------+
mysql> show create table stu\G
*************************** 1. row ***************************
       Table: stu
Create Table: CREATE TABLE `stu` (
  `id` int(2) unsigned zerofill NOT NULL COMMENT 'id并设置主键约束',
  `sn` int(5) unsigned zerofill NOT NULL COMMENT '学号',
  `name` varchar(20) NOT NULL COMMENT '姓名',
  `email` varchar(32) DEFAULT NULL COMMENT '邮箱',
  PRIMARY KEY (`id`),
  UNIQUE KEY `sn` (`sn`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8

从上面的代码可以看出其中id字段设有主键约束,sn字段设有唯一键约束;

在不使用替换的语法前对其进行插入数据,且人为的触发其中一个约束冲突;

#主键冲突
mysql> insert into stu values(5,6,'Lianhua','22222');
ERROR 1062 (23000): Duplicate entry '05' for key 'PRIMARY'
#唯一键冲突
mysql> insert into stu values(6,5,'Lianhua','22222');
ERROR 1062 (23000): Duplicate entry '00005' for key 'sn'

当发生冲突时使用语法使其完成当发生键值冲突进行替换;

mysql> insert into stu values(5,6,'Lianhua','22222') 
    -> on duplicate key update id = 6,sn = 6,name ='LIANHUA',email='22222';
Query OK, 2 rows affected (0.00 sec)
mysql> select * from stu;
+----+-------+-----------+---------------+
| id | sn    | name      | email         |
+----+-------+-----------+---------------+
| 01 | 00001 | Lihua     | 123456@xx.com |
| 02 | 00002 | Zhangqian | NULL          |
| 03 | 00003 | Liqiang   | 112233        |
| 04 | 00004 | Zhangwu   | 223344        |
| 06 | 00006 | LIANHUA   | 22222         | #->已经发生了替换
+----+-------+-----------+---------------+

从上面的操作可以看出原来的其中一个字段为:

| 05 | 00005 | Liuba | 445566 |

在这次插入失败后进行了替换,替换为了:

| 06 | 00006 | LIANHUA | 22222 |

不仅如此,在替换成功时也有对应的提示:

Query OK, 2 rows affected (0.00 sec)

在MySQL中以该方式进行数据插入时,会有对应提示:

-- 0 row affected: 表中有冲突数据,但冲突数据的值和 update 的值相等
-- 1 row affected: 表中没有冲突数据,数据被插入
-- 2 row affected: 表中有冲突数据,并且数据已经被更新

📌数据的替换📌

数据的替换类比于上一个插入数据否则更新;

数据的替换真正的意义上是:

  • 若是发生主键冲突或者唯一键冲突,则删除原数据再进行插入;
  • 若是未发生主键冲突也未发生唯一键冲突,则直接插入数据;
    对应的语法即为INSERT INTO变为REPLACE INTO;
mysql> replace into stu values(5,6,'Lianhua','22222');
Query OK, 2 rows affected (0.00 sec)



『 MySQL数据库 』表的增删查改(CRUD)之表的数据插入及基本查询(下)https://developer.aliyun.com/article/1424460

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
19天前
|
存储 人工智能 Cloud Native
云栖重磅|从数据到智能:Data+AI驱动的云原生数据库
在9月20日2024云栖大会上,阿里云智能集团副总裁,数据库产品事业部负责人,ACM、CCF、IEEE会士(Fellow)李飞飞发表《从数据到智能:Data+AI驱动的云原生数据库》主题演讲。他表示,数据是生成式AI的核心资产,大模型时代的数据管理系统需具备多模处理和实时分析能力。阿里云瑶池将数据+AI全面融合,构建一站式多模数据管理平台,以数据驱动决策与创新,为用户提供像“搭积木”一样易用、好用、高可用的使用体验。
云栖重磅|从数据到智能:Data+AI驱动的云原生数据库
|
6天前
|
缓存 关系型数据库 MySQL
MySQL索引策略与查询性能调优实战
在实际应用中,需要根据具体的业务需求和查询模式,综合运用索引策略和查询性能调优方法,不断地测试和优化,以提高MySQL数据库的查询性能。
|
11天前
|
存储 Oracle 关系型数据库
【赵渝强老师】MySQL InnoDB的数据文件与重做日志文件
本文介绍了MySQL InnoDB存储引擎中的数据文件和重做日志文件。数据文件包括`.ibd`和`ibdata`文件,用于存放InnoDB数据和索引。重做日志文件(redo log)确保数据的可靠性和事务的持久性,其大小和路径可由相关参数配置。文章还提供了视频讲解和示例代码。
119 11
【赵渝强老师】MySQL InnoDB的数据文件与重做日志文件
|
21天前
|
SQL 关系型数据库 数据库
国产数据实战之docker部署MyWebSQL数据库管理工具
【10月更文挑战第23天】国产数据实战之docker部署MyWebSQL数据库管理工具
67 4
国产数据实战之docker部署MyWebSQL数据库管理工具
|
11天前
|
缓存 NoSQL 关系型数据库
Redis和Mysql如何保证数据⼀致?
在项目中,为了解决Redis与Mysql的数据一致性问题,我们采用了多种策略:对于低一致性要求的数据,不做特别处理;时效性数据通过设置缓存过期时间来减少不一致风险;高一致性但时效性要求不高的数据,利用MQ异步同步确保最终一致性;而对一致性和时效性都有高要求的数据,则采用分布式事务(如Seata TCC模式)来保障。
47 14
|
14天前
|
SQL 前端开发 关系型数据库
SpringBoot使用mysql查询昨天、今天、过去一周、过去半年、过去一年数据
SpringBoot使用mysql查询昨天、今天、过去一周、过去半年、过去一年数据
46 9
|
16天前
|
缓存 监控 关系型数据库
如何优化MySQL查询速度?
如何优化MySQL查询速度?【10月更文挑战第31天】
44 3
|
19天前
|
关系型数据库 分布式数据库 数据库
云栖大会|从数据到决策:AI时代数据库如何实现高效数据管理?
在2024云栖大会「海量数据的高效存储与管理」专场,阿里云瑶池讲师团携手AMD、FunPlus、太美医疗科技、中石化、平安科技以及小赢科技、迅雷集团的资深技术专家深入分享了阿里云在OLTP方向的最新技术进展和行业最佳实践。
|
18天前
|
存储 缓存 固态存储
怎么让数据库查询更快
【10月更文挑战第28天】
25 2
|
20天前
|
存储 缓存 关系型数据库
怎么让数据库查询更快
【10月更文挑战第25天】通过以上综合的方法,可以有效地提高数据库查询的速度,提升应用程序的性能和响应速度。但在优化过程中,需要根据具体的数据库系统、应用场景和数据特点进行合理的调整和测试,以找到最适合的优化方案。
下一篇
无影云桌面