本文介紹了刪除MySQL中的記錄,其中id為IN(@Variable)–(2,3,4)的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!
問題描述
是否有使用WHERE IN @VARIABLE
刪除記錄的方法?
-- DEMO TABLE
CREATE TABLE people (
id int AUTO_INCREMENT NOT NULL,
name varchar(100),
age int,
active smallint DEFAULT 0,
PRIMARY KEY (id)
);
-- DEMO DATA
INSERT INTO people(id, name, age, active)
VALUES
(1, 'Jon', 37, 1),
(2, 'Jack', 23, 0),
(3, 'Peter', 24, 0),
(4, 'Phil', 55, 0);
創建變量:
SELECT @REMOVE := GROUP_CONCAT(id) FROM people WHERE active < 1; -- (2,3,4)
我正在嘗試從字符串中刪除連接的變量。
DELETE FROM people WHERE id IN(@REMOVE); -- will delete only first id which is id nr 2
上述SQL只從列表中刪除第一個元素。在本例中,List將包含:(2,3,4)。只有id=2的記錄將被刪除。ID為3、4的記錄將保留在表中。見下圖前后表:
我很清楚我可以使用以下兩種解決方案之一:
子查詢:
-- SOLUTION 1 - USEING NESTED SELECT SUB QUERY WITH AN ALIAS
DELETE FROM people WHERE id IN(SELECT * FROM (SELECT id FROM people WHERE active < 1) as temp);
如果我們以后需要在不同的查詢中運行相同子查詢,并且希望在同一個表上運行INSERT、UPDATE或DELETE操作時保留原始輸出,則解決方案1不理想。
或
臨時表:
CREATE TEMPORARY TABLE temp_remove_people (id int NOT NULL PRIMARY KEY);
INSERT INTO temp_remove_people SELECT id FROM people WHERE active < 1;
DELETE FROM people WHERE id IN(SELECT id FROM temp_remove_people);
這將在同一會話中保留原始SELECT。
我想知道是否有可能以某種不同的方式使用串聯變量以使其工作。
推薦答案
建議FIND_IN_SET()會破壞任何使用索引優化該查詢的機會。
您希望將變量視為離散整數列表,而不是恰好包含逗號和數字的字符串。這樣,它就可以使用索引來優化匹配。
為此,您必須使用預準備語句:
SET @sql = CONCAT('DELETE FROM people WHERE id IN(', @REMOVE, ')');
PREPARE stmt FROM @sql;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
這篇關于刪除MySQL中的記錄,其中id為IN(@Variable)–(2,3,4)的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,