nodejs的mysql事务,行锁,表锁

  • 使用事务(Transactions)

    • 在 MySQL 中,事务(Transaction)可以确保一组操作要么全部成功,要么全部失败和回滚,从而保持数据的一致性。
    • 使用 connection.beginTransaction() 开始事务,然后在事务中执行你的更新操作,最后通过 connection.commit() 提交事务或者 connection.rollback() 回滚事务。
    • 事务的使用可以确保在多个并发操作中,数据始终保持一致。
    connection.beginTransaction(function(err) {
        if (err) { throw err; }
        connection.query(
            "Update User Set BuCardNum=BuCardNum-1 Where UserId=?",
            [userId],
            function(err, result) {
                if (err) {
                    connection.rollback(function() {
                        throw err;
                    });
                }
                connection.commit(function(err) {
                    if (err) {
                        connection.rollback(function() {
                            throw err;
                        });
                    }
                    console.log('Transaction completed successfully.');
                });
            }
        );
    });
    
  • 使用锁(Locking)

    • 在某些情况下,你可以使用 MySQL 的行级锁或者表级锁来确保在更新操作期间其他会话不能修改相同的数据。
    • 例如,可以使用 FOR UPDATE 或者 LOCK IN SHARE MODE 来锁定特定的行或者表,直到当前会话完成操作。
  • connection.query(
        "Update User Set BuCardNum=BuCardNum-1 Where UserId=? FOR UPDATE",
        [userId],
        function(err, result) {
            if (err) { throw err; }
            console.log('Update successful.');
        }
    );
    
  • 使用排他锁(Exclusive Locks)

    • 如果你希望确保整个表的一致性,可以考虑使用 LOCK TABLES 命令来锁定整个表,直到更新操作完成为止。
    • 不过要注意,使用 LOCK TABLES 可能会影响并发性能,需要谨慎使用。
connection.query(
    "LOCK TABLES User WRITE",
    function(err, result) {
        if (err) { throw err; }
        connection.query(
            "Update User Set BuCardNum=BuCardNum-1 Where UserId=?",
            [userId],
            function(err, result) {
                if (err) { throw err; }
                console.log('Update successful.');
                connection.query("UNLOCK TABLES");
            }
        );
    }
);
  • 使用数据库级别的锁机制

    • MySQL 提供了多种锁机制,包括共享锁和排他锁,可以根据具体的需求选择合适的锁来保证数据的一致性和完整性。
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Node.js中使用MySQL服务时,可以通过事务管理来执行多条SQL操作,以确保原子性和数据一致性。事务是将一组操作视为一个单独的单元来执行,要么全部成功,要么全部失败。在Node.js中,可以使用Promise来封装事务操作。 首先,需要导入MySQL的连接池对象,例如使用`const pool = require("../db/mysql")`导入pool对象。然后,可以封装一个执行事务的函数`execTransaction`,该函数接受一个包含多个SQL语句的数组作为参数。 在`execTransaction`函数中,首先通过连接池获取一个数据库连接,然后开始事务。接下来,将所有需要执行的SQL语句封装为Promise数组,每个Promise代表一个SQL执行操作。在Promise中,使用连接对象的`query`方法执行SQL语句,并将结果返回。 使用`Promise.all`来等待所有的SQL操作完成,如果其中有任何一个操作出错,将回滚事务,并且释放连接。如果所有操作都成功执行,将提交事务,并释放连接。最后,通过`resolve`将结果返回。 这样,通过封装的`execTransaction`函数,可以在Node.js中方便地执行MySQL事务管理操作。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [Nodejs实现Mysql事务的解决方案](https://blog.csdn.net/weixin_41464806/article/details/106446449)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [NodeJs使用Mysql模块实现事务处理实例](https://download.csdn.net/download/weixin_38678796/14858646)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值