When should I use MySQL transactions?(我应该什么时候使用 MySQL 事务?)
问题描述
我阅读了一些关于何时应该使用事务的文章.我读到:
I read some articles about when I should use transactions. I read:
我应该什么时候使用事务?基本上任何时候您的工作单元要么对外部更改敏感,要么需要能够回滚每个更改,如果发生错误或其他原因.
但有人能更好地向我解释吗?
But can someone explain it better to me?
- 当我执行两个或多个时,我应该开始一个事务吗?删除/更新/插入查询?
- 当我只有一个删除/更新/插入查询时,我是否也应该开始一项事务?
- 我应该在一个页面上启动一个事务 10 次,还是整个页面最好只启动一次,或者您是否建议每个页面的最大值(例如 5 个)?
感谢您的帮助!
推荐答案
当您有一组相互依赖的查询时使用事务.
Transactions are used when you have a group of queries that all depend on one another.
例如银行:
- 银行客户John"将 100 美元转入Alice"的账户.
- 对于此示例,有 2 个查询(我没有显示日志记录或交易历史记录...等).您需要从 John 的余额中扣除 100 美元,然后将其添加到 Alice 的余额中.
开始交易
- 从约翰那里扣除
更新账户 SET balance=balance-100 WHERE account='John'
更新账户 SET balance=balance+100 WHERE account='Alice'
事务在您提交之前不会被保存.因此,如果任一查询出现错误,您可以调用
rollback
并撤消自事务启动以来运行的任何查询.如果由于某种原因向 Alice 添加 $100 的查询失败,您可以回滚而不是从 John 中扣除 $100.这是一种确保您可以在需要时自动撤消查询的方法.A transaction isn't saved until you commit it. So if there was an error in either query, you could call
rollback
and undo any queries that have run since the transaction was started. If for some reason the query for adding $100 to Alice failed, you could rollback and not deduct $100 from John. It is a way of ensuring that you can undo queries automatically if needed.当我执行两个或多个删除/更新/插入查询时,我应该启动一个事务吗?
Should I start a transaction when I execute two or more delete/update/insert queries?
取决于查询正在做什么.
当我只有一个删除/更新/插入查询时,我是否也应该开始一项事务?
Should I also start a transaction when I just have one delete/update/insert query?
除非您需要一种方法来回滚(撤消)查询,就像您想要进行更新并在调用提交(保存)之前验证它一样.
我应该在一个页面上启动一个事务 10 次,还是整个页面最好只启动一次,或者您是否建议每个页面的最大值(例如 5 个)?
Should I start a transaction like 10 times on a page, or better only once for the whole page, or do you recommend a max for each page (for example 5)?
根据需要开始.我怀疑每个页面是否有多个交易,因为您很可能在每个页面加载时做一件事(即转账).
这篇关于我应该什么时候使用 MySQL 事务?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:我应该什么时候使用 MySQL 事务?
基础教程推荐
- XAMPP 服务器不加载 CSS 文件 2022-01-01
- 通过 PHP SoapClient 请求发送原始 XML 2021-01-01
- 超薄框架REST服务两次获得输出 2022-01-01
- 如何在 PHP 中的请求之间持久化对象 2022-01-01
- 在 PHP 中强制下载文件 - 在 Joomla 框架内 2022-01-01
- 在多维数组中查找最大值 2021-01-01
- WooCommerce 中选定产品类别的自定义产品价格后缀 2021-01-01
- mysqli_insert_id 是否有可能在高流量应用程序中返回 2021-01-01
- Libpuzzle 索引数百万张图片? 2022-01-01
- 在 Woocommerce 中根据运输方式和付款方式添加费用 2021-01-01