0
A
回答
0
这是将使用mysqlbinlog可以输出和打印的INSERT/UPDATE一个美丽的汇总/ DELETE从基于行的二进制日志事件awk脚本。
只需将您的二进制日志文件mysqld-bin.000023
替换为--start-datetime="2015-01-12 21:40:00"
和--stop-datetime="2015-01-12 21:45:00"
并选择您喜欢的值即可。 Source
mysqlbinlog --base64-output=decode-rows -vv --start-datetime="2015-01-12 21:40:00" --stop-datetime="2015-01-12 21:45:00" mysqld-bin.000023 | awk \
'BEGIN {s_type=""; s_count=0;count=0;insert_count=0;update_count=0;delete_count=0;flag=0;} \
{if(match($0, /#15.*Table_map:.*mapped to number/)) {printf "Timestamp : " $1 " " $2 " Table : " $(NF-4); flag=1} \
else if (match($0, /(### INSERT INTO .*..*)/)) {count=count+1;insert_count=insert_count+1;s_type="INSERT"; s_count=s_count+1;} \
else if (match($0, /(### UPDATE .*..*)/)) {count=count+1;update_count=update_count+1;s_type="UPDATE"; s_count=s_count+1;} \
else if (match($0, /(### DELETE FROM .*..*)/)) {count=count+1;delete_count=delete_count+1;s_type="DELETE"; s_count=s_count+1;} \
else if (match($0, /^(# at) /) && flag==1 && s_count>0) {print " Query Type : "s_type " " s_count " row(s) affected" ;s_type=""; s_count=0; } \
else if (match($0, /^(COMMIT)/)) {print "[Transaction total : " count " Insert(s) : " insert_count " Update(s) : " update_count " Delete(s) : " \
delete_count "] \n+----------------------+----------------------+----------------------+----------------------+"; \
count=0;insert_count=0;update_count=0; delete_count=0;s_type=""; s_count=0; flag=0} } '
样本输出
Timestamp : #150112 21:40:14 Table : `test`.`t` Query Type : INSERT 1 row(s) affected
Timestamp : #150112 21:40:14 Table : `test`.`t` Query Type : UPDATE 1 row(s) affected
Timestamp : #150112 21:40:14 Table : `test`.`t` Query Type : DELETE 1 row(s) affected
[Transaction total : 3 Insert(s) : 1 Update(s) : 1 Delete(s) : 1]
+----------------------+----------------------+----------------------+----------------------+
0
您可以尝试
Select Row_Count();
相关问题
- 1. 获取FMDB更新查询中受影响的行数
- 2. 获取MySQL更新语句中受影响的行数?
- 3. MySQL获取受影响的行的行ID并在更新后再次更新
- 4. 在MySQL中获取更新值而不是受影响的行
- 5. 在MySQL中查找受影响的字段更新查询
- 6. 获取受影响的行mysql中
- 7. 在MySQL更新中获取所有受影响的rown
- 8. 如何从bash执行MySQL查询时获取受影响的行数?
- 9. MySQL查询0行受到影响
- 10. 在MySQL中更新/删除并获取受影响的行ID列表?
- 11. 返回受更新查询影响的行数?
- 12. 获取受影响的行
- 13. 如何获取Zend_DB_table的受影响行?
- 14. 如何获取INGRES中更新所影响的行数
- 15. 受影响的行数FTS查询
- 16. 获取受更新或插入影响的行数
- 17. {}如何在PHP中影响MySQL查询?
- 18. 在mysql pdo中获取受影响行的列名?
- 19. 在MySQL中插入后获取受影响的行?
- 20. 使用Sequel进行更新后,如何获取受影响的行数?
- 21. 上次查询中受影响行的SQL返回值?
- 22. 如何获取更新只影响一个行(PHP/MySQL的)
- 23. 在多行mongodb更新中受影响的行数
- 24. 获取SQL表的受影响行数
- 25. 如何获取VBA中的受影响行ADO是否执行?
- 26. 如何在以前的MySQL操作中获取受影响的行?
- 27. 我的mysql更新查询有什么问题?受影响的行= 0
- 28. VBA ADODB - 获取受单个查询影响的多行
- 29. 从Node.js更新MySQL - 如何判断零行是否受影响?
- 30. 如何知道在更新查询后有多少行受到影响