sql >> Base de Datos >  >> RDS >> Mysql

Cómo se mezclan los resultados entre dos tablas cuando se usa UNION

Si desea alternar filas a partir de los resultados de una unión, deberá otorgar a cada una de ellas un rango que aumente en dos:uno para probabilidades y otro para pares.

select @rank := @rank + 2 `rank`, *
  from table1, (select @rank := -1) q
    where column1 = 'anything'
union all
select @rank2 := @rank2 + 2 `rank`, *
  from table2, (select @rank2 := 0) q
    where column1 = 'anything'
order by rank asc;

sqlfiddle parece estar inactivo, de lo contrario crearía una demostración, pero debería funcionar.

@rank y @rank2 son variables. @rank2 := @rank2 + 2 incrementa @rank por 2 para cada fila en el conjunto de resultados e incluye el nuevo valor en los resultados.from table2, (select @rank2 := 0) q es solo una forma de forzar la inicialización de la variable a 0 sin tener que ejecutar consultas adicionales. Al iniciar el contador de clasificación en -1 para la primera consulta, y -0 para la segunda consulta, cada fila de la primera consulta recibe un rango en la secuencia 1,3,5,7,... , y cada fila en la segunda consulta recibe un rango en la secuencia 2,4,6,8,...

ejemplo

mysql> create table table1 (id integer primary key auto_increment, column1 varchar(25));
Query OK, 0 rows affected (0.08 sec)

mysql> create table table2 (id integer primary key auto_increment, column1 varchar(25));
Query OK, 0 rows affected (0.08 sec)

mysql> insert into table1 (column1) values ('abcd'), ('lmno'), ('abcd'), ('lmno'), ('pqr');
Query OK, 5 rows affected (0.03 sec)
Records: 5  Duplicates: 0  Warnings: 0

mysql> insert into table2 (column1) values ('lmno'), ('abcd'), ('abcd'), ('lmno'), ('abcd'), ('abcd'), ('abcd');
Query OK, 7 rows affected (0.05 sec)
Records: 7  Duplicates: 0  Warnings: 0

y los datos:

mysql> select * from table1;
+----+---------+
| id | column1 |
+----+---------+
|  1 | abcd    |
|  2 | lmno    |
|  3 | abcd    |
|  4 | lmno    |
|  5 | pqr     |
+----+---------+
5 rows in set (0.00 sec)

mysql> select * from table2;
+----+---------+
| id | column1 |
+----+---------+
|  1 | lmno    |
|  2 | abcd    |
|  3 | abcd    |
|  4 | lmno    |
|  5 | abcd    |
|  6 | abcd    |
|  7 | abcd    |
+----+---------+
7 rows in set (0.00 sec)

y el resultado:

mysql> select @rank := @rank + 2 `rank`, id from table1, (select @rank := -1) q where column1 = 'abcd' union select @rank2 := @rank2 + 2 `rank`, id from table2, (select @rank2 := 0) q where column1 = 'abcd' order by rank asc;
+------+----+
| rank | id |
+------+----+
|    1 |  1 |
|    2 |  2 |
|    3 |  3 |
|    4 |  3 |
|    6 |  5 |
|    8 |  6 |
|   10 |  7 |
+------+----+
7 rows in set (0.00 sec)