首頁 > 資料庫 > mysql教程 > MySQL锁表的用法,防止并发情况下的重复数据

MySQL锁表的用法,防止并发情况下的重复数据

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
發布: 2016-06-07 17:35:46
原創
1803 人瀏覽過

lock table 读锁定 如果一个线程获得在一个表上的read锁,那么该线程和所有其他线程只能从表中读数据,不能进行任何写操作。 loc

lock table 读锁定

如果一个线程获得在一个表上的read锁,那么该线程和所有其他线程只能从表中读数据,不能进行任何写操作。

lock tables user read;//读锁定表

unlock tables;//解锁

lock tables user read local;//本地读锁定表,其他线程的insert未被阻塞,update操作被阻塞

lock table 写锁定

如果一个线程在一个表上得到一个 write锁,,那么只有拥有这个锁的线程可以从表中读取和写表。其它的线程被阻塞。

lock tables user write;//写锁定表

unlock tables;//解锁

Yii中的用法实例

/**
*  当日单项内容状态
*/
public function getPointAready($marke,$dayTime){
 $model = SysRun::model()->findByAttributes(array('syr_marking'=>$marke,'syr_daytime'=>$dayTime));
 if(empty($model)){
  //表写锁定
  Yii::app()->db->createCommand()->setText("lock tables {{sys_run}} WRITE")->execute();
  $model = new SysRun();
  $model->syr_marking = $marke;
  $model->syr_daytime = $dayTime;
  $model->syr_val = 0;
  $model->syr_subval = 0;
  $model->save();
  //表解锁
  Yii::app()->db->createCommand()->setText("unlock  tables")->execute();
 }
 return $model;
}

linux

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
怎麼用php+mysql做動態資料表 , 急! ! !
來自於 1970-01-01 08:00:00
0
0
0
mysql - 標籤表的一些問題
來自於 1970-01-01 08:00:00
0
0
0
如何在 MySQL 中傳回資料透視表輸出?
來自於 1970-01-01 08:00:00
0
0
0
如何在MySQL中傳回透視表的輸出?
來自於 1970-01-01 08:00:00
0
0
0
在 MySQL 表中新增外鍵列:逐步指南
來自於 1970-01-01 08:00:00
0
0
0
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板