《Disney +》 迪士尼、Marvel、彼思、星球大戰…  《虹彩六號:圍攻行動》最新賽季「腥紅劫案」即日推出   收錄14部食鬼名作的PAC-MAN MUSEUM+ 2022年發售!   提神並回復專注力!在電競遊戲中試喝了「eSport對策 BREAK OUT」!   入手賽車遊戲駕駛座的門檻太高了嗎?你需要的是「Playseat Challenge」!   等身大呆呆獸登場!寶可夢中心網路商店開放預購中!   《Returnal》戰鬥細節介紹:可升級武器、異世界工具和具有風險的收集品   Astro’s Playroom:PlayStation 俏皮客串角色的幕後花絮   波導的勇者!「玩偶 等身大路卡利歐」即日起在日本寶可夢線上中心接受預購中! 

MySQL CLI 關閉 auto commit 避免失誤

商業

MySQL 於 CLI 操作時,通常都要特別小心再小心,但是也是很難避免有意外的發生,此時可以使用 Transaction 的特性,再多一層保障。

  • 注意:上述需要支援 Transaction(交易)(例如:InnoDB),MyISAM 是不支援 Transaction 的

MySQL CLI 關閉 autocommit 避免失誤

於 MySQL CLI 操作的時候,可以先將 autocommit 關閉,每次操作並確認後,再手動執行 commit 的動作。

上述於手動執行的步驟

  1. $ mysql -u root -p DBName
  2. mysql> set autocommit=0;
  3. mysql> select ... 抓取資料確認
  4. mysql> update ... sql command... 更新
  5. mysql> select ... 再次確認資料
  6. mysql> commit; # 正確就 commit
  7. mysql> rollback; # 異常就還原 (rollback)

若要讓每次 CLI 進入時,都預設關閉 autocommit 的話,可以做下述設定:

  1. 預設 autocommit 設定為 0
  2. vim ~/.my.cnf # 加入下述兩行即完成
    [client]
    init-command='set autocommit=0'
  3. 驗證是否 autocommit 都設定關閉了
  4. $ mysql -u root -p DBName
  5. mysql> select @@autocommit; # 可以查看目前 autocommit 的狀態
Tsung

隨機商業新聞

Addidas