Mysql_6 SQL 语句——DML

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 学习自b站骆昊jackfrued 老师的网课以及黑马网课。

学习自b站骆昊jackfrued 老师的网课以及黑马网课。

插入

insert into `表名` values (对应字段值)(对应字段值)(对应字段值);//写多个括号,可以一次填写多行
insert into `表名` (要填写的字段) values (对应字段值); //省略不写的一定是有默认值的或者可以非空的

注意:对应字段值一定要和字段相匹配。如果有默认值的字段也不要省略不写,要写上 default ,不然系统也难以分辨哪一项使用默认值。

日期可以写字符串 2002-01-01,会自动转换

插入完后显示:1 row(s) affected(如果写了多个括号,一次插入多行,会显示多个 row(s) affected)是影响了几行的意思。

如果主键、unique 的记录重复会报错。报错显示: duplicate key for key '定义的约束键名称'

填写了规定的 check 以外的内容会报错。报错显示:check constraint '定义的约束键名称' is violated. 不过字符串不区分大小写,规定性别只能填 'F' 'M' 的话,填 'f' 'm' 也行。

如果对应的外键在原表中没有对应的记录会报错。 报错显示:cannot add or update a child row: a foreign constraint fails 比如学生表的学院号参照了学院表,但是有学院表中不存在的学院号时。

如果没有给 NOT NULL且没有默认值的字段赋值时会报错。 报错显示:Field '字段名' doesn't have a default value. 尽量不要出现空列,之后处理空值会带来很多麻烦。哪怕用空字符串、0、1代替也更好一些。

删除

delete from `表名`;//这可不兴用啊!
delete from `表名` where `字段名`='要删除的记录的对应字段值';//不等于可以用<>,有的 DBMS 支持!=
delete from `表名` where `字段名` = '字段值' or `字段名` = '字段值';//删除多条语句
delete from `表名` where `字段名` in ('字段值','字段值');//删除多条语句

但是如果要删除的这条记录在其他表里是外键,就无法删除。报错显示: Cannot delete or update a parent row

删除了外键约束之后就可以随意修改两个表对应的值而不报错了。

另一种删除表的方式是:

truncate table `表名`;

截断表,这个比 delete 还要危险。delete 了表之后,如果有日志,还是可以找回原数据的。截断就算有日志也没法恢复。

更新

update `表名` set `列名` = '值';//把这一列的数据全都改成这个值,不常用
update `表名` set `列名` = '值',`列名` = '值',`列名` = '值' where `字段`='值';//限制条件,只修改某几个记录
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
21天前
|
SQL 关系型数据库 MySQL
|
1月前
|
SQL 运维 关系型数据库
MySQL 运维 SQL 备忘
MySQL 运维 SQL 备忘录
46 1
|
1月前
|
SQL 存储 关系型数据库
SQL文件导入MySQL数据库的详细指南
数据库中的数据转移是一项常规任务,无论是在数据迁移过程中,还是在数据备份、还原场景中,导入导出SQL文件显得尤为重要。特别是在使用MySQL数据库时,如何将SQL文件导入数据库是一项基本技能。本文将详细介绍如何将SQL文件导入MySQL数据库,并提供一个清晰、完整的步骤指南。这篇文章的内容字数大约在
168 1
|
22天前
|
SQL 关系型数据库 MySQL
MySql5.6版本开启慢SQL功能-本次采用永久生效方式
MySql5.6版本开启慢SQL功能-本次采用永久生效方式
34 0
|
22天前
|
SQL 关系型数据库 MySQL
mysql编写sql脚本:要求表没有主键,但是想查询没有相同值的时候才进行插入
mysql编写sql脚本:要求表没有主键,但是想查询没有相同值的时候才进行插入
31 0
|
1月前
|
SQL 存储 关系型数据库
mysql 数据库空间统计sql
mysql 数据库空间统计sql
46 0
|
1月前
|
SQL 存储 关系型数据库
mysql SQL必知语法
本文详细介绍了MySQLSQL的基本语法,包括SELECT、FROM、WHERE、GROUPBY、HAVING、ORDERBY等关键字的使用,以及数据库操作如创建、删除表,数据类型,插入、查询、过滤、排序、连接和汇总数据的方法。通过学习这些内容,读者将能更好地管理和操
17 0
|
1月前
|
SQL 分布式计算 关系型数据库
Hadoop-24 Sqoop迁移 MySQL到Hive 与 Hive到MySQL SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
Hadoop-24 Sqoop迁移 MySQL到Hive 与 Hive到MySQL SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
86 0
|
SQL 存储 缓存
一文搞懂MySQL中一条SQL语句是如何执行的
一文搞懂MySQL中一条SQL语句是如何执行的
|
存储 SQL 缓存
【Mysql】执行sql语句后,mysql都做了什么?
【Mysql】执行sql语句后,mysql都做了什么?
【Mysql】执行sql语句后,mysql都做了什么?
下一篇
无影云桌面