轉貼:Mysql 的Row Lock 與 Table Lock

資料來源Neo’s Blog

先前介紹過 SELECT … FOR UPDATE 的用法,不過鎖定(Lock)的資料是判別就得要注意一下了。由於 MyISAM 預設是 Row-Level Lock,所以只有「明確」的指定主鍵,MySQL 才會執行 Row lock (只鎖住被選取的資料例) ,否則 MySQL 將會執行 Table Lock (將整個資料表單給鎖住)。
舉個例子:

假設有個表單 products ,裡面有 id 跟 name 二個欄位,id 是主鍵。

例1: (明確指定主鍵,並且有此筆資料,row lock)

SELECT * FROM products WHERE id=’3′ FOR UPDATE;

例2: (明確指定主鍵,若查無此筆資料,無 lock)

SELECT * FROM products WHERE id=’-1′ FOR UPDATE;

例2: (無主鍵,table lock)

SELECT * FROM products WHERE name=’Mouse’ FOR UPDATE;

例3: (主鍵不明確,table lock)

SELECT * FROM products WHERE id<>’3′ FOR UPDATE;

例4: (主鍵不明確,table lock)

SELECT * FROM products WHERE id LIKE ‘3’ FOR UPDATE;

註1:
FOR UPDATE 僅適用於 MyISAM,且必須在交易區塊(BEGIN/COMMIT)中才能生效。

註2:
要測試鎖定的狀況,可以利用 MySQL 的 Command Mode ,開二個視窗來做測試。

如果是使用Appserver環境,請把Mysql服務停下來,打開my.ini,找到skip-innodb,前面加上註解變成
#skip-innodb

重新啟動服務,就可以在資料儲存引擎中找到innodb的選項,就可以進行lock table/lock row的功能。

連Facebook的佐克柏都來用Google Plus

我也可以把Mark Zukerberg加入我的社交圈Facebook的傳播威力,實在不可以小覷,最近在整理我的Google Plus通訊資料。

我也不知道這個祖克柏(Zuckerberg)是不是Facebook創辦人,不過怎麼說,Google Plus要加油。

另外,Google Plus真的也有不少的垃圾信,今天就有人亂加我,我連過去看,結果是一堆廣告訊息,讓大家都來用無垃圾的Google Plus,Google 加油。

把Vibo A688 刷機變成磚頭~一個字爽

今天沒有什麼事,就想把Vibo A688 OS從android 2.2升到2.3(出廠是1.6版~我已經刷過一次了),結果,運氣真好,手機開不起來了。

為什麼爽呢?因為這樣就能名正言順的申請換機了,親愛的財政部長,我要特別預算換機啦!不要什iPhone5,來個iPhone4我就很滿足了。
Read more

10分鐘電郵註冊Facebook?

因為Facebook上的通知信超多,之前就知道網路上有一些免費的電郵服務,10分鐘電郵。

意思是說,你到這個網站上,會產生一組隨機的電郵給你,10分鐘內,你都可以透過這個電郵來收發信。

結果Facebook的認證信是寄了,10分鐘電郵也收到,但是Facebook出現了下面這個畫面。
Read more

一個好笑的facebook粉絲團apps狀態

某甲原為某A公司的行銷人員,成為A公司的粉絲團管理員,在A公司的粉絲團中採用某個apps,來舉辦行銷活動。

因故,某甲無法繼續在A公司工作,因此某甲已經不是這個粉絲團的管理員,已無法用apps管理的方式,修改調整這個活動的內容,連下架都沒有辦法。

這個活動舉辦完,粉絲團人數因為抽獎而增加了,參加的人,無法抽獎,就跟詐騙集團一樣,我的老天爺啊!這個流程上是有問題的,而且找不到解決的機制。
Read more