MySQL事务超卖_php使用事务解决超买超卖问题!

public static function updateUserPrize($prizeTable, $columnId,

$columnName, $userTable, $openid, $prizeLevel)

{

// 使用事务

// mysql_connect 是面向过程的

$conn =

mysql_connect(self::$server, self::$username, self::$password);

mysql_select_db(self::$database);

mysql_query('set

autocommit=0'); // 不自动提交

mysql_query('BEGIN');

// 开启事务

// 获取奖品数量

$sql = "select $columnName

from $prizeTable where id=$columnId";

$result =

mysql_query($sql);

$row =

mysql_fetch_row($result); //

获取的是顺序数组

$prizeNum = (int)

$row[0];

//

减少奖品数量,因为在别的方法中判断了奖品数量,所以这个方法不需要给返回值

$sql = "update $prizeTable

set $columnName=$columnName-1 where id=$columnId and

$columnName=$prizeNum and $columnName>0";

$res =

mysql_query($sql);

// 更新用户获奖信息

if (mysql_affected_rows()

> 0) { //

update语句一定会执行成功,所以需要判断影响行数

$sql = "update $userTable set prize=$prizeLevel

where openid='$openid'";

$res2 = mysql_query($sql);

}

if ($res2) {

mysql_query("COMMIT");

mysql_query('set autocommit=1');

return true;

} else {

mysql_query("ROLLBACK");

mysql_query('set autocommit=1');

return false;

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值