程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> 關於MYSQL數據庫 >> 解析mysqldump的delay-insert選項

解析mysqldump的delay-insert選項

編輯:關於MYSQL數據庫

如果用delayed-insert插入時不用鎖表。
./bin/mysqldump -uroot  -proot   --lock-tables --extended-insert  --opt --quick  --master-data  test >/home/zhanghong/opdir/tmp/test.sql
--
LOCK TABLES `student` WRITE;
/*!40000 ALTER TABLE `student` DISABLE KEYS */;
INSERT INTO `student` VALUES (16,'hhah',3),(17,'22',3),(18,'ss',18);
/*!40000 ALTER TABLE `student` ENABLE KEYS */;
UNLOCK TABLES;

使用delayed-insert不會鎖表
./bin/mysqldump -uroot  -proot   --lock-tables --delayed-insert --extended-insert  --opt --quick  --master-data  test >/home/zhanghong/opdir/tmp/test.sql
/*!40000 ALTER TABLE `student` DISABLE KEYS */;
INSERT  DELAYED INTO `student` VALUES (16,'hhah',3),(17,'22',3),(18,'ss',18);
/*!40000 ALTER TABLE `student` ENABLE KEYS */;
/*!40103 SET TIME_ZONE=@OLD_TIME_ZONE */;

當一個線程對一個表執行DELAYED語句時,會創建出一個管理程序線程(如果原來不存在),對用於本表的所有DELAYED語句進行處理。

·線程會檢查是否管理程序以前已獲取了DELAYED鎖定;如果沒有獲取,則告知管理程序線程進行此項操作。 即使其它線程對表有READ或WRITE鎖定,也可以獲得DELAYED鎖定。但是管理程序會等待所有的ALTER TABLE鎖定或FLUSH TABLE鎖定,以確保表的結構是最新的。

·線程執行INSERT語句,但不是把行寫入表中,而是把最終行的拷貝放入一個由管理程序線程管理的隊列中。線程會提示出現語法錯誤,這些錯誤會被報告到客戶端中。

·因為在插入操作之前,INSERT返回已經完成,所以客戶端不能從服務器處獲取重復記錄的數目,也不能獲取生成的行的AUTO_INCREMENT值。(如果您使用C API,則出於同樣的原因,mysql_info()函數不會返回任何有意義的東西。)

·當行被插入表中時,二進制日志被管理程序線程更新。在多行插入情況下,當第一行被插入時,二進制日志被更新。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved