日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網(wǎng)為廣大站長(zhǎng)提供免費(fèi)收錄網(wǎng)站服務(wù),提交前請(qǐng)做好本站友鏈:【 網(wǎng)站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(wù)(50元/站),

點(diǎn)擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會(huì)員:747

本文介紹了刪除MySQL中的記錄,其中id為IN(@Variable)–(2,3,4)的處理方法,對(duì)大家解決問(wèn)題具有一定的參考價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧!

問(wèn)題描述

是否有使用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);

創(chuàng)建變量:

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只從列表中刪除第一個(gè)元素。在本例中,List將包含:(2,3,4)。只有id=2的記錄將被刪除。ID為3、4的記錄將保留在表中。見(jiàn)下圖前后表:

我很清楚我可以使用以下兩種解決方案之一:

子查詢:

-- 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);

如果我們以后需要在不同的查詢中運(yùn)行相同子查詢,并且希望在同一個(gè)表上運(yùn)行INSERT、UPDATE或DELETE操作時(shí)保留原始輸出,則解決方案1不理想。

臨時(shí)表:

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);

這將在同一會(huì)話中保留原始SELECT。

我想知道是否有可能以某種不同的方式使用串聯(lián)變量以使其工作。

推薦答案

建議FIND_IN_SET()會(huì)破壞任何使用索引優(yōu)化該查詢的機(jī)會(huì)。

您希望將變量視為離散整數(shù)列表,而不是恰好包含逗號(hào)和數(shù)字的字符串。這樣,它就可以使用索引來(lái)優(yōu)化匹配。

為此,您必須使用預(yù)準(zhǔn)備語(yǔ)句:

SET @sql = CONCAT('DELETE FROM people WHERE id IN(', @REMOVE, ')');
PREPARE stmt FROM @sql;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;

這篇關(guān)于刪除MySQL中的記錄,其中id為IN(@Variable)–(2,3,4)的文章就介紹到這了,希望我們推薦的答案對(duì)大家有所幫助,

分享到:
標(biāo)簽:3 4) errorDeletingrecordsinMySQLWHEREidIN(@VARIABLE)--(2 exception IT資
用戶無(wú)頭像

網(wǎng)友整理

注冊(cè)時(shí)間:

網(wǎng)站:5 個(gè)   小程序:0 個(gè)  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會(huì)員

趕快注冊(cè)賬號(hào),推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨(dú)大挑戰(zhàn)2018-06-03

數(shù)獨(dú)一種數(shù)學(xué)游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過(guò)答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫(kù),初中,高中,大學(xué)四六

運(yùn)動(dòng)步數(shù)有氧達(dá)人2018-06-03

記錄運(yùn)動(dòng)步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓(xùn)練成績(jī)?cè)u(píng)定2018-06-03

通用課目體育訓(xùn)練成績(jī)?cè)u(píng)定