本文整理匯總了PHP中think\Model::rollback方法的典型用法代碼示例。如果您正苦於以下問題:PHP Model::rollback方法的具體用法?PHP Model::rollback怎麽用?PHP Model::rollback使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類think\Model
的用法示例。
在下文中一共展示了Model::rollback方法的7個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: buy
/**
* 生成訂單
* @param array $data 購買數據
* @return array $ret 結果狀態
*/
public function buy($data)
{
//--開始事務
$model = new Model();
$model->startTrans();
//--判斷用戶是否有足夠餘額
$goods = D('goods')->getById($data['id']);
date_default_timezone_set("Asia/Shanghai");
$amount = $data['number'] * $goods['univalent'];
$user = D('user')->getById(session('user')['id']);
if ($user['balance'] < $amount) {
return array('ret' => false, 'msg' => '餘額不足');
}
//--修改用戶餘額
$newBalance = $user['balance'] - $amount;
if (!D('user')->where(['id' => $user['id']])->save(['balance' => $newBalance])) {
$model->rollback();
}
//--創建訂單
$order->user_id = session('user')['id'];
$order->goods_id = $goods['id'];
$order->shop_id = D('Goods')->getById($goods['id'])['shop_id'];
$order->goods_name = $goods['name'];
$order->univalent = $goods['univalent'];
$order->number = $data['number'];
$order->amount = $data['number'] * $goods['univalent'];
$order->remark = $data['remark'];
if ($this->create($order)) {
if (!($orderId = $this->add())) {
$model->rollback();
return array('ret' => false, 'msg' => $this->getError());
}
} else {
return array('ret' => false, 'msg' => $this->getError());
}
//--創建資金變動
$fundChange['user_id'] = $user['id'];
$fundChange['associate_id'] = $orderId;
$fundChange['time'] = time();
$fundChange['type'] = '訂單扣款';
$fundChange['amount'] = $amount;
$fundChange['before_change'] = $user['balance'];
$fundChange['after_change'] = $user['balance'] - $amount;
if (D('FundChange')->create($fundChange)) {
if (!D('FundChange')->add()) {
$model->rollback();
return array('ret' => false, 'msg' => D('FundChange')->getError());
}
} else {
return array('ret' => false, 'msg' => D('FundChange')->getError());
}
$model->commit();
return array('ret' => true, 'msg' => '購買成功');
}
示例2: regist
/**
* 注冊
* @param array $data 注冊數據
*/
public function regist($data)
{
// 將用戶信息添加到User表中
$tranDb = new Model();
$tranDb->startTrans();
$username = $data['username'];
$result = $tranDb->table('west_user')->where("username = '{$username}'")->find();
if ($result == null) {
$user_info = array('username' => $username, 'password' => $data['password'], 'group' => 'user', 'status' => 0, 'modify_time' => time());
$uid = $tranDb->table('west_user')->data($user_info)->add();
if ($uid) {
// 判斷公司是否存在
$company_name = $data['company_name'];
$result = $tranDb->table('west_company')->where("name = '{$company_name}'")->find();
if ($result == null) {
$company_info = array('uid' => $user_id, 'name' => $data['company_name'], 'mail' => $data['company_mail'], 'tel' => $data['company_tel'], 'modify_time' => time());
$result = $tranDb->table('west_company')->data($company_info)->add();
if ($result) {
$tranDb->commit();
return 1;
// 注冊用戶成功
} else {
$tranDb->rollback();
return -4;
// 添加公司信息失敗
}
} else {
$tranDb->rollback();
return -3;
// 公司名稱已存在
}
} else {
$tranDb->rollback();
return -2;
// 添加用戶信息失敗
}
} else {
return -1;
// 用戶名已存在
}
}
示例3: create
/**
* 生成訂單
* @param $order
* @param $goods
* @return array
*/
public function create($order, $goods)
{
$db = new Model();
$db->startTrans();
$order_id = $db->table($this->_table)->add($order);
$status = false;
if ($order_id) {
foreach ($goods as $g) {
$g['order_id'] = $order_id;
$flag = $db->table($this->_table_order_goods)->add($g);
}
if ($flag) {
$db->commit();
$status = true;
}
}
if (!$status) {
$db->rollback();
}
return $order_id;
}
示例4: rollback
public function rollback()
{
parent::rollback();
$this->query('SET FOREIGN_KEY_CHECKS = 1');
}
示例5: end
/**
* 提交事務
* @access public
* @return boolean
*/
public function end($success = true, $tag = 'default')
{
if ($success) {
if (self::$_startedTrans != $tag) {
return;
}
self::$_startedTrans = null;
return parent::commit();
} else {
self::$_startedTrans = null;
return parent::rollback();
}
}
示例6: calculateRice
public function calculateRice($rice_id)
{
$tranDb = new Think\Model();
$tranDb->startTrans();
//啟動事務,保證數據的一致性
$ricedata = $this->where("rice_id='{$rice_id}'")->find();
$calculatedData = $this->calculateIndicator($ricedata);
$rid = $this->where("rice_id='{$rice_id}'")->save($calculatedData);
$wave = new InfoWaveModel();
$wid = $wave->addWave($calculatedData);
if ($rid !== false && $wid) {
$tranDb->commit();
return true;
} else {
$this->error = "計算失敗!";
$tranDb->rollback();
return false;
}
}
示例7: EditSave
/**
*修改用戶
*/
public function EditSave()
{
//獲取參數
$id = I('id', 0, 'int');
$username = I('username');
$password = I('password');
$email = I('email');
$mobile = I('mobile');
$roleid = I('role_id');
//是否修改
if ($id == 0) {
$result['result'] = false;
$result['msg'] = '該用戶不存在';
$this->ajaxReturn($result);
}
//開啟事務
$model = new Model();
$model->startTrans();
$flage === false;
//申明修改用戶對象
$data['UserName'] = $username;
if (!empty($password)) {
$data['PassWord'] = md5($password);
}
$data['Email'] = $email;
$data['Mobile'] = $mobile;
//更新
$flage = $model->table('sys_user')->where('id=%d', $id)->save($data);
if ($flage === false) {
//事務回滾
$model->rollback();
$result['result'] = false;
$result['msg'] = '修改用戶資料失敗!';
$this->ajaxReturn($result);
} else {
$flage = $model->table('sys_role_user')->where('user_id=%d', $id)->delete();
if ($flage === false) {
//事務回滾
$model->rollback();
$result['result'] = false;
$result['msg'] = '修改用戶資料失敗!';
$this->ajaxReturn($result);
}
//角色處理
foreach ($roleid as $key => $value) {
# code...
$data2['role_id'] = $value;
$data2['user_id'] = $id;
$flage = $model->table('sys_role_user')->add($data2);
if ($flage === false) {
//事務回滾
$model->rollback();
$result['result'] = false;
$result['msg'] = '修改用戶資料失敗!';
$this->ajaxReturn($result);
}
}
if ($flage) {
//事務提交
$model->commit();
$result['result'] = true;
$result['msg'] = '修改用戶資料成功!';
$this->ajaxReturn($result);
}
}
}