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

MySQL에서 행 수를 일련 번호로 계산하는 새 열을 어떻게 추가합니까?

<시간/>

행 수를 일련 번호로 계산하는 새 열을 추가하려면 select 문에서 전역 변수를 사용할 수 있습니다.

테이블을 만들어 봅시다. 테이블 생성 쿼리는 다음과 같습니다.

mysql> create table addColumnToCountAsSerialNumber
   -> (
   -> Id int,
   -> Name varchar(20),
   -> Age int,
   -> Salary int
   -> );
Query OK, 0 rows affected (0.80 sec)

삽입 명령을 사용하여 테이블에 일부 레코드를 삽입하십시오. 쿼리는 다음과 같습니다.

mysql> insert into addColumnToCountAsSerialNumber values(10,'John',23,8576);
Query OK, 1 row affected (0.10 sec)
mysql> insert into addColumnToCountAsSerialNumber values(12,'Carol',21,4686);
Query OK, 1 row affected (0.14 sec)
mysql> insert into addColumnToCountAsSerialNumber values(9,'Mike',22,38585);
Query OK, 1 row affected (0.11 sec)
mysql> insert into addColumnToCountAsSerialNumber values(15,'Sam',25,38586);
Query OK, 1 row affected (0.16 sec)
mysql> insert into addColumnToCountAsSerialNumber values(20,'Bob',26,43544);
Query OK, 1 row affected (0.17 sec)
mysql> insert into addColumnToCountAsSerialNumber values(39,'Larry',29,485886);
Query OK, 1 row affected (0.16 sec)

select 문을 사용하여 테이블의 모든 레코드를 표시합니다. 쿼리는 다음과 같습니다.

mysql> select *from addColumnToCountAsSerialNumber ;

다음은 출력입니다.

+------+-------+------+--------+
| Id   | Name  | Age  | Salary |
+------+-------+------+--------+
|   10 | John  |  23 |    8576 |
|   12 | Carol |  21 |    4686 |
|    9 | Mike  |  22 |   38585 |
|   15 | Sam   |  25 |   38586 |
|   20 | Bob   |  26 |   43544 |
|   39 | Larry |  29 |  485886 |
+------+-------+------+--------+
6 rows in set (0.00 sec)

다음은 각 행을 일련 번호로 계산하는 쿼리입니다.

mysql> select @globalVar:=@globalVar+1 RowCount,tblColumns.*
   -> from (select @globalVar:=0) initializeGlobalVariable,addColumnToCountAsSerialNumber tblColumns;

다음은 새 열 "RowCount"에 개수를 표시하는 출력입니다.

+----------+------+-------+------+--------+
| RowCount | Id   | Name  | Age  | Salary |
+----------+------+-------+------+--------+
|        1 |   10 | John  |   23 |   8576 |
|        2 |   12 | Carol |   21 |   4686 |
|        3 |    9 | Mike  |   22 |  38585 |
|        4 |   15 | Sam   |   25 |  38586 |
|        5 |   20 | Bob   |   26 |  43544 |
|        6 |   39 | Larry | 29   | 485886 |
+----------+------+-------+------+--------+
6 rows in set (0.06 sec)