Bạn hiện đang ngoại tuyến, hãy chờ internet để kết nối lại

Khắc phục: Lỗi khi bạn chạy một truy vấn có sử dụng các khoản FOR XML trong chế độ đường dẫn trong SQL Server 2008 R2 hoặc trong SQL Server 2012

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: 2715312
Microsoft phân phối bản sửa lỗi Microsoft SQL Server 2008 R2 Service Pack 1 (SP1) trong một tập tin 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à tất cả các bản cập nhật bảo mật được bao gồm trong bản phát hành bản cập nhật trước SQL Server 2008 R2 Service Pack 1 (SP1).
Triệu chứng
Xem xét kịch bản sau đây:
  • Bạn có một ứng dụng khách mà chạy một truy vấn trong Microsoft SQL Server 2008 R2 hoặc trong Microsoft SQL Server 2012.
  • Truy vấn sử dụng các khoản FOR XML trong chế độ đường dẫn .
  • Truy vấn chạy lệnh SET NO_BROWSETABLE ON để kích hoạt các thiết lập NO_BROWSETABLE .
Trong trường hợp này, các truy vấn không chạy. Ngoài ra, bạn nhận được thông báo lỗi sau trên các ứng dụng khách hàng, và một tệp kết xuất nhỏ được tạo ra trong Nhật ký lỗi SQL.

Msg 0, tầng 11, bang 0, Line 0
Một lỗi nghiêm trọng xảy ra vào lệnh hiện hành. Các kết quả, nếu có, nên được bỏ đi.
Msg 0, mức 20, bang 0, Line 0
Một lỗi nghiêm trọng xảy ra vào lệnh hiện hành. Các kết quả, nếu có, nên được bỏ đi.

Ghi chú
  • Một kế hoạch truy vấn được sử dụng để chạy truy vấn không được biên dịch.
  • Không có không có sự kiện hồ sơ cho truy vấn không thành công khi bạn khởi động cấu hình máy chủ SQL.
  • Khi vấn đề này xảy ra, các bản ghi dịch vụ SQL Server tắt không liên tục.

Nguyên nhân
Vấn đề này xảy ra bởi vì có một lỗi nội bộ trong SQL Server algebrizer. Vấn đề này xảy ra khi máy chủ SQL cố gắng thêm cột được kéo từ một phía của một nút chọn một điều hành tham gia để phía bên kia của nút chọn một tham gia điều hành. Vì vậy, một cây algebrizer không hợp lệ được tạo ra bởi vì các cột được định nghĩa trong một bên của nút chọn một điều hành tham gia không có thể nhìn thấy phía bên kia của nút chọn một tham gia điều hành.
Giải pháp

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

SQL Server 2012

Sửa chữa cho vấn đề này đã được phát hành lần đầu tiên trong Cumulative Update 3 cho SQL Server 2012. Để biết thêm chi tiết về gói tích lũy Cập nhật này, nhấp vào số bài viết sau để xem bài viết trong cơ sở kiến thức Microsoft:
2723749 Tích lũy thông tin trọn gói 3 cho SQL Server 2012
Lưu ý Bởi vì các bản xây dựng được tích lũy, mỗi sửa chữa mới phát hành chứa tất cả các hotfix và tất cả các sửa lỗi bảo mật đó được đính kèm với trước năm 2012 Server SQL Sửa chữa phát hành. Microsoft khuyến cáo bạn hãy xem xét việc áp dụng sửa chữa phát hành gần đây nhất có chứa hotfix này. Để biết thêm chi tiết, nhấp vào số bài viết sau để xem bài viết trong cơ sở kiến thức Microsoft:
2692828 SQL Server 2012 xây dựng được phát hành sau khi SQL Server 2012 được phát hành
Bạn phải áp dụng một hotfix SQL Server 2012 cho tiến trình cài đặt chuyên biệt SQL Server 2012.

SQL Server 2008 R2 Service Pack 2

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

Tích lũy thông tin trọn gói 7 cho SQL Server 2008 R2 SP1

Sửa chữa cho vấn đề này lần đầu tiên được phát hành trong Cumulative Update 7 cho SQL Server 2008 R2 Service Pack 1. Để biết thêm chi tiết về gói tích lũy Cập nhật này, nhấp vào số bài viết sau để xem bài viết trong cơ sở kiến thức Microsoft:
2703282 Tích lũy thông tin trọn gói 6 cho SQL Server 2008 R2 SP1
Lưu ý Bởi vì các bản xây dựng được tích lũy, mỗi sửa chữa mới phát hành chứa tất cả các hotfix và sửa chữa tất cả các sửa lỗi bảo mật đó được đính kèm với trước SQL Server 2008 R2 phát hành. Microsoft khuyến cáo bạn hãy xem xét việc áp dụng sửa chữa phát hành gần đây nhất có chứa hotfix này. Để biết thêm chi tiết, nhấp vào số bài viết sau để xem bài viết trong cơ sở kiến thức Microsoft:
2567616 SQL Server 2008 R2 xây dựng được phát hành sau khi SQL Server 2008 R2 SP1 được phát hành
Microsoft SQL Server 2008 R2 hotfix được tạo ra cho cụ thể SQL Server service pack. Bạn phải áp dụng một hotfix SQL Server 2008 R2 Service Pack 1 cho tiến trình cài đặt chuyên biệt của SQL Server 2008 R2 Service Pack 1. theo mặc định, bất kỳ hotfix được cung cấp trong gói bản ghi dịch vụ máy chủ SQL được bao gồm trong gói bản ghi dịch vụ tiếp theo của SQL Server.
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ách giải quyết khác
Để làm việc xung quanh vấn đề này, sử dụng một trong những phương pháp sau đây.

Phương pháp 1

Không sử dụng các khoản FOR XML trong chế độ đường dẫn .

Phương pháp 2

Chạy lệnh sau đây để vô hiệu hoá các thiết lập NO_BROWSETABLE :

THIẾT LẬP NO_BROWSETABLE TẮT

Tham khảo
Để biết thêm chi tiết về chế độ duyệt, đi đến web site MSDN sau đây:Để biết thêm chi tiết về làm thế nào để sử dụng chế độ đường dẫn với các khoản FOR XML, đi đến web site MSDN sau đây:

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

Thuộc tính

ID Bài viết: 2715312 - Xem lại Lần cuối: 08/30/2012 00:25:00 - Bản sửa đổi: 3.0

Microsoft SQL Server 2008 R2 Developer, Microsoft SQL Server 2008 R2 Enterprise, Microsoft SQL Server 2008 R2 Express, Microsoft SQL Server 2008 R2 Standard, Microsoft SQL Server 2008 R2 Web, Microsoft SQL Server 2008 R2 Workgroup, Microsoft SQL Server 2012 Business Intelligence, Microsoft SQL Server 2012 Developer, Microsoft SQL Server 2012 Enterprise, Microsoft SQL Server 2012 Standard, Microsoft SQL Server 2012 Web, SQL Server 2012 Enterprise Core

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