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

데이터, 트리거 및 인덱스와 함께 테이블을 어떻게 복제/복제할 수 있습니까?

<시간/>

데이터, 트리거 및 인덱스와 함께 이전 테이블과 같은 새 테이블을 생성하려면 다음 두 쿼리를 실행해야 합니다.

CREATE TABLE new_table LIKE old_table;
INSERT new_table SELECT * from old_table;

예시

mysql> Create table employee(ID INT PRIMARY KEY NOT NULL AUTO_INCREMENT, NAME VARCHAR(20));
Query OK, 0 rows affected (0.21 sec)

mysql> Describe employee;
+-------+-------------+------+-----+---------+----------------+
| Field | Type        | Null | Key | Default | Extra          |
+-------+-------------+------+-----+---------+----------------+
| ID    | int(11)     | NO   | PRI | NULL    | auto_increment |
| NAME  | varchar(20) | YES  |     | NULL    |                |
+-------+-------------+------+-----+---------+----------------+
2 rows in set (0.07 sec)

mysql> Insert into employee(name) values('Gaurav'),('Raman');
Query OK, 2 rows affected (0.07 sec)
Records: 2 Duplicates: 0 Warnings: 0

mysql> Select * from employee;
+----+--------+
| ID | NAME   |
+----+--------+
| 1  | Gaurav |
| 2  | Raman  |
+----+--------+
2 rows in set (0.00 sec)

아래 쿼리는 테이블 employee와 유사한 구조를 갖는 테이블 employee1을 생성할 것입니다. DESCRIBE 쿼리를 실행하여 확인할 수 있습니다.

mysql> create table employee1 like employee;
Query OK, 0 rows affected (0.19 sec)

mysql> describe employee1;
+-------+-------------+------+-----+---------+----------------+
| Field | Type        | Null | Key | Default | Extra          |
+-------+-------------+------+-----+---------+----------------+
| ID    | int(11)     | NO   | PRI | NULL    | auto_increment |
| NAME  | varchar(20) | YES  |     | NULL    |                |
+-------+-------------+------+-----+---------+----------------+
2 rows in set (0.14 sec)

이제 아래 쿼리는 employee1에 동일한 값을 삽입하며 아래와 같이 확인할 수 있습니다.

mysql> INSERT INTO employee1 select * from employee;
Query OK, 2 rows affected (0.09 sec)
Records: 2 Duplicates: 0 Warnings: 0

mysql> select * from employee1;
+----+--------+
| ID | NAME   |
+----+--------+
| 1  | Gaurav |
| 2  | Raman  |
+----+--------+
2 rows in set (0.00 sec)

이런 식으로 데이터, 트리거 및 인덱스와 함께 테이블의 복제본도 만들 수 있습니다.