1.事务
(1)事务:一个操作序列,这些操作要么都执行,要么都不执行。一组原子性的SQL查询。
(2)事务四大特性(ACID):原子性,一致性,隔离性(一个事务在最终提交之前,对其他事务时不可见的,隔离级别:未提交读,提交读,可重复读),持久性
(3)隔离级别
在sql标准中定义了四种隔离级别,每一种级别都规定了一个事务所做的修改,那些在事务内和事务间是可见的。那些是不可见的,通常较低级别的隔离可以执行更高的并发,系统开销也低。
面试常考
A.未提交读:事务的修改,即使没有提交,对其他事务也都是可见的,事务可以读取未提交的数据,这也被称为“脏读"。
B.提交读:大对数数据库系统默认隔离级别,
C.可重复读:解决脏读的问题,幻读:当某个事务在读取某个范围内的记录时,另外一个事务又在该范围内插入了新的记录,当之前的事务再次读取该范围内的记录时,会产生幻行。
D.可串行化:最高隔离级别,它通过强制事务串行执行,避免了前面说的幻读,只有在非常需要确保数据的一致性而且可以接受没有并发的情况下,才考虑采用该级别。
a 查看会话隔离级别(如果修改会话隔离级别,只能修改会话隔离级别)
SELECT @@SESSION.transaction_isolation;
b 查看系统隔离级别(如果修改系统隔离级别,所有人隔离级别都会发生改变)
SELECT @@GLOBAL.transaction_isolation;
1)开始事务,命令如下:
开启事务后执行修改命令,变更会维护到本地缓存中,而不维护到物理表中
begin;
或者
start transaction;
2)提交事务,命令如下:
将缓存中的数据变更维护到物理表中
commit;
3)回滚事务,命令如下:
rollback;
4)查看数据库引擎
show create table student;
2.视图
(1)概念:一种虚拟存在的表,对于使用视图的用户来说基本上是透明的,视图并不在数据库中实际存放数据,它的数据来自定义视图时使用的基本表,并且是在使用视图时动态生成的。
select * from v_stu_info
(2)为什么要使用视图?
·简化复杂的sql操作,在编写查询后,可以方便的重用它而不必知道它的查询细节。
·重复使用该sql语句。
·使用表的组成部分而不是整个表。
·保护数据,可以给用户授予表的特定部分的访问权限而不是整个表。
·更改数据格式和表示。
(3)创建视图:
(4)删除视图
drop view viewname;
3.索引
索引是一种特殊的文件,塔包含着对数据表里面所有记录的引用指针