张怒天 2019-03-01 10:38 采纳率: 0%
浏览 388
已结题

请教一个MySql更新数据锁问题

 public bool UpdateAmount(long userId, decimal amount)
        {


            string sql = " select * from T_User where UserId=userId for update";//锁住行           
            decimal A = GetUserAmount(userId);//在用户表查询金额
            decimal AA = A + amount;//原来金额+上当前金额
            //更新金额
            string updateSql = "update T_User set Amount=AA where UserId=userId";
            return true;
        }
        如果有两个用户同时调用这个方法 传进来userId都是1
        两个用户同时GetUserAmount(userId)获得得到的是同一个金额
        A先执行updateSql 此时数据库的金额是更新后的了 
        那B此时手上的数据还是更新前的,B再updateSql还是原来金额+当前金额,而不是A更新后的金额+当前金额

请问怎么解决这个问题?谢谢

  • 写回答

2条回答 默认 最新

  • 御风御吾 2019-03-01 11:23
    关注

    修改如下sql语句为:
    string sql = " select * from T_User where UserId=userId lock in share mode";//锁住行

    评论

报告相同问题?

悬赏问题

  • ¥15 求chat4.0解答一道线性规划题,用lingo编程运行,第一问要求写出数学模型和lingo语言编程模型,第二问第三问解答就行,我的ddl要到了谁来求了
  • ¥15 Ubuntu在安装序列比对软件STAR时出现报错如何解决
  • ¥50 树莓派安卓APK系统签名
  • ¥15 maple软件,用solve求反函数出现rootof,怎么办?
  • ¥65 汇编语言除法溢出问题
  • ¥15 Visual Studio问题
  • ¥20 求一个html代码,有偿
  • ¥100 关于使用MATLAB中copularnd函数的问题
  • ¥20 在虚拟机的pycharm上
  • ¥15 jupyterthemes 设置完毕后没有效果