MySQL数据库(日结)

1、为什么进行数据库备份?

数据库故障

突然断电

病毒入侵

误操作导致数据丢失


2、索引有:

主键索引:唯一性;非空;只能存在一个。

唯一索引:唯一性;允许为空;可以存在多个。

常规索引

全文索引:表类型--MYISAM;你要设置为全文索引的字段,必须是字符串--char、varchar、text表类型:INNODB---支持事务;MyISAM----全文索引。创建表时默认表类型为INNODB


3、mysql事务处理
①概念:mysql中事务是将一组SQL语句放在同一批次内去执行。
注意:在执行期间,若其中任意n条语句发生错误,则该批次内所有的sql语句都将被取消执行,执行过的sql也将发生回滚。

②.事务的ACID原则
事务的原子性(Atomicity)是指一个事务要么全部执行,要么不执行.也就是说一个事务不可能只执行了一半就停止了.比如你从取款机取钱,这个事务可以分成两个步骤:1划卡,2出钱.不可能划了卡,而钱却没出来.这两步必须同时完成.要么就不完成.

③事务的一致性(Consistency)是指事务的运行并不改变数据库中数据的一致性.例如,完整性约束了a+b=10,一个事务改变了a,那么b也应该随之改变.

④独立性(Isolation):事务的独立性也有称作隔离性,是指两个以上的事务不会出现交错执行的状态.因为这样可能会导致数据不一致.

⑤持久性(Durability):事务的持久性是指事务执行成功以后,该事务所对数据库所作的更改便是持久的保存在数据库之中,不会无缘无故的回滚.


⑥事务的执行步骤:
(1).#关闭自动提交
SET autocommit=0;

(2).#开始事务
START TRANSACTION;

(3).#执行sql语句
UPDATE account SET cash=cash-500 WHERE `name`='A';
#UPDATE account SET cash=cash+500 WHERE `name`='B';

(4).#sql发生意外,回滚
ROLLBACK;
#sql执行成功,提交
COMMIT;

(5).#打开自动提交
SET autocommit=1;

注意:在事务执行过程中,回滚/提交之前,对数据库的更改是临时的。再打开数据库,对此表进行查询时,会发现,表数据依旧是sql执行之前的数据。只有提交/回滚之后的数据才是永久性的!!

⑦支持事务的表类型为INNODB。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值