• <small id='wXSNg'></small><noframes id='wXSNg'>

      • <bdo id='wXSNg'></bdo><ul id='wXSNg'></ul>

      1. <i id='wXSNg'><tr id='wXSNg'><dt id='wXSNg'><q id='wXSNg'><span id='wXSNg'><b id='wXSNg'><form id='wXSNg'><ins id='wXSNg'></ins><ul id='wXSNg'></ul><sub id='wXSNg'></sub></form><legend id='wXSNg'></legend><bdo id='wXSNg'><pre id='wXSNg'><center id='wXSNg'></center></pre></bdo></b><th id='wXSNg'></th></span></q></dt></tr></i><div id='wXSNg'><tfoot id='wXSNg'></tfoot><dl id='wXSNg'><fieldset id='wXSNg'></fieldset></dl></div>
      2. <legend id='wXSNg'><style id='wXSNg'><dir id='wXSNg'><q id='wXSNg'></q></dir></style></legend>
        <tfoot id='wXSNg'></tfoot>

        增加字段时如何确保MySQL数据库中没有竞争条件?

        How to make sure there is no race condition in MySQL database when incrementing a field?(增加字段时如何确保MySQL数据库中没有竞争条件?)

            • <legend id='QRG9X'><style id='QRG9X'><dir id='QRG9X'><q id='QRG9X'></q></dir></style></legend>

              <small id='QRG9X'></small><noframes id='QRG9X'>

                <i id='QRG9X'><tr id='QRG9X'><dt id='QRG9X'><q id='QRG9X'><span id='QRG9X'><b id='QRG9X'><form id='QRG9X'><ins id='QRG9X'></ins><ul id='QRG9X'></ul><sub id='QRG9X'></sub></form><legend id='QRG9X'></legend><bdo id='QRG9X'><pre id='QRG9X'><center id='QRG9X'></center></pre></bdo></b><th id='QRG9X'></th></span></q></dt></tr></i><div id='QRG9X'><tfoot id='QRG9X'></tfoot><dl id='QRG9X'><fieldset id='QRG9X'></fieldset></dl></div>
              • <tfoot id='QRG9X'></tfoot>

                  <tbody id='QRG9X'></tbody>
                • <bdo id='QRG9X'></bdo><ul id='QRG9X'></ul>
                  本文介绍了增加字段时如何确保MySQL数据库中没有竞争条件?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

                  问题描述

                  限时送ChatGPT账号..

                  当两个连接想要更新同一条记录时,如何防止 MySQL 数据库中的竞争条件?

                  How to prevent a race condition in MySQL database when two connections want to update the same record?

                  例如,连接 1 想要增加尝试"计数器.第二个连接也想做同样的事情.两个连接SELECT尝试"计数,增加值并且两个UPDATE尝试"增加值.突然间,尝试次数"只是尝试次数+1"而不是尝试次数+2",因为两个连接都得到了相同的尝试次数"并加了 1.

                  For example, connection 1 wants to increase "tries" counter. And the second connection wants to do the same. Both connections SELECT the "tries" count, increase the value and both UPDATE "tries" with the increased value. Suddenly "tries" is only "tries+1" instead of being "tries+2", because both connections got the same "tries" and incremented it by one.

                  如何解决这个问题?

                  推荐答案

                  这里有 3 种不同的方法:

                  Here's 3 different approaches:

                  update table set tries=tries+1 where condition=value;
                  

                  它将以原子方式完成.

                  如果您确实需要先选择值并在您的应用程序中更新它,您可能需要使用事务.这意味着您必须使用 InnoDB,而不是 MyISAM 表.您的查询将类似于:

                  If you do need to first select the value and update it in your application, you likely need to use transactions. That means you'll have to use InnoDB, not MyISAM tables. Your query would be something like:

                  BEGIN; //or any method in the API you use that starts a transaction
                  select tries from table where condition=value for update;
                  .. do application logic to add to `tries`
                  update table set tries=newvalue where condition=value;
                  END;
                  

                  如果交易失败,您可能需要手动重试.

                  if the transaction fails, you might need to manually retry it.

                  一种常见的方法是在表中引入一个版本列.您的查询将执行以下操作:

                  A common approach is to introduce a version column in your table. Your queries would do something like:

                  select tries,version from table where condition=value;
                  .. do application logic, and remember the old version value.
                  update table set tries=newvalue,version=version + 1 where condition=value and version=oldversion;
                  

                  如果该更新失败/返回受影响的 0 行,则其他人同时更新了该表.您必须从头开始 - 也就是说,选择新值,执行应用程序逻辑并再次尝试更新.

                  If that update fails/returns 0 rows affected, someone else has updated the table in the mean time. You have to start all over - that is, select the new values, do the application logic and try the update again.

                  这篇关于增加字段时如何确保MySQL数据库中没有竞争条件?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

                  本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

                  相关文档推荐

                  Can#39;t Create Entity Data Model - using MySql and EF6(无法创建实体数据模型 - 使用 MySql 和 EF6)
                  MySQL select with CONCAT condition(MySQL选择与CONCAT条件)
                  Capitalize first letter of each word, in existing table(将现有表格中每个单词的首字母大写)
                  How to retrieve SQL result column value using column name in Python?(如何在 Python 中使用列名检索 SQL 结果列值?)
                  Update row with data from another row in the same table(使用同一表中另一行的数据更新行)
                  Exporting results of a Mysql query to excel?(将 Mysql 查询的结果导出到 excel?)
                    <tbody id='xiFVE'></tbody>

                  <i id='xiFVE'><tr id='xiFVE'><dt id='xiFVE'><q id='xiFVE'><span id='xiFVE'><b id='xiFVE'><form id='xiFVE'><ins id='xiFVE'></ins><ul id='xiFVE'></ul><sub id='xiFVE'></sub></form><legend id='xiFVE'></legend><bdo id='xiFVE'><pre id='xiFVE'><center id='xiFVE'></center></pre></bdo></b><th id='xiFVE'></th></span></q></dt></tr></i><div id='xiFVE'><tfoot id='xiFVE'></tfoot><dl id='xiFVE'><fieldset id='xiFVE'></fieldset></dl></div>

                        <bdo id='xiFVE'></bdo><ul id='xiFVE'></ul>
                          • <small id='xiFVE'></small><noframes id='xiFVE'>

                            <legend id='xiFVE'><style id='xiFVE'><dir id='xiFVE'><q id='xiFVE'></q></dir></style></legend>

                            <tfoot id='xiFVE'></tfoot>