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更新后的金额+当前金额
请问怎么解决这个问题?谢谢