14/08/2018, 11:44

Mô phỏng bảng trong MySQL

Có một tình huống khi bạn cần một bản sao thực sự của một bảng và các lệnh CREATE TABLE … SELECT … không phù hợp với mục đích của bạn, bởi vì bản sao phải bao gồm cùng chỉ mục, cùng giá trị mặc định, và … Bạn có thể xử lý tình huống này theo các bước sau: Ví dụ Bạn ...

Có một tình huống khi bạn cần một bản sao thực sự của một bảng và các lệnh CREATE TABLE … SELECT … không phù hợp với mục đích của bạn, bởi vì bản sao phải bao gồm cùng chỉ mục, cùng giá trị mặc định, và …

Bạn có thể xử lý tình huống này theo các bước sau:

Ví dụ

Bạn thử ví dụ sau để tạo một bảng mô phỏng cho sinhvienk60:

Bước 1:

Lấy toàn bộ cấu trúc của bảng với lệnh SHOW CREATE TABLE ten_bang;:

SHOW CREATE TABLE sinhvienk60;

Khi bạn đang làm việc trên MySQL Workbench thì lệnh trên sẽ trả về một hàng, bạn có thể nhấn chuột phải vào hàng này và lựa chọn các tùy chọn Copy, sau đó dán vào phần bạn đang làm việc, kết quả là:

CREATE TABLE `sinhvienk60` (
  `mssv` int(11) NOT NULL AUTO_INCREMENT,
  `ho` varchar(255) NOT NULL,
  `ten` varchar(255) NOT NULL,
  `diemthi` float(4,2) NOT NULL,
  PRIMARY KEY (`mssv`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8

Bước 2:

Thay tên bảng này và tạo bảng khác.

CREATE TABLE `sinhvienk61` (
  `mssv` int(11) NOT NULL AUTO_INCREMENT,
  `ho` varchar(255) NOT NULL,
  `ten` varchar(255) NOT NULL,
  `diemthi` float(4,2) NOT NULL,
  PRIMARY KEY (`mssv`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8

Bước 3:

Sau khi thực thi bước 2, bạn sẽ mô phỏng một bảng trong Database. Nếu bạn muốn sao chép dữ liệu từ bảng cũ, thì bạn có thể thực hiện bằng việc sử dụng lệnh INSERT INTO … SELECT.

INSERT INTO sinhvienk61 (mssv, ho, ten, diemthi)
      SELECT mssv, ho, ten, diemthi FROM sinhvienk60;

Cuối cùng, bạn sẽ có bảng mô phỏng thực sự như bạn muốn có.

Follow fanpage của team https://www.facebook.com/vietjackteam/ hoặc facebook cá nhân Nguyễn Thanh Tuyền https://www.facebook.com/tuyen.vietjack để tiếp tục theo dõi các loạt bài mới nhất về Java,C,C++,Javascript,HTML,Python,Database,Mobile.... mới nhất của chúng tôi.

Các bài học MySQL phổ biến khác tại code24h:

0