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

MySQL에서 별칭에 대해 필터링을 수행하시겠습니까?

<시간/>

이를 위해서는 HAVING 절에 alias를 사용하십시오.

먼저 테이블을 생성하겠습니다 -

mysql> create table DemoTable755 (
   Id int NOT NULL AUTO_INCREMENT PRIMARY KEY,
   Score1 int,
   Score2 int
);
Query OK, 0 rows affected (0.62 sec)

삽입 명령을 사용하여 테이블에 일부 레코드 삽입 -

mysql> insert into DemoTable755(Score1,Score2) values(30,23);
Query OK, 1 row affected (0.18 sec)
mysql> insert into DemoTable755(Score1,Score2) values(50,60);
Query OK, 1 row affected (0.13 sec)
mysql> insert into DemoTable755(Score1,Score2) values(89,90);
Query OK, 1 row affected (0.29 sec)
mysql> insert into DemoTable755(Score1,Score2) values(99,99);
Query OK, 1 row affected (0.18 sec)
mysql> insert into DemoTable755(Score1,Score2) values(40,43);
Query OK, 1 row affected (0.14 sec)

select 문을 사용하여 테이블의 모든 레코드 표시 -

mysql> select *from DemoTable755;

그러면 다음과 같은 출력이 생성됩니다. -

+----+--------+--------+
| Id | Score1 | Score2 |
+----+--------+--------+
|  1 |     30 |     23 |
|  2 |     50 |     60 |
|  3 |     89 |     90 |
|  4 |     99 |     99 |
|  5 |     40 |     43 |
+----+--------+--------+
5 rows in set (0.00 sec)

다음은 MySQL에서 별칭에 대한 필터링을 수행하는 쿼리입니다. 여기에서는 HAVING 절이 있는 쿼리와 같이 점수를 추가하고 일치하는 결과를 표시합니다. 필터링된 레코드는 점수와 함께 ID와 결과를 표시합니다. -

mysql> select Score1+Score2 AS Result,DemoTable755.* from DemoTable755 having Result=83;

그러면 다음과 같은 출력이 생성됩니다. -

+--------+----+--------+--------+
| Result | Id | Score1 | Score2 |
+--------+----+--------+--------+
|     83 |  5 |     40 |     43 |
+--------+----+--------+--------+
1 row in set (0.00 sec)