Mysql数据库,增删改查笔记(非常重要)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: Mysql数据库,增删改查笔记(非常重要) 新增数据: INSERT 语法: INSERT [INTO] <表名>[列名] VALUES<值列表>; INSETR INTO 表名(列名1,列名2) VALUES(值1,值2); 如果INSETR语句中不写列名,则默认是向表中的所有字段添加值。

Mysql数据库,增删改查笔记(非常重要)

新增数据:

INSERT

语法:

INSERT [INTO] <表名>[列名] VALUES<值列表>;

INSETR INTO 表名(列名1,列名2) VALUES(值1,值2);

如果INSETR语句中不写列名,则默认是向表中的所有字段添加值。

(此时输入数据数量要等同于列的数量,否则会报错,数据库对插入的数据是否有效进行了完整的校验)

字符串需要以‘’或者“”“”来括起

字符会自动转换成数字插入

 

INSERT INTO SELECT

INSERT [INTO] <表名>[列名] SELECT [源列名] FROM <源表名>;

INSERT INTO 表名 (列名1,列名2) SELECT 源列名1,源列名2 FROM 源表名;

 

1.每次插入一行数据,不可能只插入半行或者几列数据,因此,插入的数据是否有效将按照整行的完整性的要求来检验

INSERT INTO students (s_id,s_name,age) VALUES (‘小明')

2.每个数据值的数据类型、精度和小数位数必须与相应的列匹配

insert into students(s_id,s_name,age) values(1001,123, 'asd');

insert into students(s_id,s_name,age) values(1001,123, '100');

insert into students(s_id,s_name,age) values(1001,123, '255');

3.如果在设计表的时候就指定了某列不允许为空,则必须插入数据;

insert into students(s_id) values(1001); 错误

4.具有缺省值的列,可以使用DEFAULT(缺省)关键字来代替插入的数值

 

常见错报错类型:

[Err] 1136  - Column cout doesn't match value count at row 1

INSERT语句中没有输入列名且列多值少 报错 数据库对插入的数据是否有效进行了完整性的校验

[Err] 1265 - Data truncated for column '...' at row 1

数值类型或长度不符合列名设置

[Err] 1364 -Field 's_name' doesn't have a default value 

如果字段设置了 NOT NULL 则必须插入。或者设置DEFAULT值

修改数据

UPDATE

语法: 

UPDATE <表名> SET <列名 = 更新值> [WHERE <更新条件>]

UPDATE 表名 SET 列名1=值1,列名2=值2 .... WHERE 列名=值;

不带where条件会导致全量更新

叙述:

where 子句是判断语句,用来设定条件,限制只更新匹配的行,如果 不带where子句,则更新所有行数据。

例如:

update students set age=23,height=185 where s_name='火狐';

删除数据

DELETE

语法:

DELETE FROM <表名> [WHERE <更新条件>]

叙述:

此语句删除表中的行,如果不带where子句,则删除整个表中的记录 但是表不被删除

 

DELETE FROM <表名>; 删除表里的所有数据,表结构还在。

TRUNCATE TABLE <表名>; 删除表里的所有数据,但不会显示删除的数据行数,不能够做筛选。直接进行整表删除,表结构还在。

DORP TABLE <表名>; 删除表。表结构不存在。

查询数据

SELECT

语法:

SELECT <列名> FROM <表名> [WHERE <查询表达式>];

1、查询学生的学号(s_id) ,姓名(s_name)

SELECT s_id,s_name FROM students; 

2、查询姓名为‘CMCC’的学号和性别信息

SELECT s_id,s_sex FROM students WHERE s_name='CMCC';

3、查询表里的所有列 (使用*号)

方法1:SELECT * FROM students; // 用*表示所有列

方法2:SELECT s_id,s_name,age,height,sex,class_id,birthday,s_desc FROM students; // 把所有列的列举出来

4、给列起别名:SELECT 列名1 [AS] 列别名1,列名2 [AS] 列别名2... FROM 表名;

SELECT s_name AS ‘学员姓名’,s_id AS ‘学员编号’ FROM students;

5、给表起别名: SELECT 表别名.列名1.列名2 FROM 表名 表别名;

SELECT s.s_id,s.s_name FROM students s;

补充:

MySQL中使用SQL语言几点说明

属于一个SQL语句,使用分号(;)结尾,否则mysql认为语句没有输入完。

箭头(->)代表SQL语句没有输入完

取消SQL语句使用(\c)

SQL语句关键字和函数名不区分大小写(Linux区分,Windows不区分)

使用函数时,函数名和后面的括号之间不能有空格

说明:

表和字段的引用方式有两种:绝对引用和相对引用

绝对引用:数据库名.表名(.字段名)

mysql> select school.students.s_name from school.students;

相对引用:表名.(字段名)

mysql> select students.s_name from school.students;

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1月前
|
SQL 关系型数据库 MySQL
【MySQL】基本查询(表的增删改查)-- 详解(上)
【MySQL】基本查询(表的增删改查)-- 详解(上)
|
1月前
|
SQL 存储 关系型数据库
Mysql优化提高笔记整理,来自于一位鹅厂大佬的笔记,阿里P7亲自教你
Mysql优化提高笔记整理,来自于一位鹅厂大佬的笔记,阿里P7亲自教你
|
11天前
|
SQL 安全 API
Python基础教程(第3版)中文版 第13章 数据库支持(笔记)
Python基础教程(第3版)中文版 第13章 数据库支持(笔记)
|
24天前
|
SQL 关系型数据库 MySQL
mysql 数据库 增删改查 基本操作
mysql 数据库 增删改查 基本操作
|
1月前
|
存储 SQL 关系型数据库
MySQL万字超详细笔记❗❗❗
MySQL万字超详细笔记❗❗❗
92 1
MySQL万字超详细笔记❗❗❗
|
29天前
|
小程序 数据库
一分钟教你学会小程序云开发的数据库的增删改查
本文简要介绍了小程序云开发中数据库的增删改查操作。首先展示了查询代码,通过`wx.cloud.database().collection().get()`获取数据;接着演示添加数据,强调数据字段需与数据库匹配;然后说明删除数据需基于_id,通过`doc(id).remove()`执行;最后,更新数据同样依赖_id,使用`doc(id).update()`进行修改。
26 1
|
1月前
|
存储 关系型数据库 MySQL
【MySQL系列笔记】分库分表
分库分表是一种数据库架构设计的方法,用于解决大规模数据存储和处理的问题。 分库分表可以简单理解为原来一个表存储数据现在改为通过多个数据库及多个表去存储,这就相当于原来一台服务器提供服务现在改成多台服务器组成集群共同提供服务。
57 8
|
18天前
|
关系型数据库 MySQL 数据库
mysql数据库表格的增删改查
mysql数据库表格的增删改查
|
20天前
|
关系型数据库 MySQL 数据库
MySql基础二之【MySql增删改查操作】
MySql基础二之【MySql增删改查操作】
15 0
|
1月前
|
SQL 关系型数据库 MySQL
【MySQL系列笔记】MySQL总结
MySQL 是一种关系型数据库,说到关系,那么就离不开表与表之间的关系,而最能体现这种关系的其实就是我们接下来需要介绍的主角 SQL,SQL 的全称是 Structure Query Language ,结构化的查询语言,它是一种针对表关联关系所设计的一门语言,也就是说,学好 MySQL,SQL 是基础和重中之重。SQL 不只是 MySQL 中特有的一门语言,大多数关系型数据库都支持这门语言。
259 8

热门文章

最新文章