当前位置: 首页 > news >正文

网站建设商城模板下载wordpress程序 wp

网站建设商城模板下载,wordpress程序 wp,邯郸公司起名,万众城网站建设MySQL 中的事务是由存储引擎实现的。在 MySQL 中,只有 InnoDB 存储引擎支持事务。事务处理可用于维护数据库的完整性,确保批处理的 SQL 语句要么执行要么根本不执行。事务用于管理 DDL、DML 和 DCL 操作,例如插入、更新和删除语句&#xff0c…

MySQL 中的事务是由存储引擎实现的。在 MySQL 中,只有 InnoDB 存储引擎支持事务。事务处理可用于维护数据库的完整性,确保批处理的 SQL 语句要么执行要么根本不执行。事务用于管理 DDL、DML 和 DCL 操作,例如插入、更新和删除语句,这些语句默认是自动提交的。

 

例如,在银行转账时,必须保证转账绝对安全,这时需要事务参与:

update account set money = money - 200 where id = 1; 
update account set money = money + 200 where id = 2;

假如在第一次update之后,出现了意外、异常,没有执行第二次update,这时,转账会出现异常。

一、操作

MySQL的事务操作主要有以下三种:

1. 开启事务:Start Transaction

任何DML语句(insert、update、delete)被执行,标志着事务的开启。

BEGIN;
-- 或
START TRANSACTION;

2. 提交事务:Commit Transaction

成功完成后,所有DML语句操作历史记录和底层硬盘数据将同步一次。

COMMIT;

3. 回滚事务:Rollback Transaction

失败结束时,清除所有DML语句操作历史记录。

ROLLBACK;

之前所有的SQL操作其实都是有事务的,只是MySQL自动帮我们完成了。 每次执行 SQL 时,MySQL 都会自动为我们提交事务。 因此,如果要手动控制事务,就必须关闭MySQL的事务自动提交。

在 MySQL 中直接使用 SET 来改变 MySQL 的自动提交模式:

set autocommit=0; --禁止自动提交 
set autocommit=1; --开启自动提交 
create database if not exists mydb12_transcation;
use mydb12_transcation;
-- 创建账户表
create table account(id int primary key, -- 账户idname varchar(20), -- 账户名money double -- 金额
);--  插入数据
insert into account values(1,'zhangsan',1000);
insert into account values(2,'lisi',1000);-- 设置MySQL的事务为手动提交(关闭自动提交)
select @@autocommit;
set autocommit = 0;-- 模拟账户转账
-- 开启事务 
begin;
update account set money = money - 200 where name = 'zhangsan';
update account set money = money + 200 where name = 'lisi';
-- 提交事务
commit;-- 如果转账中的任何一条出现问题,则回滚事务
rollback;

二、特性

三、隔离级别

隔离(Isolate)顾名思义,就是将一个事务与另一个事务隔离开来,为什么要隔离呢? 如果一个事务正在操作的数据被另一个事务修改或删除,最终的执行结果可能不符合预期。 不这样做可能会导致其他问题。

读未提交(Read uncommitted):一个事务可以读取另一个未提交事务的数据。在最底层,任何情况下都没有保证,会造成脏读。

读已提交(Read committed):一个事务只有在另一个事务提交后才能读取数据,这样可以避免脏读导致不可重复读。

可重复读(Repeatable read):即在读取数据时(事务启动),不再允许修改操作,可以避免脏读和不可重复读的发生,但会造成幻读。

串行(Serializable):是最高的事务隔离级别。在这个层次下,事务是串行和顺序执行的,可以避免脏读、不可重复读和幻读。但是这种事务隔离级别效率低,对数据库性能消耗较大,所以一般不使用。

MySQL 的默认隔离级别是Repeatable read。

-- 查看隔离级别 
show variables like '%isolation%'; /*
设置隔离级别
set session transaction isolation level 级别字符串
级别字符串:read uncommitted、read committed、repeatable read、serializable
*/-- 设置read uncommitted
set session transaction isolation level read uncommitted;-- 设置read committed
set session transaction isolation level read committed;-- 设置repeatable read
set session transaction isolation level repeatable read;-- 设置serializable
set session transaction isolation level serializable;
http://www.yayakq.cn/news/665915/

相关文章:

  • 购物网站源码下载wordpress 好的插件
  • 陕西网站开发企业泉州seo按天扣费
  • 如何制作史莱姆 简单江门17年seo优化技术软件
  • 关注城市建设网站wordpress 分类目录404
  • 南昌网站设计特色网站版块策划
  • wordpress建图片站微商城网站建设策划方案
  • cnzz统计代码如何添加到网站上去露兜博客 wordpress
  • 网站服务器和vps做一台专业设计vi公司
  • 关于干外贸的一些好的学习网站如何给网站划分栏目
  • 网站建设网站多少钱做别人一样的网站模板
  • 中石化第四建设有限公司网站给网站网站做推广犯法
  • 石家庄网站定制制作wordpress 抛弃php
  • 网站优化需要哪些工具商品推广软文800字
  • 甘肃手机网站建设外贸平台是做什么的
  • 海淀网站开发公司百度权重从1提升到2的办法
  • 有的网站为什么打不开怎么回事济宁市建设局网站
  • 深圳网站建设制作公司wordpress写代码编辑器
  • 太原网站排名公司个人简介html代码简单
  • 做网站通常又什么开发完成网站平台建设流程
  • 网站开发搭建合同wordpress模板底部
  • 做视频网站每部电影都要版权重庆网站推广产品企业
  • 网站怎样自己不花钱在电脑上做网页北京南站到北京站
  • 亿藤互联网站建设开发制度建设对网站管理的重要性
  • 网站排名优化原理可编辑wordpress主题
  • 现代企业网站建设特点湛江网站建设优化推广
  • 有没有只做软装方案收设计费的网站wordpress怎么弄会员
  • 企业中英文网站开发wordpress网站可以显示中文和英文
  • 黑客如何攻击网站前端网站开发一个月多少钱
  • 连云港做网站公司wordpress正文宽度
  • 网站301跳转代码硬件开发是什么意思