Khắc phục: SSIS Checkpoint restores một giá trị biến không đúng cho một mục Execute SQL nhiệm vụ của một đối với Loop Container mục SSIS 2008 nếu một gói SSIS thực hiện một lần nữa sau khi nó lỗi hoặc dừng lại

QUAN TRỌNG: Bài viết này được dịch bằng phần mềm dịch máy của Microsoft chứ không phải do con người dịch. Microsoft cung cấp các bài viết do con người dịch và cả các bài viết do máy dịch để bạn có thể truy cập vào tất cả các bài viết trong Cơ sở Kiến thức của chúng tôi bằng ngôn ngữ của bạn. Tuy nhiên, bài viết do máy dịch không phải lúc nào cũng hoàn hảo. Loại bài viết này có thể chứa các sai sót về từ vựng, cú pháp hoặc ngữ pháp, giống như một người nước ngoài có thể mắc sai sót khi nói ngôn ngữ của bạn. Microsoft không chịu trách nhiệm về bất kỳ sự thiếu chính xác, sai sót hoặc thiệt hại nào do việc dịch sai nội dung hoặc do hoạt động sử dụng của khách hàng gây ra. Microsoft cũng thường xuyên cập nhật phần mềm dịch máy này.

Nhấp chuột vào đây để xem bản tiếng Anh của bài viết này:2583994
Microsoft phân phối bản sửa lỗi Microsoft SQL Server 2008 Service Pack 1 (SP1) như một file tải về. Bởi vì các bản sửa lỗi tích lũy, mỗi bản phát hành mới có chứa tất cả các hotfix và cập nhật tất cả các bản cập nhật bảo mật mà được đính kèm với trước SQL Server 2008 SP1 phát hành.
TRIỆU CHỨNG
Hãy xem xét các tình huống sau:
  • Bạn cài đặt Microsoft SQL Server 2008 dịch vụ tích hợp (SSIS 2008) trên một máy tính.
  • Bạn tạo một gói SSIS chứa hai Đối với Loop Container khoản mục.
  • Bạn tạo hai Đối với Loop Container phạm vi các biến cho hai người Đối với Loop Container khoản mục. Các biến có cùng tên.
  • Bạn sử dụng các biến trong các InitExpression, EvalExpression, và AssignExpression thuộc tính cho hai người Đối với Loop Container khoản mục.
  • Hai Đối với Loop Container khoản mục chứa nhiều Thực hiện nhiệm vụ SQL khoản mục chạy song song.
  • Bạn bật các Điểm kiểm tra cài đặt gói SSIS.
  • Bạn chạy SSIS gói.
  • Một trong những Thực hiện nhiệm vụ SQL khoản mục lỗi hoặc dừng lại trong khi gói SSIS chạy.
  • Các gói phần mềm SSIS chạy một lần nữa.

Trong trường hợp này, biến giá trị đối với một trong các Thực hiện nhiệm vụ SQL mặt hàng mà đã không thất bại hoặc dừng lại không chính xác.

Chú ý
Điều này Thực hiện nhiệm vụ SQL mục là trong các Đối với Loop Container mục mà đã không thất bại hoặc dừng.

Ví dụ, hãy xem xét kịch bản sau đây:
  • Bạn tạo một gói SSIS có hai Đối với Loop Container khoản mục. Các mặt hàng được đặt tên là FLC01 và FLC02.
  • Bạn tạo một BatchNo biến cho FLC01 và một BatchNo biến cho FLC02.
  • Bạn thiết lập các InitExpression bất động sản để @ [User::BatchNo] = 0.
  • Bạn thiết lập các EvalExpression bất động sản để @ [User::BatchNo]<>.
  • Bạn thiết lập các AssignExpression bất động sản để @ [User::BatchNo]=@[User::BatchNo]+1.
  • Hai Đối với Loop Container khoản mục chứa nhiều Thực hiện nhiệm vụ SQL mục đã sử dụng một kế hoạch thực hiện song song.
  • Bạn bật các Điểm kiểm tra cài đặt gói SSIS.
  • Bạn chạy SSIS gói.
  • Một trong những Thực hiện nhiệm vụ SQL mục trong FLC01 không thành công hoặc dừng lại.
  • Các gói phần mềm SSIS chạy một lần nữa.

Trong trường hợp này, các BatchNo giá trị cho một trong các Thực hiện nhiệm vụ SQL khoản mục trong FLC02 không chính xác.

Chú ý Vấn đề này cũng có mặt trong Microsoft SQL Server 2008 R2 tích hợp dịch vụ (SSIS 2008 R2).
NGUYÊN NHÂN
Vấn đề này xảy ra vì một lỗi trong logic phục hồi của các Điểm kiểm tra biến.

Các Điểm kiểm tra các biến được khôi phục lại các nhiệm vụ sai. Vì vậy, không đúng giá trị biến được khôi phục.
GIẢI PHÁP

Cumulative update Cập nhật thông tin

Cumulative update gói 16 cho SQL Server 2008 SP1

Sửa chữa cho vấn đề này lần đầu tiên phát hành gói tích lũy 16 cho SQL Server 2008 SP1. Để biết thêm chi tiết về làm thế nào để có được điều này gói cumulative update cho SQL Server 2008 SP1, nhấp vào số bài viết sau đây để xem bài viết trong cơ sở kiến thức Microsoft:
2582282 Cumulative update gói 16 cho SQL Server 2008 Service Pack 1
Chú ý Bởi vì các bản xây dựng tích lũy, mỗi bản phát hành bản cập nhật mới có chứa tất cả các hotfix và cập nhật tất cả các bản cập nhật bảo mật mà được đính kèm với trước SQL Server 2008 SP1 phát hành. Chúng tôi khuyên bạn hãy xem xét việc áp dụng việc phát hành bản cập nhật mới nhất có chứa hotfix này. Để biết thêm thông tin, hãy bấm vào số bài viết sau để xem bài viết trong Cơ sở Kiến thức Microsoft:
970365 SQL Server 2008 xây dựng được phát hành sau khi SQL Server 2008 Service Pack 1 đã được phát hành


CÁCH GIẢI QUYẾT KHÁC
Để làm việc xung quanh vấn đề này, sử dụng một tên biến khác nhau cho mỗi Đối với Loop Container khoản mục.
TÌNH TRẠNG
Microsoft đã xác nhận rằng đây là một vấn đề trong các sản phẩm của Microsoft được liệt kê trong phần "Áp dụng cho".

Cảnh báo: Bài viết này được dịch tự động

Thuộc tính

ID Bài viết: 2583994 - Xem lại Lần cuối: 09/19/2011 16:34:00 - Bản sửa đổi: 1.0

Microsoft SQL Server 2008 Enterprise, Microsoft SQL Server 2005 Enterprise Edition, Microsoft SQL Server 2008 R2 Datacenter

  • kbqfe kbfix kbexpertiseadvanced kbsurveynew kbmt KB2583994 KbMtvi
Phản hồi