Hướng dẫn mysql copy indexes from one table to another - mysql sao chép chỉ mục từ bảng này sang bảng khác
Đây là bài viết cũ, nhưng tôi hình dung tôi có thể giúp đỡ người khác. Bạn có thể làm điều gì đó như thế này: Show
hoặc khác cho chỉ mục sao chép vào một bảng cho các trường khác có cùng trường:
Sau đó sao chép dán vào cửa sổ truy vấn. Điều cơ bảnĐể có được tất cả các định nghĩa chỉ số, bạn có thể sử dụng chức năng thông tin danh mục hệ thống Truy vấn có thể đơn giản hơn đáng kể, mặc dù, sử dụng tham số 0. Đối với một bảng gọi là 1 trong lược đồ 2:
Điều này bao gồm tất cả các chỉ mục: PK, một phần, chức năng, duy nhất, với các lớp toán tử đặc biệt, v.v. Chi tiết cho 0:
Chuẩn bị các báo cáo DDLBạn không thể làm việc với điều này, chưa. Bạn phải thay thế tên bảng cũ bằng tên mới - và bạn không muốn thay thế các dương tính giả trong chuỗi (như tên cột khớp với tên bảng): Nếu bạn đang làm việc với quy ước đặt tên mặc định của Postgres, các định nghĩa chỉ số trông như thế này:default naming convention of Postgres, index definitions look like this:
Tôi in đậm trong mọi lần xuất hiện của tên bảng ban đầu. Lưu ý ba dương tính giả (một phần của tên cột hoặc tên chỉ mục) mà chúng tôi không muốn thay thế. Truy vấn này sẽ hoạt động hoàn hảo - nhưng xác minh điều đó so với các chỉ mục thực tế của bạn!verify that against your actual indexes yourself!
1ST 4 chỉ thay thế trận đấu đầu tiên trong tên (trừ khi được hướng dẫn khác). 5 thứ 2 cụ thể hơn và chỉ thay thế tên bảng thực tế.Đối với các ví dụ đã cho bạn nhận được:
Nhưng chúng tôi chưa xem xét các tên bảng, lược đồ hoặc cài đặt 6. Tất cả điều đó được xây dựng vào chức năng dưới đây.Tự động hóa đầy đủNếu bạn tự tin vào sơ đồ đặt tên của mình, bạn có thể hoàn toàn tự động hóa:fully automate:
Điều này cũng được chuẩn bị cho các tên bảng không chuẩn cần phải trình chạy hai và khác nhau. Để buộc các tên bảng đủ điều kiện lược đồ, tôi đặt lại search_path bên trong hàm ( 7). Bằng cách này, tôi nhận được kết quả đáng tin cậy không phụ thuộc vào cài đặt.Tôi đã thêm 8 làm giá trị mặc định cho các tham số lược đồ 9 và 0. Vì vậy, nếu cả hai bảng nằm trong lược đồ công khai, bạn có thể đơn giản bỏ qua các tham số lược đồ.Call:
Hoặc cho các tên bảng yêu cầu các lược đồ hai lần và các lược đồ khác nhau:
Fiddle SQL thể hiện chức năng đang sử dụng. demonstrating the function in use. Làm cách nào để sao chép một chỉ mục từ bảng này sang bảng khác?Trong Studio quản lý, nhấp vào thư mục Indexes cho bảng trong cơ sở dữ liệu đích. Trong tab Tóm tắt trong khung bên phải, tô sáng tất cả các chỉ mục, nhấp chuột phải và chọn Chỉ mục Script là | Rơi xuống | Cửa sổ Trình chỉnh sửa truy vấn mới. Xem lại mã được tạo để đảm bảo đây thực sự là những gì bạn muốn làm.
Làm cách nào để sao chép bảng từ bảng này sang bảng khác trong MySQL?Làm thế nào để nhân đôi một bảng trong MySQL.. Tạo bảng new_table như chọn * từ gốc_table ;. Tạo bảng new_table như gốc_table ;. Chèn vào new_table Chọn * từ gốc_table ;. Làm cách nào để sao chép dữ liệu từ bảng này sang bảng khác trong SQL?Sử dụng SQL Server Management Studio Mở bảng với các cột bạn muốn sao chép và cái bạn muốn sao chép vào bằng cách nhấp chuột phải vào các bảng, sau đó nhấp vào Thiết kế.Nhấp vào tab cho bảng với các cột bạn muốn sao chép và chọn các cột đó.Từ menu Chỉnh sửa, nhấp vào Sao chép.Open the table with columns you want to copy and the one you want to copy into by right-clicking the tables, and then clicking Design. Click the tab for the table with the columns you want to copy and select those columns. From the Edit menu, click Copy.
Làm cách nào để sao chép cột từ bảng này sang bảng khác trong MySQL?Để sao chép từ cột này sang cột khác, bạn có thể sử dụng Chèn vào câu lệnh Chọn. |