《Mysql學習解析mysqldump的delay-insert選項》要點:
本文介紹了Mysql學習解析mysqldump的delay-insert選項,希望對您有用。如果有疑問,可以聯系我們。
如果用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;MYSQL教程
使用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 */;MYSQL教程
當一個線程對一個表執行DELAYED語句時,會創建出一個管理程序線程(如果原來不存在),對用于本表的所有DELAYED語句進行處理.
?線程會檢查是否管理程序以前已獲取了DELAYED鎖定;如果沒有獲取,則告知管理程序線程進行此項操作. 即使其它線程對表有READ或WRITE鎖定,也可以獲得DELAYED鎖定.但是管理程序會等待所有的ALTER TABLE鎖定或FLUSH TABLE鎖定,以確保表的結構是最新的.
?線程執行INSERT語句,但不是把行寫入表中,而是把最終行的拷貝放入一個由管理程序線程管理的隊列中.線程會提示出現語法錯誤,這些錯誤會被報告到客戶端中.
?因為在插入操作之前,INSERT返回已經完成,所以客戶端不能從服務器處獲取重復記錄的數目,也不能獲取生成的行的AUTO_INCREMENT值.(如果您使用C API,則出于同樣的原因,mysql_info()函數不會返回任何有意義的東西.)
?當行被插入表中時,二進制日志被管理程序線程更新.在多行插入情況下,當第一行被插入時,二進制日志被更新.
MYSQL教程
轉載請注明本頁網址:
http://www.snjht.com/jiaocheng/5136.html