位置: 编程技术 - 正文

深入理解MySQL中的事务机制(mysql深度解析)

编辑:rootadmin

推荐整理分享深入理解MySQL中的事务机制(mysql深度解析),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql的理解,深入mysql实战,深入理解mysql主从原理 pdf,mysqlmgr深入理解,深入理解mysql技术,mysqlmgr深入理解,深入mysql实战,深入理解mysql核心技术pdf,内容如对您有帮助,希望把文章链接给更多的朋友!

使用数据库事务可以确保除事务性单元内的所有操作都成功完成。MySQL中的InnoDB引擎的表才支持transaction。在一个事务里,如果出现一个数据库操作失败了,事务内的所有操作将被回滚,数据库将会回到事务前的初始状态。有一些不能被回滚的语句:将在本文的最后讨论。

在一个web应用中,会很经常遇到需要使用事务的地方,要么希望若干语句都执行成功,要么都不执行,如果出现有些执行成功,而其他的失败将会导致数据损坏。

在这篇文章的例子中,我们使用下面的两张表"employee"和"telephone",下面是SQL语句(作为参考):

创建 employee表:

向employee中插入数据

创建telephone表

深入理解MySQL中的事务机制(mysql深度解析)

向telephone表插入数据

设想你需要一个新的叫做Grace Williams雇员,并带有他的电话号码信息。你可能会执行下面两句sql:

让我们看看第二个语句,在第一个语句中,employee_id是在第一条语句中指定的,设想一下,当第一条语句失败,而第二条语句成功的状况。在这种状况下,telephone表中就会有一条employee_id为9的记录,而employee表中并没有id为9的记录,而如果将这两个语句放在MySQL事务中,如果第一条语句失败,那么第二条语句也将回滚,从而不会造成这种问题。

在PHP(PHP参考文档)中我们可以使用如下的方式启用事务:

当你执行mysqli_query函数的时候,结果被立即提交到了数据库。使用mysqli_autocommit函数,可以关闭自动提交,执行结果只有当你想提交的时候才提交。 如果任何语句执行失败我们都可以设置$flag变量为false。如果有很多语句要执行,可以考虑将他们放在for循环中。 最后,如果flag是true(也就是没有错误发生),我们使用mysqli_commit提交事务。否则我们使用mysqli_rollback回滚事务。

所以,事务可以在某种程度上帮助我们维护数据的完整和正确,另外,为了保证数据无误,我们还推荐使用外键。

并不是所有的语句都是支持事务的,例如,如果使用CREATE TABLE或者ALTER TABLE语句,需要了解更多可以参考MySQL手册查看哪些语句不能回滚。

MySQL在Linux系统中隐藏命令行中的密码的方法 在命令行中输入命令并不是一个好主意,会造成安全问题。但是如果你决定去写一个应用,而这个应用需要在命令行中使用密码或者其他敏感信息。那

在Linux系统的命令行中为MySQL创建用户的方法 要访问一个MySQL服务器,你需要使用一个用户帐号登录其中方可进行。每个MySQL用户帐号都有许多与之相关连的属性,例如用户名、密码以及权限和资源

在Ubuntu或Debian系统的服务器上卸载MySQL的方法 对于有的vps,系统默认安装了mysql。我们需要从我们的服务器、vps上卸载(移除)默认的mysql。那么如何(怎样)在ubuntuDebian上卸载mysql通常情况下,下列mysql

标签: mysql深度解析

本文链接地址:https://www.jiuchutong.com/biancheng/347653.html 转载请保留说明!

上一篇:MySQL中三种关联查询方式的简单比较(mysql中数据表的关联关系有哪三种?)

下一篇:MySQL在Linux系统中隐藏命令行中的密码的方法

  • 什么叫直接税?直接税有哪些?
  • 经营租赁含有免租金吗
  • 收到增值税发票是不是就给钱了
  • 厂房自用和出租税收区别
  • 增值税减免税申报明细表免税代码和名称
  • 公司给员工发放福利的说辞
  • 出口销售收入要交增值税吗
  • 返利应计入什么科目
  • 支付给外包公司的工资备注怎么写
  • 小规模纳税人税率有几种
  • 做实验用的东西哪里可以买到
  • 进项税额已认证未抵扣会计分录
  • 减半征收附加税会计分录
  • 受托开发软件产品免征增值税
  • 房地产公司解散条件
  • 销售报废车辆按多少计提销项税额
  • 委外加工半成品入库的会计分录
  • 企业法人投资股4 账户
  • 延期付款利息的税率是多少
  • 关于建筑工程发包与承包下列说法正确的是
  • 税收分类编码怎么导出来
  • 同程旅行酒店预订
  • 误餐补助有限制性的规定吗
  • 回单是会计还是出纳职责
  • 中奖个人所得税多少起征收
  • 捐赠计提管理费的账务处理?
  • 开立银行承兑汇票清单怎么盖章
  • 生育津贴的相关法律规定
  • 项目款申请
  • mac更新内容
  • php字符串型数据的定义方式
  • 结转消费成本的会计分录
  • 吃鸡到底用什么显卡性价比最高?
  • linux递归创建目录命令
  • 进出口公司出口退税额
  • 购买车辆的会计分录该怎样做
  • 常用的前端大屏软件
  • 解决安装后软件icon一圈白边问题
  • 邮件发送错误怎么解释
  • ts基础
  • phpcrawl
  • qiankun跨域问题
  • 个人独资企业法律责任
  • 其他综合收益需要写二级科目吗
  • 基础kl
  • vue render ref
  • 命令行mkdir创建文件夹
  • php 输出
  • 出口退税逾期申报,需申报出口货物收汇情况表
  • 电子税务局没有开票业务
  • 电费发票查不到
  • 增值税普通发票几个点
  • php7安装mysqli扩展
  • 资产负债表中没有专项储备怎么填写
  • 同一控制下合并报表恢复留存收益
  • 小规模纳税人出租不动产免征增值税
  • 固定资产到期出售 合同
  • 合同约定合同期限自动顺延
  • 母公司与子公司的法律关系
  • 期初调整分录
  • 小规模纳税人购进税控机的税如何抵扣
  • 资本公积只能转现金吗
  • 企业所得税季报营业成本包括哪些
  • centos账号密码
  • xp系统还原系统
  • window系统桌面
  • fpassist.exe是什么进程 有什么作用 fpassist进程查询
  • 怎么用root登录
  • linux中mnt
  • win7任务栏突然变成灰色
  • 关于dns的说法错误的是
  • cocos2d教程
  • Cocos2dx 疯狂跑酷(CrazyRun)游戏项目解析
  • Node.js中的全局对象有
  • shell执行多个命令
  • jquery22插件网
  • jquery获取动态生成的元素的值
  • 国家税务总局好进吗
  • 湖北国税办税人是谁
  • 税控专用设备包括哪些
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设