Run Code
|
API
|
Code Wall
|
Misc
|
Feedback
|
Login
|
Theme
|
Privacy
|
Patreon
MYSQL: Eliminar duplicados mediante nueva tabla - https://es.stackover...
Language:
Ada
Assembly
Bash
C#
C++ (gcc)
C++ (clang)
C++ (vc++)
C (gcc)
C (clang)
C (vc)
Client Side
Clojure
Common Lisp
D
Elixir
Erlang
F#
Fortran
Go
Haskell
Java
Javascript
Kotlin
Lua
MySql
Node.js
Ocaml
Octave
Objective-C
Oracle
Pascal
Perl
Php
PostgreSQL
Prolog
Python
Python 3
R
Rust
Ruby
Scala
Scheme
Sql Server
Swift
Tcl
Visual Basic
Layout:
Vertical
Horizontal
/*MYSQL: Eliminar duplicados mediante nueva tabla - https://es.stackoverflow.com/q/148640/29967*/ /* -- ATENCIÓN NO USE DROP TABLE CON SUS TABLAS REALES -- YA QUE DROP TABLE BORRARÁ SUS DATOS -- DROP TABLE SE USA AQUÍ SÓLO PARA PODER PROBAR LOS DATOS */ DROP TABLE IF EXISTS usuarios; DROP TABLE IF EXISTS usuarios_copy; /* NO COPIE LA SENTENCIA ^ DROP TABLE ^ EN SUS DATOS REALES */ -- Datos de prueba CREATE TABLE usuarios ( id INT PRIMARY KEY AUTO_INCREMENT, first_name VARCHAR(50) NOT NULL, last_name VARCHAR(50) NOT NULL, email VARCHAR(255) NOT NULL ); INSERT INTO usuarios (first_name,last_name,email) VALUES ('Pedro ','Pérez','p.pedro@gmail.com'), ('Juan','Roa','r.juan@icloud.com'), ('Santiago','Guerrero','g.santiago@hotmail.com'), ('Juan','Roa','r.juan@icloud.com'), ('Andrés ','Brito','b.andres@live.com'), ('Juan','Roa','r.juan@icloud.com'), ('Santiago','Guerrero','g.santiago@hotmail.com'), ('Felipe','Castro','c.felipe@me.com') ; /* Prueba de datos antes de borrar*/ SELECT id, email FROM usuarios ORDER BY email; -- II. Borrar mediante creación de otra tabla /* 1. Creamos la nueva tabla basada en la estructura de la antigua usando LIKE */ CREATE TABLE usuarios_copy LIKE usuarios; /* 2. Insertamos los datos desde la antigua tabla en la nueva discriminando los repetidos mediante GROUP BY sabiendo que en el GROUP BY debemos poner la columna en cuestión */ INSERT INTO usuarios_copy SELECT NULL, first_name, last_name, email FROM usuarios GROUP BY email; -- Poner en el GROUP BY la columna repetida /* 3. Borramos la tabla antigua y renombramos la nueva tabla con el nombre de la antigua */ DROP TABLE usuarios; ALTER TABLE usuarios_copy RENAME TO usuarios; -- Prueba de datos sobre la tabla final SELECT id, email FROM usuarios ORDER BY id; -- III. Restringir duplicados ALTER TABLE usuarios ADD UNIQUE (email); /* Prueba de la nueva restricción creada: al descomentar el código tendremos el siguiente error: Error(s), warning(s): Duplicate entry 'p.pedro@gmail.com' for key 'email' */ -- INSERT INTO usuarios (first_name,last_name,email) VALUES ('Pedro ','Pérez','p.pedro@gmail.com');
absolute service time: 0,38 sec
edit mode
|
history
id
email
1
5
b.andres@live.com
2
8
c.felipe@me.com
3
3
g.santiago@hotmail.com
4
7
g.santiago@hotmail.com
5
1
p.pedro@gmail.com
6
2
r.juan@icloud.com
7
4
r.juan@icloud.com
8
6
r.juan@icloud.com
id
email
1
1
b.andres@live.com
2
2
c.felipe@me.com
3
3
g.santiago@hotmail.com
4
4
p.pedro@gmail.com
5
5
r.juan@icloud.com