Mysql uses the kill command to solve the deadlock problem (kill a certain SQL statement being executed)

Mysql uses the kill command to solve the deadlock problem (kill a certain SQL statement being executed)

When using MySQL to run certain statements, a deadlock may occur due to the large amount of data, and no response will be given. At this time, you need to kill a query statement that is consuming resources. The syntax format of the KILL command is as follows:

KILL [CONNECTION | QUERY] thread_id

Each connection to mysqld runs in a separate thread. You can use the SHOW PROCESSLIST statement to see which threads are running and the KILL thread_id statement to kill a thread.

KILL allows optional CONNECTION or QUERY modifiers: KILL CONNECTION is the same as KILL with no modifiers: it terminates the connection associated with the given thread_id. KILL QUERY terminates the statement currently executing on the connection, but leaves the connection intact.

If you have PROCESS permission, you can view all threads. If you have super administrator privileges, you can terminate all threads and statements. Otherwise, you can view and terminate only your own threads and statements. You can also use the mysqladmin processlist and mysqladmin kill commands to examine and kill threads.

First log in to MySQL, and then use: show processlist; to view the status of each thread in the current MySQL.

mysql> show processlist; 
+------+------+----------------------+----------------+---------+-------+-----------+--------------------  
| Id | User | Host | db | Command | Time | State | Info 
+------+------+----------------------+----------------+---------+-------+-----------+--------------------  
| 7028 | root | ucap-devgroup:53396 | platform | Sleep | 19553 | | NULL  
| 8352 | root | ucap-devgroup:54794 | platform | Sleep | 4245 | | NULL 
| 8353 | root | ucap-devgroup:54795 | platform | Sleep | 3 | | NULL 
| 8358 | root | ucap-devgroup:62605 | platform | query | 4156 | updating | update t_shop set |

The above shows the list of SQL statements currently being executed, and finds the id corresponding to the statement that consumes the most resources.

Then run the kill command. The command format is as follows:

kill id; 
- Example: 
kill 8358

Just kill it.

You may also be interested in:
  • mysql show processlist displays the mysql query process
  • Reasons why MySQL kill cannot kill threads
  • How to view and kill processes in MYSQL

<<:  How to use glog log library in Linux environment

>>:  Which loop is the fastest in JavaScript?

Recommend

Use CSS to implement special logos or graphics

1. Introduction Since pictures take up a lot of s...

Example of how to identify the user using a linux Bash script

It is often necessary to run commands with sudo i...

5 cool and practical HTML tags and attributes introduction

In fact, this is also a clickbait title, and it c...

Eight rules for effective web forms

If you're collecting information from your us...

How to query a record in Mysql in which page of paging

Preface In practice, we may encounter such a prob...

Web Design Tutorial (8): Web Page Hierarchy and Space Design

<br />Previous article: Web Design Tutorial ...

The process of building lamp architecture through docker container

Table of contents 1. Pull the centos image 2. Bui...

In-depth understanding of the matching logic of Server and Location in Nginx

Server matching logic When Nginx decides which se...

30 excellent examples of color matching in web design

Today, this article has collected 30 excellent cas...

Example code of how to create a collapsed header effect using only CSS

Collapsed headers are a great solution for displa...

Solution to MySQL remote connection failure

I have encountered the problem that MySQL can con...

Two ways to build Docker images

Table of contents Update the image from an existi...

MySQL batch adding and storing method examples

When logging in to the stress test, many differen...