먼저 테이블을 생성하겠습니다 -
mysql> create table DemoTable ( Id int NOT NULL AUTO_INCREMENT PRIMARY KEY, Value char(1) ); Query OK, 0 rows affected (0.66 sec)
삽입 명령을 사용하여 테이블에 일부 레코드 삽입 -
mysql> insert into DemoTable(Value) values('X'); Query OK, 1 row affected (0.20 sec) mysql> insert into DemoTable(Value) values('Y'); Query OK, 1 row affected (0.09 sec) mysql> insert into DemoTable(Value) values('X'); Query OK, 1 row affected (0.30 sec) mysql> insert into DemoTable(Value) values('X'); Query OK, 1 row affected (0.07 sec) mysql> insert into DemoTable(Value) values('Y'); Query OK, 1 row affected (0.17 sec) mysql> insert into DemoTable(Value) values('Z'); Query OK, 1 row affected (0.13 sec) mysql> insert into DemoTable(Value) values('Z'); Query OK, 1 row affected (0.11 sec)
select 문을 사용하여 테이블의 모든 레코드 표시 -
mysql> select *from DemoTable;
이것은 다음과 같은 출력을 생성합니다 -
+----+-------+ | Id | Value | +----+-------+ | 1 | X | | 2 | Y | | 3 | X | | 4 | X | | 5 | Y | | 6 | Z | | 7 | Z | +----+-------+ 7 rows in set (0.00 sec)
사례 1 − 다음은 그룹화할 쿼리이지만 무작위로 −
mysql> select DemoTable.* from DemoTable join ( select Value, rand() as `random_Value` from DemoTable group by Value ) tbl2 on DemoTable.Value = tbl2.Value order by tbl2.`random_Value`;
이것은 다음과 같은 출력을 생성합니다 -
+----+-------+ | Id | Value | +----+-------+ | 6 | Z | | 7 | Z | | 1 | X | | 3 | X | | 4 | X | | 2 | Y | | 5 | Y | +----+-------+ 7 rows in set (0.00 sec)
사례 2 − 임의의 레코드를 표시하고 있으므로 위 쿼리를 다시 실행하여 표시해 보겠습니다. −
mysql> select DemoTable.* from DemoTable join ( select Value, rand() as `random_Value` from DemoTable group by Value ) tbl2 on DemoTable.Value = tbl2.Value order by tbl2.`random_Value`;
이것은 다음과 같은 출력을 생성합니다 -
+----+-------+ | Id | Value | +----+-------+ | 2 | Y | | 5 | Y | | 6 | Z | | 7 | Z | | 1 | X | | 3 | X | | 4 | X | +----+-------+ 7 rows in set (0.00 sec)