Mysql命令总结二
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Mysql命令总结二相关的知识,希望对你有一定的参考价值。
数据的各种约束
什么是数据约束:
对用户操作表的数据进行约束 |
默认值约束
作用: 当用户对使用默认值的字段不插入值的时候,就使用默认值。 注意: 1)对默认值字段插入null是可以的。 2)对默认值字段可以插入非null |
|
-- 1.1 默认值 CREATE TABLE student( id INT, NAME VARCHAR(20), address VARCHAR(20) DEFAULT ‘广州天河‘ -- 默认值 )
-- 当字段没有插入值的时候,mysql自动给该字段分配默认值 INSERT INTO student(id,NAME) VALUES(1,‘张三‘);
-- 注意:默认值的字段允许为null INSERT INTO student(id,NAME,address) VALUE(2,‘李四‘,NULL); -- 如果插入了值,默认值就不显示了 INSERT INTO student(id,NAME,address) VALUE(3,‘王五‘,‘广州番禺‘); |
非空约束
作用: 限制字段必须赋值 注意: 1)非空字符必须赋值 2)非空字符不能赋null |
|
-- 1.2 非空 -- 需求: gender字段必须有值(不为null) CREATE TABLE student( id INT, NAME VARCHAR(20), gender VARCHAR(2) NOT NULL -- 非空 )
-- 非空字段必须赋值, INSERT INTO student(id,NAME) VALUES(1,‘李四‘); -- 非空字符不能插入null INSERT INTO student(id,NAME,gender) VALUES(1,‘李四‘,NULL); |
唯一约束
作用: 对字段的值不能重复 注意: 1)唯一字段可以插入null 2)唯一字段可以插入多个null |
|
-- 1.3 唯一 CREATE TABLE student( id INT UNIQUE, -- 唯一 NAME VARCHAR(20) )
INSERT INTO student(id,NAME) VALUES(1,‘zs‘); INSERT INTO student(id,NAME) VALUES(1,‘lisi‘); -- ERROR 1062 (23000): Duplicate entry ‘1‘ for key ‘id‘
INSERT INTO student(id,NAME) VALUES(2,‘lisi‘); |
主键约束
作用: 非空+唯一 注意: 1)通常情况下,每张表都会设置一个主键字段。用于标记表中的每条记录的唯一性。 2)建议不要选择表的包含业务含义的字段作为主键,建议给每张表独立设计一个非业务含义的id字段。 |
|
CREATE TABLE student( id INT PRIMARY KEY, -- 主键 NAME VARCHAR(20) )
INSERT INTO student(id,NAME) VALUES(1,‘张三‘); INSERT INTO student(id,NAME) VALUES(2,‘张三‘); -- INSERT INTO student(id,NAME) VALUES(1,‘李四‘); -- 违反唯一约束: Duplicate entry ‘1‘ for key ‘PRIMARY‘
-- insert into student(name) value(‘李四‘); -- 违反非空约束: ERROR 1048 (23000): Column ‘id‘ cannot be null |
自增加
作用: 自动递增 |
|
-- 1.5 自增长 CREATE TABLE student( id INT(4) ZEROFILL PRIMARY KEY AUTO_INCREMENT, -- 自增长,从0开始 ZEROFILL 零填充 NAME VARCHAR(20) )
-- 自增长字段可以不赋值,自动递增 INSERT INTO student(NAME) VALUES(‘张三‘); INSERT INTO student(NAME) VALUES(‘李四‘); INSERT INTO student(NAME) VALUES(‘王五‘);
-- 不能影响自增长约束,删除的数据后,在添加数据的时候,会在原来的基础上添加上去 DELETE FROM student; -- 可以影响自增长约束 ,删除数据的时候,添加数据时,会重新开始添加,id重0开始算起 TRUNCATE TABLE student; |
外键约束
作用:约束两种表的数据,避免数据的冗余高问题 |
没有外键的情况下:
-- 员工表 CREATE TABLE employee( id INT PRIMARY KEY, empName VARCHAR(20), deptName VARCHAR(20) -- 部门名称 )
INSERT INTO employee VALUES(1,‘张三‘,‘软件开发部‘); INSERT INTO employee VALUES(2,‘李四‘,‘软件开发部‘); INSERT INTO employee VALUES(3,‘王五‘,‘应用维护部‘);
-- 添加员工,部门名称的数据冗余高 INSERT INTO employee VALUES(4,‘陈六‘,‘软件开发部‘); |
|
|
|
-- 解决数据冗余高的问题:给冗余的字段放到一张独立表中 -- 独立设计一张部门表 CREATE TABLE dept( id INT PRIMARY KEY, deptName VARCHAR(20) ) |
|
|
|
问题出现:在插入员工表数据的时候,员工表的部门ID字段可以随便插入!!!!! 使用外键约束:约束插入员工表的部门ID字段值 解决办法: 在员工表的部门ID字段添加一个外键约束 |
|
-- 部门表(主表) CREATE TABLE dept( id INT PRIMARY KEY, deptName VARCHAR(20) )
-- 修改员工表(副表/从表) CREATE TABLE employee( id INT PRIMARY KEY, empName VARCHAR(20), deptId INT,-- 把部门名称改为部门ID -- 声明一个外键约束 CONSTRAINT emlyee_dept_fk FOREIGN KEY(deptId) REFERENCES dept(id) -- 外键名称 外键 参考表(参考字段) )
按照先建立主表,然后建立副表,就可以建立员工表的外键约束了,建立后如图:
|
外键添加数据,修改数据,删除数据
1)被约束的表称为副表,约束别人的表称为主表,外键设置在副表上的!!! 2)主表的参考字段通用为主键! 3)添加数据: 先添加主表,再添加副表 4)修改数据: 先修改副表,再修改主表 5)删除数据: 先删除副表,再删除主表 |
添加主表 INSERT INTO dept(id,deptName) VALUES(1,‘软件开发部‘); INSERT INTO dept(id,deptName) VALUES(2,‘应用维护部‘); INSERT INTO dept(id,deptName) VALUES(3,‘秘书部‘);
添加副表 INSERT INTO employee VALUES(1,‘张三‘,1); INSERT INTO employee VALUES(2,‘李四‘,1); INSERT INTO employee VALUES(3,‘王五‘,2); INSERT INTO employee VALUES(4,‘陈六‘,3); |
添加数据的例子:
-- 问题: 该记录业务上不合法,员工插入了一个不存在的部门数据 INSERT INTO employee VALUES(5,‘陈六‘,4); -- 违反外键约束: Cannot add or update a child row: a foreign key constraint fails
(`day16`.`employee`, CONSTRAINT `emlyee_dept_fk` FOREIGN KEY (`deptId`) REFERENCES `dept` (`id`)) |
级联操作
问题: 当有了外键约束的时候,必须先修改或删除副表中的所有关联数据,才能修改或删除主表!但是,我们希望直接修改或删除主表数据,从而影响副表数据。可以使用级联操作实现!!!
级联修改: ON UPDATE CASCADE 级联删除: ON DELETE CASCADE |
CREATE TABLE employee( id INT PRIMARY KEY, empName VARCHAR(20), deptId INT,-- 把部门名称改为部门ID -- 声明一个外键约束 CONSTRAINT emlyee_dept_fk FOREIGN KEY(deptId) REFERENCES dept(id) ON UPDATE CASCADE ON DELETE CASCADE -- ON CASCADE UPDATE :级联修改 -- 外键名称 外键 参考表(参考字段) ) 注意: 级联操作必须在外键基础上使用 |
-- 级联修改(修改) -- 直接修改部门 UPDATE dept SET id=5 WHERE id=4;
-- 级联删除 -- 直接删除部门 DELETE FROM dept WHERE id=1; |
数据库设计原则:尽量符合三大范式
3.2 三大范式 设计原则: 建议设计的表尽量遵守三大范式。 第一范式: 要求表的每个字段必须是不可分割的独立单元 student : name -- 违反第一范式 张小名|狗娃 sutdent : name old_name --符合第一范式 张小名 狗娃
第二范式: 在第一范式的基础上,要求每张表只表达一个意思。表的每个字段都和表的主键有依赖 employee(员工): 员工编号 员工姓名 部门名称 订单名称 --违反第二范式 员工表:员工编号 员工姓名 部门名称 订单表: 订单编号 订单名称 -- 符合第二范式
第三范式: 在第二范式基础,要求每张表的主键之外的其他字段都只能和主键有直接决定依赖关系。 员工表: 员工编号(主键) 员工姓名 部门编号 部门名 --符合第二范式,违反第三范式 (数据冗余高) 员工表:员工编号(主键) 员工姓名 部门编号 --符合第三范式(降低数据冗余) 部门表:部门编号 部门名 |
关联查询(多表查询)
交叉查询(不推荐)
-- 需求:查询员工及其所在部门(显示员工姓名,部门名称) -- 2.1 交叉连接查询(不推荐。产生笛卡尔乘积现象:4 * 3=12,有些是重复记录) SELECT empName,deptName FROM employee,dept; |
|
内连接查询(推荐使用)
-- 需求:查询员工及其所在部门(显示员工姓名,部门名称) -- 多表查询规则:1)确定查询哪些表 2)确定哪些哪些字段 3)表与表之间连接条件 (规律:连接条件数量是表数量-1) -- 2.2 内连接查询:只有满足条件的结果才会显示(使用最频繁) SELECT empName,deptName -- 2)确定哪些哪些字段 FROM employee,dept -- 1)确定查询哪些表 WHERE employee.deptId=dept.id -- 3)表与表之间连接条件 |
|
|
-- 内连接的另一种语法 SELECT empName,deptName FROM employee INNER JOIN dept ON employee.deptId=dept.id;
-- 使用别名 SELECT e.empName,d.deptName FROM employee e INNER JOIN dept d ON e.deptId=d.id;
|
左连接查询
概念: 使用左边表的数据去匹配右边表的数据,如果符合连接条件的结果则显示,如果不符合连接条件则显示null -- (注意: 左外连接:左表的数据一定会完成显示!) |
|
-- 需求: 查询每个部门的员工 -- 预期结果: -- 软件开发部 张三 -- 软件开发部 李四 -- 应用维护部 王五 -- 秘书部 陈六 -- 总经办 null |
|
INSERT INTO dept VALUES(5,‘总经办‘) SELECT d.deptName,e.empName FROM dept d LEFT OUTER JOIN employee e ON d.id=e.deptId; |
|
右连接查询
-右[外]连接查询: 使用右边表的数据去匹配左边表的数据,如果符合连接条件的结果则显示,如果不符合连接条件则显示null -- (注意: 右外连接:右表的数据一定会完成显示!) SELECT d.deptName,e.empName FROM employee e RIGHT OUTER JOIN dept d ON d.id=e.deptId; |
MySQL权限问题
-- mysql数据库权限问题:root :拥有所有权限(可以干任何事情) -- 权限账户,只拥有部分权限(CURD)例如,只能操作某个数据库的某张表 |
-- mysql数据库,用户配置 : user表 USE mysql;
SELECT * FROM USER; --查看有多少用户 |
-- 修改密码: 需要重新启动服务才能生效 UPDATE USER SET PASSWORD=PASSWORD(‘123456‘) WHERE USER=‘root‘; |
|
-- 分配权限账户:eric 密码:123456 权限是可以对employee表查询和删除的权限 GRANT SELECT ON day16.employee TO ‘eric‘@‘localhost‘ IDENTIFIED BY ‘123456‘; GRANT DELETE ON day16.employee TO ‘eric‘@‘localhost‘ IDENTIFIED BY ‘123456‘; |
以上是关于Mysql命令总结二的主要内容,如果未能解决你的问题,请参考以下文章