這期內容當中小編將會給大家?guī)碛嘘Pkill指令怎么正確的在MySQL數據庫中使用,文章內容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
成都創(chuàng)新互聯公司是一家專注于成都網站制作、成都網站建設與策劃設計,廣南網站建設哪家好?成都創(chuàng)新互聯公司做網站,專注于網站建設10多年,網設計領域的專業(yè)建站公司;建站業(yè)務涵蓋:廣南等地區(qū)。廣南做網站價格咨詢:18980820575KILL [CONNECTION | QUERY] processlist_id
在Mysql中每個連接都是單獨線程運行,可以使用語句 KILL processlist_id statement.來終止語句執(zhí)行。
KILL允許可選 CONNECTION或QUERY 修飾符:
KILL CONNECTION ,KILL與無修飾符相同 :終止與給定關聯的連接 processlist_id,在終止該連接正在執(zhí)行的任何語句之后。
KILL QUERY終止連接當前正在執(zhí)行的語句,但保持連接本身不變。
使用show processlist 查看所有id
如果我們應用執(zhí)行SQL后,由于鎖select for update或者數量太大,導致執(zhí)行SQL卡在數據庫,此時想取消該SQL怎么辦?可以通過kill命令停止mysql線程或者是取消該SQL執(zhí)行,此處需要到底是執(zhí)行 kill threadId指令還是 kill query theadId指令?
kill與kill query 較大區(qū)別是是否取消該連接上執(zhí)行的所有sql,即是否關閉該線程,如果關閉該線程即對應JDBC中statement關閉
-- 數據庫鎖住acctno=13記錄 然后執(zhí)行如下更新語句 update test set acctname ='12' where acctno=13
show processlist查看正在執(zhí)行sql的線程id
如果想取消該SQL執(zhí)行,可以使用命令 kill query 407 取消SQL執(zhí)行,執(zhí)行后407線程并不會消失,如果該連接上有SQL執(zhí)行會繼續(xù)執(zhí)行;但是如果使用kill 407 ,407線程會消失。使用時需要注意二者差異。
線程id除了通過show processlist查看,也可以使用編程的方式獲取threadId
Connection connection = getConnection(); ((MysqlConnection)connection).getSession().getThreadId();
我們使用JDBC編程方式對數據庫進行操作時,可以也可以使用Statement對象的cancel方法進行取消,Mysql驅動內部也是發(fā)送Kill query threadId 指令,Mysql驅動cancel方法源碼
public void cancel() throws SQLException { try { if (this.query.getStatementExecuting().get()) { if (!this.isClosed && this.connection != null) { JdbcConnection cancelConn = null; Object cancelStmt = null; try { HostInfo hostInfo = this.session.getHostInfo(); String database = hostInfo.getDatabase(); String user = StringUtils.isNullOrEmpty(hostInfo.getUser()) ? "" : hostInfo.getUser(); String password = StringUtils.isNullOrEmpty(hostInfo.getPassword()) ? "" : hostInfo.getPassword(); NativeSession newSession = new NativeSession(this.session.getHostInfo(), this.session.getPropertySet()); newSession.connect(hostInfo, user, password, database, 30000, new TransactionEventHandler() { public void transactionCompleted() { } public void transactionBegun() { } }); //驅動內部使用 KILL QUERY + threadId 指令取消 newSession.sendCommand((new NativeMessageBuilder()).buildComQuery(newSession.getSharedSendPacket(), "KILL QUERY " + this.session.getThreadId()), false, 0); this.setCancelStatus(CancelStatus.CANCELED_BY_USER); } catch (IOException var13) { throw SQLExceptionsMapping.translateException(var13, this.exceptionInterceptor); } finally { if (cancelStmt != null) { ((Statement)cancelStmt).close(); } if (cancelConn != null) { ((JdbcConnection)cancelConn).close(); } } } } } catch (CJException var15) { throw SQLExceptionsMapping.translateException(var15, this.getExceptionInterceptor()); } }
客戶端工具執(zhí)行SQL后取消執(zhí)行,有些工具發(fā) kill 命令 有些發(fā)kill query 指令,可以通過抓包工具驗證下Navicat工具發(fā)送什么指令,抓包工具推薦Wireshark,很強大。
是kill 指令,對應的線程ID為407,也有部分工具是發(fā)送的kill query指令。
上述就是小編為大家分享的kill指令怎么正確的在MySQL數據庫中使用了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注創(chuàng)新互聯行業(yè)資訊頻道。