• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > 讲解MySQL中的事务特性

讲解MySQL中的事务特性

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-11

通过本文主要向大家介绍了mysql事务特性,mysql特性,mysql5.7新特性,mysql5.6新特性,mysql特点特性等相关知识,希望本文的分享对您有所帮助

一个事务是一个连续的一组数据库操作,就好像它是一个单一的工作单元进行。换言之,永远不会是完整的事务,除非该组内的每个单独的操作是成功的。如果在事务的任何操作失败,则整个事务将失败。

实际上,会俱乐部许多SQL查询到一个组中,将执行所有的人都一起作为事务的一部分。
事务的特性:

事务有以下四个标准属性的缩写ACID,通常被称为:

  •     原子性: 确保工作单元内的所有操作都成功完成,否则事务将被中止在故障点,和以前的操作将回滚到以前的状态。
  •     一致性: 确保数据库正确地改变状态后,成功提交的事务。
  •     隔离性: 使事务操作彼此独立的和透明的。
  •     持久性: 确保提交的事务的结果或效果的系统出现故障的情况下仍然存在。
  • 在MySQL中,事务开始使用COMMIT或ROLLBACK语句开始工作和结束。开始和结束语句的SQL命令之间形成了大量的事务。
  • COMMIT & ROLLBACK:
  • 这两个关键字提交和回滚主要用于MySQL的事务。
  •     当一个成功的事务完成后,发出COMMIT命令应使所有参与表的更改才会生效。
  •     如果发生故障时,应发出一个ROLLBACK命令返回的事务中引用的每一个表到以前的状态。

可以控制的事务行为称为AUTOCOMMIT设置会话变量。如果AUTOCOMMIT设置为1(默认值),然后每一个SQL语句(在事务与否)被认为是一个完整的事务,并承诺在默认情况下,当它完成。 AUTOCOMMIT设置为0时,发出SET AUTOCOMMIT =0命令,在随后的一系列语句的作用就像一个事务,直到一个明确的COMMIT语句时,没有活动的提交。

可以通过使用mysql_query()函数在PHP中执行这些SQL命令。
通用事务例子

这一系列事件是独立于所使用的编程语言,可以建立在任何使用的语言来创建应用程序的逻辑路径。
可以通过使用mysql_query()函数在PHP中执行这些SQL命令。

  •     BEGIN WORK开始事务发出SQL命令
  •     发出一个或多个SQL命令,如SELECT,INSERT,UPDATE或DELETE
  •     检查是否有任何错误,一切都依据的需要。
  •     如果有任何错误,那么问题ROLLBACK命令,否则发出COMMIT命令。

在MySQL中的事务安全表类型:

如果打算使用MySQL事务编程,那么就需要一种特殊的方式创建表。有很多支持事务但最流行的是InnoDB表类型。

从源代码编译MySQL时,InnoDB表支持需要特定的编译参数。如果MySQL版本没有InnoDB支持,请互联网服务提供商建立一个版本的MySQL支持InnoDB表类型,或者下载并安装Windows或Linux/UNIX的MySQL-Max二进制分发和使用的表类型在开发环境中。
如果MySQL安装支持InnoDB表,只需添加一个的TYPE=InnoDB 定义表创建语句。例如,下面的代码创建InnoDB表tcount_tbl:

root@host# mysql -u root -p password;
Enter password:*******
mysql> use TUTORIALS;
Database changed
mysql> create table tcount_tbl
  -> (
  -> tutorial_author varchar(40) NOT NULL,
  -> tutorial_count INT
  -> ) TYPE=InnoDB;
Query OK, 0 rows affected (0.05 sec)

</div>

请查看下面的链接了解更多关于: InnoDB

可以使用其他GEMINI或BDB表类型,但它取决于您的安装,如果它支持这两种类型。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • MySQL易学易用之MYSQL不为人知的特性
  • 讲解MySQL中的事务特性
  • 利用mysql事务特性实现并发安全的自增ID示例

相关文章

  • 2018-12-05phpstorm如何通过SSH连接mysql数据库
  • 2018-12-05MySQL创建索引和删除索引的方法
  • 2018-12-05mysql主从库不同步问题解决方法
  • 2017-05-11浅析Mysql Join语法以及性能优化
  • 2017-05-11MySQL Order By用法分享
  • 2018-12-05ORA-01002: 提取违反顺序的问题分析
  • 2018-12-05MySQL数据库锁定机制的介绍
  • 2018-12-05ORACLE常见错误代码的分析与解决(二)
  • 2018-12-05关于mysql联结的详细介绍
  • 2017-05-11mysql常见的错误提示问题处理小结

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • mysql show processlist 显示mysql查询进程
    • Mysql学习笔记(一)
    • MySQL高可用解决方案MMM详解
    • SQL Server连接中三个常见的错误分析
    • MySQL存储过程-创建智能存储过程和检查存储过程
    • mysql创建Bitmap_Join_Indexes中的约束与索引
    • MySQL DNS的使用过程详细分析
    • 关于mysql操作sql的小技巧
    • 使用cmd命令行窗口操作SqlServer的方法
    • SQLSERVER Pager store procedure分页存储过程

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有