MySQL-DML之数据表操作

文章目录

  • [一. 插入表记录](#一. 插入表记录)
    • [1. 向表中插入部分字段](#1. 向表中插入部分字段)
    • [2. 向表中插入所有字段,字段的顺序为创建表时的顺序](#2. 向表中插入所有字段,字段的顺序为创建表时的顺序)
    • [3. 一次添加多条数据信息](#3. 一次添加多条数据信息)
  • [二. 更新表记录](#二. 更新表记录)
    • [1. 更新所有记录的指定字段](#1. 更新所有记录的指定字段)
  • 更新符号条件记录的指定字段
    • [2. 更新符号条件记录的指定字段](#2. 更新符号条件记录的指定字段)
  • [三. 删除表记录](#三. 删除表记录)
    • [1. 按条件删除记录](#1. 按条件删除记录)
    • [2. 清空记录](#2. 清空记录)
  • [四. SQL约束](#四. SQL约束)
    • [1. 主键约束](#1. 主键约束)
      • [① 添加主键约束](#① 添加主键约束)
        • [Ⅰ. 创建表时,在字段描述处,声明指定字段为主键](#Ⅰ. 创建表时,在字段描述处,声明指定字段为主键)
        • [Ⅱ. 创建表后,指定字段为主键](#Ⅱ. 创建表后,指定字段为主键)
      • [② 删除主键约束](#② 删除主键约束)
    • [2. 自动增长](#2. 自动增长)
    • [3. 非空约束](#3. 非空约束)
    • [4. 唯一约束](#4. 唯一约束)
    • [5. 默认值约束](#5. 默认值约束)

数据操作语言:简称DML(Data Manipulation Language)

一. 插入表记录

1. 向表中插入部分字段

格式:insert into 表 (字段1,字段2,字段3...) values(值1,值2,值3...);

powershell 复制代码
insert into  category2(cid, cname) values('c001','电器');

2. 向表中插入所有字段,字段的顺序为创建表时的顺序

格式:insert into 表 values(值1,值2,值3...);

powershell 复制代码
insert into category2 values('c002','服饰',2);

3. 一次添加多条数据信息

格式:insert into 表 (字段1,字段2,字段3...) values(值1,值2,值3...),(值1,值2,值3...)...;

powershell 复制代码
insert into category2 (cid, cname) values('03','化妆品'),('04','书籍'),('05',null);

格式:insert into 表 values(值1,值2,值3...),(值1,值2,值3...),...;

powershell 复制代码
insert into category2 values('06','玩具',4),('07','蔬菜',5); 

二. 更新表记录

1. 更新所有记录的指定字段

将所有行的cname改为'家电'

powershell 复制代码
update category2 set cname  = '家电';

更新符号条件记录的指定字段

格式:update 表名 set 字段名=值,字段名=值,... where 条件;

将cid为c001的cname修改为水果

powershell 复制代码
update category2 set cname  = '水果' where cid = 'c001'; 

注意:

1、列名的类型与修改的值要一致.

2、修改值得时候不能超过最大长度.

3、除了数值类型外,其它的字段类型的值必须使用引号引起

2. 更新符号条件记录的指定字段

三. 删除表记录

1. 按条件删除记录

格式:delete from 表名 [where 条件];

删除cid为005的纪录

powershell 复制代码
delete from category where cid = '005'; 

2. 清空记录

格式:delete from 表名;

格式:truncate table 表名;

清空表数据

powershell 复制代码
delete from category;
truncate category;

注意:

清空表记录和删除表记录的区别:

使用delete删除表记录时,主键自增序列不清零。

使用truncate删除表记录时,主键自增序列清零。

四. SQL约束

1. 主键约束

1、PRIMARY KEY 约束唯一标识数据库表中的每条记录。

2、主键必须包含唯一的值。

3、主键列不能包含 NULL 值。

4、每个表都应该有一个主键,并且每个表只能有一个主键。
遵循原则:

1)主键应当是对用户没有意义的

2)永远也不要更新主键。

3)主键不应包含动态变化的数据,如时间戳、创建时间列、修改时间列等。

4) 主键应当由计算机自动生成。

① 添加主键约束

Ⅰ. 创建表时,在字段描述处,声明指定字段为主键

创建表时,在字段描述处,声明指定字段为主键:


Ⅱ. 创建表后,指定字段为主键
powershell 复制代码
alter table person1 add primary key(id);

② 删除主键约束

如需撤销 PRIMARY KEY 约束,请使用下面的 SQL

powershell 复制代码
alter table persons1 drop primary key ;

2. 自动增长

我们通常希望在每次插入新记录时,数据库自动生成字段的值。

我们可以在表中使用 auto_increment(自动增长列)关键字,自动增长列类型必须是整型,自动增长列必须为键(一般是主键)。

下列 SQL 语句把 "persons2" 表中的 "id" 列定义为 auto_increment 主键


向persons添加数据时,可以不为Id字段设置值,也可以设置成null,数据库将自动维护主键值:

powershell 复制代码
insert into persons2(first_name,last_name) values('Bill','Gates');insert into persons2(id,first_name,last_name) values(null,'Bill','Gates');

3. 非空约束

NOT NULL 约束强制列不接受 NULL 值。

NOT NULL 约束强制字段始终包含值。这意味着,如果不向字段添加值,就无法插入新记录或者更新记录。

下面的 SQL 语句强制 "id" 列和 "last_name" 列不接受 NULL 值:

4. 唯一约束

UNIQUE 约束唯一标识数据库表中的每条记录。

UNIQUE 和 PRIMARY KEY 约束均为列或列集合提供了唯一性的保证。

PRIMARY KEY 拥有自动定义的 UNIQUE 约束。

请注意:

每个表可以有多个 UNIQUE 约束,但是每个表只能有一个 PRIMARY KEY 约束。

5. 默认值约束

默认 DEFAULT: 当不填写字段对应的值会使用默认值,如果填写时以填写为准

相关推荐
摘星怪sec24 分钟前
【漏洞复现】|方正畅享全媒体新闻采编系统reportCenter.do/screen.do存在SQL注入
数据库·sql·web安全·媒体·漏洞复现
基哥的奋斗历程33 分钟前
学到一些小知识关于Maven 与 logback 与 jpa 日志
java·数据库·maven
苏-言41 分钟前
MyBatis最佳实践:提升数据库交互效率的秘密武器
数据库·mybatis
gyeolhada1 小时前
计算机组成原理(计算机系统3)--实验八:处理器结构拓展实验
java·前端·数据库·嵌入式硬件
码农丁丁1 小时前
为什么数据库不应该使用外键
数据库·mysql·oracle·数据库设计·外键
随心Coding3 小时前
【MySQL】存储引擎有哪些?区别是什么?
数据库·mysql
m0_748237054 小时前
sql实战解析-sum()over(partition by xx order by xx)
数据库·sql
dal118网工任子仪5 小时前
61,【1】BUUCTF WEB BUU XSS COURSE 11
前端·数据库·xss
萌小丹Fighting6 小时前
【Postgres_Python】使用python脚本批量创建和导入多个PG数据库
数据库
青灯文案16 小时前
Oracle 数据库常见字段类型大全及详细解析
数据库·oracle