1. Hướng dẫn tạo SSIS package để thực hiện Import/Export dữ liệu giữa hai server.
Trước tiên bạn phải cài Visual Studio 2013 và MS SQL Server Management Studio 2014
Để tạo được SSIS package thì tiếp theo bạn phải download và cài Microsoft SQL Server Data Tools - Business Intelligence for Visual Studio 2013
Sau khi cài xong, mở SQL Server Data Tools for Visual Studio 2013 lên:
Tiếp theo bạn vào File > New > Project và tạo một Integration Services Project:
Sau khi project được tạo bạn sẽ nhìn thấy file Package.dtsx mặc định tạo ra
Tạo DB Connections Nguồn và Đích:
- Click chuột phải vào khu vực Connection Managers và chọn New OLE DB Connection…
Cửa sổ Configure OLE DB Connection Manager xuất hiện
Click New > Điền các thông tin server về DB nguồn
(Click nút Test Connection nếu OK sẽ thông báo 1 cửa sổ success)
Nhấn OK để kết thúc:
Click chuột phải làm tương tự như trên rồi điền các thông tin server về DB đích. Mục đích của chúng ta là import dữ liệu (một hoặc nhiều bảng) từ db Nguồn tới db Đích.
Trong bài này chúng ta lấy ví dụ import dữ liệu từ 1 bảng tên là tblSummaryReport ở db Nguồn tới bảng cùng tên ở db Đích. Lưu ý cần tạo cấu trúc bảng ở db Đích giống hệt cấu trúc bảng ở db Nguồn.
- Trên thanh công cụ SSIS Toolbox kéo chọn control Execute SQL Task và đặt tên là “Truncate table at Distination”, mục đích là trước khi import sẽ đảm bảo xóa trắng dữ liệu bảng tblSummaryReport ở db Đích.
- Click đúp vào control trên (hoặc chuột phải > Properties) và thiết lập các thông tin như sau:
- Tiếp theo kéo thả control “Data Flow Task” vào trong cửa sổ của file Package.dtsx và đặt tên “Import data”
- Click đúp vào control trên và nó mở ra cửa sổ Data Flow như hình dưới:
- Kéo thả control “OLD DB Source” từ SSIS Toolbox (dưới group: Other Sources) vào và thiết lập Connection và table như hình bên dưới:
- Tiếp theo kéo thả control “OLD DB Destinations” từ SSIS Toolbox (dưới group: Other Destinations) vào và thiết lập Connection và table như hình bên dưới (à bạn phải nhớ là tạo trước mapping trỏ từ control Nguồn tới control Đích theo mũi tên)
- Quay trở lại tab “Control Flow” của file Package.dtsx và thiết lập mapping giữa 2 control như hình bên dưới. (Lưu ý việc mapping này chỉ ra rằng các object của chúng ta tạo ra sẽ chạy từ đâu đến đâu tron các bước thiết lập)
- Nhấn F5 và chạy thử, xem các kết quả:
>> Như vậy chúng ta đã hoàn thành xong phần import/Export dữ liệu giữa 2 bảng từ 2 server.
2. Hướng dẫn tạo SQL Server Agent để thực thi file package .dtsx đã tạo ở trên
Mục đích của việc này là import/export dữ liệu được chạy hàng ngày/hàng tuần/… một cách tự động theo ý đồ của tác giả, ở đây mục đích của mình là hằng ngày sẽ lấy lại dữ liệu mới nhất từ server nguồn về server đích.
Để làm được điều này yêu cầu bạn phải cài SQL Server Agent, nó là 1 dịch vụ tích hợp trong MS SQL Server 2014 (hoặc các phiên bản cũ hơn).
Tạo SQL Agent Job:
- Trước khi tạo một Job trong SQL Agent thì chúng ta cần phải tạo một Credential với tên được đặt là “SSISProxyCredentials”, với Identify và Password mình sử dụng tài khoản windows:
- Tiếp theo chúng ta sẽ tạo một New Proxy, và nhập các thông tin như hình dưới:
Mục đích của 2 bước trên là tạo ra 1 chứng thực khi chạy một SQL Agent Job
- Tạo một Job với tên “Run SSIS Package for Import Data”
- Tiếp đến tạo 1 Step trong Job: Click vào Steps > New, và điền các thông tin như hình:
Trong phần Advanced:
Thiết lập lịch chạy tự động cho Job: Chọn Schedules > New:
> Lưu ý ở trên mình đặt lịch chạy hằng ngày vào lúc 12:00AM.
Như vậy là đã xong, bây giờ mình sẽ chạy thử nhá:
Và kết quả sau khi chạy Success:
Tóm lại: Ở trên mình đã trình bày chi tiết cách tạo SSIS package để Import/Export dữ liệu và Tạo SQL Server Agent Job để thực thi package. Ngoài ra bạn có thể tham khảo thêm nhiều cách import/export dữ liệu từ nhiều nguồn và đích khác nhau chứ không giới hạn chỉ OLE DB Connection. Và bạn cũng có thể Import/Export data trên SSIS package bằng SQL Scripts/Excel/CSV/MySQL/..etc..
Trương Đức Tài