MySQL数据库入门——浅析 视图和事务

==========视图============mysql

数据库中的虚拟表,至关于软连接sql

做用:一张表中的数据给不一样的权限用户提供访问数据库


假设一张表:ide

公司员工绩效工资考核表云计算

工号     姓名     年龄      岗位                   绩效        工资spa

1      Tom         50         总裁                                 100万事务

2      Jerry         42         总监                  90           20万内存

3      charry      30         云计算工程师     80           12万资源

4      Jack         24         云计算工程师     90           15万it


语法:create view 视图名称 as  (可加)select 语句


建立查找成绩大于80 的表造成 视图

create view score_view as select * from info where score >80;


修改视图也是意味着修改表

update score_view set score=88 where name='lisi';


==========事务============

数据库事务(Database Transaction) ,是指做为单个逻辑工做单元执行的一系列操做,要么彻底地执行,要么彻底地不执行。 事务处理能够确保除非事务性单元内的全部操做都成功完成,不然不会永久更新面向数据的资源。经过将一组相关操做组合为一个要么所有成功要么所有失败的单元,能够简化错误恢复并使应用程序更加可靠。


一个逻辑工做单元要成为事务,必须知足所谓的ACID(原子性、一致性、隔离性和持久性)属性。事务是数据库运行中的逻辑工做单位,由DBMS中的事务管理子系统负责事务的处理。


一组操做共同执行或者都不执行,结果保持一致。


假设举例:银行转帐

姓名                余额          【条件是余额必定要大于0】

zhangsan       100

lisi                  200


假设操做:zhangsan转帐100给lisi  (操做是不成立的)


银行数据库转帐的执行过程语句:

begin   #开始

update bank set money=money-100 where name=‘zhangsan’

update bank set money=money+100 where name=‘lisi’

rollback   #回滚

commit    #提交

#由于zhangsan的帐户余额不能等于0,因此语句不成立,直接执行rollback   #回滚。


原理:只要有一条语句不能执行成功就回滚

要么执行,保持结果一致性,

要么就是回滚到begin最开始的时候(内存中进行的操做),都不执行


set命令:

set autocommit=0    #禁止自动提交  等同于begin

set autocommit=1     #开启自动提交 


在begin事务操做中

savepoint s1;      #至关于快照,保存当前的mysql操做

rollback to savepoint s1;      #回滚到以前的保存点

commit;    #一旦提交就不可更改

相关文章
相关标签/搜索