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

MySQL의 다른 테이블에 있는 데이터에서 한 테이블의 데이터를 업데이트하시겠습니까?

<시간/>

이를 위해 JOIN과 함께 UPDATE 명령을 사용할 수 있습니다.

첫 번째 테이블을 만들어 보겠습니다 -

mysql> create table demo54
−> (
−> firstName varchar(20),
−> lastName varchar(20)
−> );
Query OK, 0 rows affected (0.57 sec)

insert 명령을 사용하여 일부 레코드를 테이블에 삽입하십시오 -

mysql> insert into demo54 values('John','Smith');
Query OK, 1 row affected (0.09 sec)

mysql> insert into demo54 values('John','Smith');
Query OK, 1 row affected (0.09 sec)

mysql> insert into demo54 values('David','Smith');
Query OK, 1 row affected (0.11 sec)

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

mysql> select *from demo54;

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

+-----------+----------+
| firstName | lastName |
+-----------+----------+
| John      | Smith    |
| John      | Smith    |
| David     | Smith    |
+-----------+----------+
3 rows in set (0.00 sec)

다음은 두 번째 테이블을 생성하는 쿼리입니다 -

mysql> create table demo55
−> (
−> firstName varchar(20),
−> lastName varchar(20)
−> );
Query OK, 0 rows affected (1.93 sec)

insert 명령을 사용하여 일부 레코드를 테이블에 삽입하십시오 -

mysql> insert into demo55 (firstName) values('John');
Query OK, 1 row affected (0.10 sec)

mysql> insert into demo55 (firstName) values('David');
Query OK, 1 row affected (0.13 sec)

mysql> insert into demo55 (firstName) values('Bob');
Query OK, 1 row affected (0.10 sec)

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

mysql> select *from demo55;

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

+-----------+----------+
| firstName | lastName |
+-----------+----------+
| John      | NULL     |
| David     | NULL     |
| Bob       | NULL     |
+-----------+----------+
3 rows in set (0.00 sec)

다음은 한 테이블의 데이터를 다른 테이블에서 업데이트하는 쿼리입니다.

mysql> UPDATE demo55 tbl1
−> JOIN demo54 tbl2 ON tbl1.firstName = tbl2.firstName
−> set tbl1.lastName = tbl2.lastName;
Query OK, 2 rows affected (0.10 sec)
Rows matched: 2 Changed: 2 Warnings: 0

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

mysql> select *from demo55;

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

+-----------+----------+
| firstName | lastName |
+-----------+----------+
| John      | Smith    |
| David     | Smith    |
| Bob       | NULL     |
+-----------+----------+
3 rows in set (0.00 sec)