亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

So entfernen Sie Duplikate in einer SQL-Tabelle basierend auf mehreren Feldern
P粉757556355
P粉757556355 2023-10-20 12:01:14
0
2
769

Ich habe einen Spieltisch mit der folgenden Beschreibung:

+---------------+-------------+------+-----+---------+----------------+
| Field         | Type        | Null | Key | Default | Extra          |
+---------------+-------------+------+-----+---------+----------------+
| id            | int(11)     | NO   | PRI | NULL    | auto_increment |
| date          | date        | NO   |     | NULL    |                |
| time          | time        | NO   |     | NULL    |                |
| hometeam_id   | int(11)     | NO   | MUL | NULL    |                |
| awayteam_id   | int(11)     | NO   | MUL | NULL    |                |
| locationcity  | varchar(30) | NO   |     | NULL    |                |
| locationstate | varchar(20) | NO   |     | NULL    |                |
+---------------+-------------+------+-----+---------+----------------+

Aber jedes Spiel hat irgendwo in der Tabelle einen doppelten Eintrag, weil jedes Spiel im Spielplan beider Teams steht. Gibt es eine SQL-Anweisung, mit der ich alle Duplikate basierend auf denselben Feldern für Datum, Uhrzeit, Heimteam-ID, Ausw?rtsteam-ID, Standortstadt und Standortstatus anzeigen und entfernen kann?

P粉757556355
P粉757556355

Antworte allen(2)
P粉781235689

您可以嘗試這樣的查詢:

DELETE FROM table_name AS t1
WHERE EXISTS (
 SELECT 1 FROM table_name AS t2 
 WHERE t2.date = t1.date 
 AND t2.time = t1.time 
 AND t2.hometeam_id = t1.hometeam_id 
 AND t2.awayteam_id = t1.awayteam_id 
 AND t2.locationcity = t1.locationcity 
 AND t2.id > t1.id )

這將在數(shù)據(jù)庫中僅保留每個(gè)具有最小 ID 的游戲?qū)嵗囊粋€(gè)示例。

P粉201448898

您應(yīng)該能夠執(zhí)行相關(guān)子查詢來刪除數(shù)據(jù)。查找所有重復(fù)的行并刪除除 id 最小的行之外的所有行。對(duì)于 MYSQL,需要使用內(nèi)連接(相當(dāng)于 EXISTS 的功能),如下所示:

delete games from games inner join 
    (select  min(id) minid, date, time,
             hometeam_id, awayteam_id, locationcity, locationstate
     from games 
     group by date, time, hometeam_id, 
              awayteam_id, locationcity, locationstate
     having count(1) > 1) as duplicates
   on (duplicates.date = games.date
   and duplicates.time = games.time
   and duplicates.hometeam_id = games.hometeam_id
   and duplicates.awayteam_id = games.awayteam_id
   and duplicates.locationcity = games.locationcity
   and duplicates.locationstate = games.locationstate
   and duplicates.minid <> games.id)

要進(jìn)行測試,請(qǐng)將從游戲中刪除游戲替換為從游戲中選擇*。不要只是在數(shù)據(jù)庫上運(yùn)行刪除:-)

Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage