Computer >> 컴퓨터 >  >> 프로그램 작성 >> MySQL

레코드를 주문하지만 특정 이름을 수정하고 나머지 값(일부만)을 무작위로 표시하는 MySQL 쿼리

<시간/>

이를 위해 LIMIT와 함께 ORDER BY RAND()를 사용할 수 있습니다. 먼저 −

를 생성해 보겠습니다.
mysql> create table DemoTable1426
   -> (
   -> FirstName varchar(20)
   -> );
Query OK, 0 rows affected (0.59 sec)

insert −

를 사용하여 테이블에 일부 레코드 삽입
mysql> insert into DemoTable1426 values('John');
Query OK, 1 row affected (0.17 sec)
mysql> insert into DemoTable1426 values('Adam');
Query OK, 1 row affected (0.10 sec)
mysql> insert into DemoTable1426 values('Robert');
Query OK, 1 row affected (0.12 sec)
mysql> insert into DemoTable1426 values('David');
Query OK, 1 row affected (0.12 sec)
mysql> insert into DemoTable1426 values('Sam');
Query OK, 1 row affected (0.13 sec)

select −

를 사용하여 테이블의 모든 레코드 표시
mysql> select * from DemoTable1426;

이것은 다음과 같은 출력을 생성합니다 -

+-----------+
| FirstName |
+-----------+
| John      |
| Adam      |
| Robert    |
| David     |
| Sam       |
+-----------+
5 rows in set (0.00 sec)

다음은 레코드를 정렬하지만 특정 이름을 수정하고 나머지 값(일부만)을 표시하는 쿼리입니다. random -

mysql> select * from DemoTable1426 order by (FirstName='Robert') desc,RAND()
   -> limit 3;

이것은 다음과 같은 출력을 생성합니다 -

+-----------+
| FirstName |
+-----------+
| Robert    |
| Adam      |
| David     |
+-----------+
3 rows in set (0.52 sec)