Dubbele entries verwijderen uit MySQL database

Status
Niet open voor verdere reacties.

Acario

Gebruiker
Lid geworden
28 jul 2010
Berichten
5
Goedendag allen,

Ik heb momenteel in mijn MySQL woordenboek-database enkele honderden woorden inclusief vertalingen staan (met auto-increment).

Echter, sommige rijen bevatten dezelfde woorden inclusief dezelfde vertalingen, denk aan:
id woord vertaling
-----------------
1 zand sand
2 boom tree
3 bloem flower
4 boom tree
5 vogel bird

(dat zijn dus 4 rijen en 3 kolommen)

Zoals te zien is, rij 2 en rij 4 zijn qua inhoud hetzelfde (behalve de id-waarde). Dat wil ik dus niet hebben in de database. Ik wil slechts dat ieder woord (en vertaling) slechts één keer voorkomt.

Weet iemand met welke code ik dit in MyPHPAdmin kan oplossen? Dus alle dubbele entries verwijderen? Kan deze code ook hoofdletter-ongevoelig worden gemaakt?
 
Je kunt voor het selecteren de optie DISTINCT gebruiken, dan neemt hij iig de dubbele niet mee in zijn output.

succes...!
 
volgens mij zal je je structuur moeten zetten op UNIQUE zie onderstaande text
maar weet dat er ook .properties files bestaan voor vertalingsystemen

LET OP je werkt mogelijks van een bestaand systeem het mogelijkdat die rij structuur niet kan aangepast worden als er dubbele al in staan
Code:
12.2.4.3. INSERT ... ON DUPLICATE KEY UPDATE Syntax
If you specify ON DUPLICATE KEY UPDATE, and a row is inserted that would cause a duplicate value in a UNIQUE index or PRIMARY KEY, an UPDATE of the old row is performed. For example, if column a is declared as UNIQUE and contains the value 1, the following two statements have identical effect: 

INSERT INTO table (a,b,c) VALUES (1,2,3)
  ON DUPLICATE KEY UPDATE c=c+1;

UPDATE table SET c=c+1 WHERE a=1;

With ON DUPLICATE KEY UPDATE, the affected-rows value per row is 1 if the row is inserted as a new row and 2 if an existing row is updated. 

If column b is also unique, the INSERT is equivalent to this UPDATE statement instead: 

UPDATE table SET c=c+1 WHERE a=1 OR b=2 LIMIT 1;

If a=1 OR b=2 matches several rows, only one row is updated. In general, you should try to avoid using an ON DUPLICATE KEY clause on tables with multiple unique indexes. 

The ON DUPLICATE KEY UPDATE clause can contain multiple column assignments, separated by commas. 

You can use the VALUES(col_name) function in the UPDATE clause to refer to column values from the INSERT portion of the INSERT ... UPDATE statement. In other words, VALUES(col_name) in the UPDATE clause refers to the value of col_name that would be inserted, had no duplicate-key conflict occurred. This function is especially useful in multiple-row inserts. The VALUES() function is meaningful only in INSERT ... UPDATE statements and returns NULL otherwise. Example: 

INSERT INTO table (a,b,c) VALUES (1,2,3),(4,5,6)
  ON DUPLICATE KEY UPDATE c=VALUES(a)+VALUES(b);

That statement is identical to the following two statements: 

INSERT INTO table (a,b,c) VALUES (1,2,3)
  ON DUPLICATE KEY UPDATE c=3;
INSERT INTO table (a,b,c) VALUES (4,5,6)
  ON DUPLICATE KEY UPDATE c=9;

If a table contains an AUTO_INCREMENT column and INSERT ... UPDATE inserts a row, the LAST_INSERT_ID() function returns the AUTO_INCREMENT value. If the statement updates a row instead, LAST_INSERT_ID() is not meaningful. However, you can work around this by using LAST_INSERT_ID(expr). Suppose that id is the AUTO_INCREMENT column. To make LAST_INSERT_ID() meaningful for updates, insert rows as follows: 

INSERT INTO table (a,b,c) VALUES (1,2,3)
  ON DUPLICATE KEY UPDATE id=LAST_INSERT_ID(id), c=3;

The DELAYED option is ignored when you use ON DUPLICATE KEY UPDATE.
 
Status
Niet open voor verdere reacties.

Nieuwste berichten

Terug
Bovenaan Onderaan