JavaWeb_Day4

今日内容

1. 多表查询
2. 事务
3. DCL

多表查询 :

* 查询语法 :
	select
		列名列表
	from
		表名列表
	where...
* 准备SQL
	# 创建部门表
	CREATE TABLE dept(
		id INT PRIMARY KEY AUTO_INCREMENT,
		NAME VARCHAR(20)
	);
	INSERT INTO dept (NAME) VALUES ('开发部'),('市场部'),('财务部');
	# 创建员工表
	CREATE TABLE emp(
		id INT PRIMARY KEY AUTO_INCREMENT,
		NAME VARCHAR(10),
		gender CHAR(1), -- 性别
		salary DOUBLE, -- 工资
		join_date DATE, -- 入职日期
		dept_id INT,
		FOREIGN KEY (dept_id) REFERENCES dept(id) -- 外键,关联部门表(部门表的主键)
	);
	INSERT INTO emp(NAME,gender,salary,join_date,dept_id) VALUES('Sloth','男',7200,'2013-02-24',1);
	INSERT INTO emp(NAME,gender,salary,join_date,dept_id) VALUES('Envy','男',4600,'2010-02-24',1);
	INSERT INTO emp(NAME,gender,salary,join_date,dept_id) VALUES('Last','女',3300,'2013-06-24',2);
	INSERT INTO emp(NAME,gender,salary,join_date,dept_id) VALUES('Blade','男',5200,'2015-02-24',1);
	INSERT INTO emp(NAME,gender,salary,join_date,dept_id) VALUES('W','女',3500,'2013-03-24',3);
* 笛卡尔积 :
	* 有两个集合A,B取这两个集合的所有组成情况
	* 要完成多表查询,需要消除无用的数据
* 多表查询的分类 :
	1. 内连接查询 :
		1. 隐式内连接 :使用where条件消除无用数据
			* 例子
			-- 查询所有员工信息和对应的部门信息
			SELECT * FROM emp,dept WHERE emp.`dept_id` = dept.`id`;
			-- 查询员工表的名称,性别,部门表的名称
			SELECT emp.`name`,emp.`gender`,dept.`NAME` FROM emp,dept WHERE emp.`dept_id` = dept.`id`;
			
			SELECT
				t1.`name`, -- 员工表的姓名
				t1.`gender`, -- 员工表的性别
				t2.`NAME` -- 部门表的名称
			FROM
				emp t1,
				dept t2
			WHERE
				t1.`dept_id` = t2.`id`;
		2. 显式内连接 :
			* 语法 :select 字段列表 from 表名1 [inner] join 表名2 on 条件;
			* 例如 :
				* SELECT * FROM emp INNER JOIN dept ON emp.`dept_id` = dept.`id`;
				* SELECT * FROM emp JOIN dept ON emp.`dept_id` = dept.`id`;
		3. 内连接查询 :
			1. 从哪些表中查询数据
			2. 条件是什么
			3. 查询哪些字段
	2. 外连接查询 :
		1. 左外连接 :
			* 语法 :select 字段列表 from 表1 left [outer] join 表2 on 条件;
			* 查询的是左表所有数据以及其交集部分
		2. 右外连接 :
			* 语法 :select 字段列表 from 表1 right [outer] join 表2 on 条件;
			* 查询的是右表所有数据以及其交集部分
			* 例如
			-- 查询所有员工信息,如果员工有部门,则查询部门名称,没有部门,则不显示部门名称
			SELECT
				t1.*,t2.`NAME`
			FROM
				emp t1
			LEFT JOIN
				dept t2
			ON
				t1.`dept_id` = t2.`id`;
	3. 子查询 :
		* 概念 :查询中嵌套查询,称嵌套查询为子查询
		* 子查询的不同情况
			1. 子查询的结果是单行单列的 :
				* 子查询可以作为条件,使用运算符去判断。 运算符 :> >= <= < = !=
				* select 查询内容(列名) from 表名 where 判断内容 运算符 sql子语句;
			2. 子查询的结果是多行单列的 :
				* 子查询可以作为条件,使用运算符in来判断
				-- 查询'财务部'和'市场部'所有的员工信息
				SELECT id FROM dept WHERE NAME = '财务部' OR NAME = '市场部';
				SELECT * FROM emp WHERE dept_id = 3 OR dept_id = 2;
				-- 子查询
				SELECT * FROM emp WHERE dept_id IN (SELECT id FROM dept WHERE NAME = '财务部' OR NAME = '市场部');
			3. 子查询的结构是多行多列的 :
				* 子查询可以作为一张虚拟表参与查询
				-- 查询员工入职日期是2011-11-11日之后的员工信息和部门信息
				-- 子查询
				SELECT * FROM dept t1,(SELECT * FROM emp WHERE emp.`join_date` > '2011-11-11') t2 WHERE t1.id = t2.dept_id;
				-- 普通内连接
				SELECT * FROM dept t2,emp t1 WHERE t1.`dept_id` = t2.`id` AND t1.`join_date` > '2011-11-11';

事务

1. 事务的基本介绍
	1. 概念 :
		* 如果一个包含多个步骤的业务操作,被事务管理,那么这些操作要么同时成功要么同时失败。
	2. 操作 :
		1. 开启事务 :start transaction;
		2. 回滚 :rollback;
		3. 提交 :commit;
		4. MySQL数据库中事务默认自动提交
			* 事务提交的两种方式 :
				* mysql就是自动提交的
				* 一条DML(增删改)语句会自动提交一次事务
			* 手动提交 :
				* Oracle 数据库默认是手动提交事务
				* 需要先开启事务,再提交
			* 修改事务的默认提交方式 :
				* 查看事务的默认提交方式 :SELECT @@autocommit; -- 1 代表自动提交 0 代表手动提交
				* 修改默认提交方式 set @@autocommit = 0;
2. 事务的四大特征
	1. 原子性 :是不可分割的最小操作单位,要么同时成功,要么同时失败
	2. 持久性 :当事务提交或回滚后,数据库会持久化地保存数据。
	3. 隔离性 :多个事务之间。相互独立。
	4. 一致性 :事务操作前后,数据总量不变
3. 事务的隔离级别(了解)
	* 概念 :多个事务之间隔离的,相互独立的。但是如果多个事务操作同一批数据,则会引发一些问题,设置不同的隔离级别就可以解决这些问题。
	* 存在问题 :
		1. 脏读 : 一个事务,读取到另一个事务中没有提交的数据
		2. 不可重复读(虚读) :在同一个事务中,两次读取到的数据不一样
		3. 幻读 :一个事务操作(DML)数据表中所有记录,另一个事务添加了一条数据,则第一个事务查询不到自己的修改。
	* 隔离级别 :
		1. read uncommitted : 读未提交
			* 解决上述存在问题 :无
		2. read committed :读已提交 (Oracle默认)
			* 解决上述存在问题 :脏读
		3. repeatable read :可重复读 (MySQL默认)
			* 解决上述存在问题 :不可重复读、脏读
		4. serializable : 串行化
			* 解决上述存在问题 :全部
			
		* 注意 :隔离级别从小到大安全性越来越高,但效率越来越低
		* 数据库查询隔离级别 :
			* select @@tx_isolation;
		* 数据库设置隔离级别 :
			* set global transaction isolation level 级别字符串;

DCL

* SQL分类 :
	1. DDL :操作数据库和表
	2. DML :增删改表中数据
	3. DQL :查询表中数据
	4. DCL :管理用户,授权

* DBA :数据库管理员
* DCL :管理用户,授权
	1. 管理用户
		1. 添加用户 :
			* 语法 :create user '用户名'@'主机名' identified by '密码';
		2. 删除用户 :
			* 语法 :drop user '用户名'@'主机名';
		3. 修改用户密码 :
			* update user set password = password ('新密码') where user = '用户名';
			* set password for '用户名'@'主机名' = password('新密码');
			* 在mysql中忘记root用户的密码?
				1. cmd -- > net stop mysql 停止mysql服务
					* 需要管理员运行该cmd
				2. 使用无验证方式启动mysql服务 :mysqld -- skip-grant-tables
				3. 打开新的cmd窗口,直接输入mysql命令,敲回车。就可以登录成功
				4. use mysql;
				5. update user set password = password('新密码') where user = 'root';
				6. 关闭两个窗口
				7. 打开任务管理器,手动结束mysqld.exe的进程
				8. 启动mysql服务
				9. 使用新密码登录
		4. 查询用户 :
			-- 1. 切换到MySQL数据库
			USE mysql;
			-- 2. 查询user表
			select * from user;
			* 通配符 :% 表示可以在任意主机使用用户登录数据库

	2. 授权管理 :
		1. 查询权限 :
			-- 查询权限
			show grants for '用户名'@'主机名';
			show grants for 'lisi'@'%';
		2. 授予权限 :
			-- 授予权限
			grant 权限列表 on 数据库名.表名 to '用户名'@'主机名';
			-- 给张三用户授予所有权限,在任意数据库任意表上
			grant all on *.* to 'zhangsan'@'localhost';
		3. 撤销权限 :
			-- 撤销权限 :
			revoke 权限列表 on 数据库名.表名 from '用户名'@'主机名';
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值