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

MySQL 쿼리에서 SELECT를 사용하여 INSERT INTO를 수행하는 동안 정적 값을 추가하는 방법은 무엇입니까?

<시간/>

INSERT INTO SELECT MySQL 쿼리를 사용할 때 정적 값을 추가할 수 있습니다. select 문에 직접 값을 쓰거나 값을 초기화하는 변수의 도움으로 추가할 수 있습니다.

사례 1 − 값을 INSERT INTO SELECT 문에 직접 배치합니다. 구문은 다음과 같습니다 -

INSERT INTO yourSecondTableName(yourColumnName1,yourColumnName2,....N)
   SELECT yourColumnName1 ,yourColumnName2,.....N,yourStaticValue from yourFirstTableName;

사례 2 − 변수를 사용하여 추가합니다. 구문은 다음과 같습니다 -

SET @yourVariableName − = yourstaticValue;
   INSERT INTO yourSecondTableName(yourColumnName1,yourColumnName2,....N)
   SELECT yourColumnName1 ,yourColumnName2,.....N,@yourVariableName from yourFirstTableName;

위의 구문을 이해하려면 두 개의 테이블을 생성해야 합니다. 첫 번째 테이블에는 테이블에 일부 레코드가 있는 반면 두 번째 테이블은 insert into select 문을 사용하여 첫 번째 테이블 레코드를 삽입하고 정적 값을 추가합니다.

첫 번째 테이블을 생성해 보겠습니다. 테이블을 생성하는 쿼리는 다음과 같습니다 -

mysql> create table First_table
   -> (
   -> Id int NOT NULL AUTO_INCREMENT,
   -> FirstValue int,
   -> SecondValue int,
   -> PRIMARY KEY(Id)
   -> );
Query OK, 0 rows affected (0.56 sec)

이제 insert 명령을 사용하여 테이블에 일부 레코드를 삽입할 수 있습니다. 쿼리는 다음과 같습니다 -

mysql> insert into First_table(FirstValue,SecondValue) values(10,14);
Query OK, 1 row affected (0.20 sec)

mysql> insert into First_table(FirstValue,SecondValue) values(12,13);
Query OK, 1 row affected (0.52 sec)

mysql> insert into First_table(FirstValue,SecondValue) values(100,110);
Query OK, 1 row affected (0.14 sec)

mysql> insert into First_table(FirstValue,SecondValue) values(45,55);
Query OK, 1 row affected (0.27 sec)

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

mysql> select *from First_table;

다음은 출력입니다 -

+----+------------+-------------+
| Id | FirstValue | SecondValue |
+----+------------+-------------+
|  1 |         10 |          14 |
|  2 |         12 |          13 |
|  3 |        100 |         110 |
|  4 |         45 |          55 |
+----+------------+-------------+
4 rows in set (0.00 sec)

두 번째 테이블을 생성해 보겠습니다. 테이블을 생성하는 쿼리는 다음과 같습니다 -

mysql> create table Second_table
   -> (
   -> Id int NOT NULL AUTO_INCREMENT,
   -> Value1 int,
   -> Value2 int,
   -> Value3 int,
   -> PRIMARY KEY(Id)
   -> );
Query OK, 0 rows affected (0.81 sec)

위의 표에는 두 개의 열이 첫 번째 테이블에서 값을 가져오고 세 번째 열이 직접 또는 간접적으로 값을 가져오는 세 개의 열이 있습니다.

쿼리 INSERT INTO SELECT 문은 다음과 같습니다 -

사례 1 − 세 번째 열에 정적 값을 추가합니다. 쿼리는 다음과 같습니다 -

mysql> insert into Second_table(Value1,Value2,Value3)
   -> select FirstValue,SecondValue,45 from First_table;
Query OK, 4 rows affected (0.16 sec)
Records − 4 Duplicates − 0 Warnings − 0

여기에서 세 번째 열에 45를 추가했습니다. 이제 select 문을 사용하여 테이블의 모든 레코드를 확인하십시오. 쿼리는 다음과 같습니다 -

mysql> select *from Second_table;

다음은 출력입니다 -

+----+--------+--------+--------+
| Id | Value1 | Value2 | Value3 |
+----+--------+--------+--------+
|  1 |     10 |     14 | 45     |
|  2 |     12 |     13 | 45     |
|  3 |    100 |    110 | 45     |
|  4 |     45 |     55 | 45     |
+----+--------+--------+--------+
4 rows in set (0.00 sec)

사례 2 − 변수를 사용할 때. 쿼리는 다음과 같습니다 -

mysql> set @staticValue − = 20;
Query OK, 0 rows affected (0.00 sec)

mysql> insert into Second_table(Value1,Value2,Value3)
   -> select FirstValue,SecondValue,@staticValue from First_table;
Query OK, 4 rows affected (0.19 sec)
Records − 4 Duplicates − 0 Warnings − 0

세 번째 열에 값 20을 추가합니다. select 문을 이용하여 테이블의 레코드를 다시 한 번 확인해보자. 쿼리는 다음과 같습니다 -

mysql> select *from Second_table;

다음은 출력입니다 -

+----+--------+--------+--------+
| Id | Value1 | Value2 | Value3 |
+----+--------+--------+--------+
|  1 |     10 |     14 |     20 |
|  2 |     12 |     13 |     20 |
|  3 |    100 |    110 |     20 |
|  4 |     45 |     55 |     20 |
+----+--------+--------+--------+
4 rows in set (0.00 sec)