请教一个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更新后的金额+当前金额

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

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

那个回答不对。
好用的解决方法是,把整个方法调用放到一个事务里面,其他不用改。

锁住行没问题,然后因为整个方法都在事务中,行锁的释放时间是事务结束后

所以 decimal A = GetUserAmount(userId);//这个动作的执行会被之前的select for update卡住,不会发生并发问题