PostgreSQL: soi kèo bóng đá truoctran | |||
---|---|---|---|
prev | UP | Chương 51. Các quy ước mã hóa PostgreSQL | NEXT |
kèo bóng đá c1, cảnh báo và tin nhắn nhật ký được tạo trong mã máy chủ phải được tạo bằng cách sử dụngEREPORT
hoặc anh em họ cũ của nóELOG
. Việc sử dụng chức năng này đủ phức tạp để yêu cầu một số giải thích.
Có hai yếu tố cần thiết cho mỗi thông điệp: mức độ nghiêm trọng (từDebugđếnPanic) và một văn bản tin nhắn chính. Ngoài ra, có các yếu tố tùy chọn, trong số đó phổ biến nhất là mã định danh kèo bóng đá c1 tuân theo các quy ước SQLState của SQL Spec.EREPORT
Bản thân nó chỉ là một hàm shell, tồn tại chủ yếu để thuận tiện cho cú pháp để tạo ra thông báo trông giống như một cuộc gọi chức năng kèo bóng đá c1 mã nguồn C. Tham số duy nhất được chấp nhận trực tiếp bởiEREPORT
là mức độ nghiêm trọng. Văn bản tin nhắn chính và bất kỳ yếu tố tin nhắn tùy chọn nào được tạo bằng cách gọi các chức năng phụ trợ, chẳng hạn nhưerrmsg
, kèo bóng đá c1EREPORT
cuộc gọi.
Một cuộc gọi điển hình đếnEREPORT
Có thể trông như thế này:
EREPORT (kèo bóng đá c1,
Điều này chỉ định mức độ nghiêm trọng của kèo bóng đá c1ERROR(một kèo bóng đá c1 chạy bộ). Theerrcode
cuộc gọi Chỉ định mã kèo bóng đá c1 SQLSTATE bằng cách sử dụng macro được xác định trongsrc/bao gồm/utils/errcodes.h. Theerrmsg
cuộc gọi cung cấp văn bản tin nhắn chính. Lưu ý tập hợp thêm các dấu ngoặc đơn xung quanh các cuộc gọi chức năng phụ trợ - chúng rất khó chịu nhưng cần thiết về mặt cú pháp.
Đây là một ví dụ phức tạp hơn:
EREPORT (kèo bóng đá c1,
Điều này minh họa việc sử dụng mã định dạng để nhúng các giá trị thời gian chạy vào một văn bản tin nhắn. Ngoài ra, một tùy chọn"Gợi ý"Tin nhắn được cung cấp.
Nếu mức độ nghiêm trọng làERRORhoặc cao hơn,EREPORT
hủy bỏ việc thực thi chức năng do người dùng xác định và không trả lại cho người gọi. Nếu mức độ nghiêm trọng thấp hơnERROR, EREPORT
trả về bình thường.
Các thói quen phụ trợ có sẵn choEREPORT
là:
errcode (sqlerrcode)
Chỉ định mã định danh kèo bóng đá c1 SQLSTATE cho điều kiện. Nếu thói quen này không được gọi, định danh kèo bóng đá c1 mặc định làerrCode_Internal_errorKhi mức độ nghiêm trọng của kèo bóng đá c1 làERRORhoặc cao hơn,errcode_warningKhi mức kèo bóng đá c1 làCảnh kèo bóng đá c1, nếu không (choThông kèo bóng đá c1và bên dưới)errCode_successful_completion. Mặc dù các mặc định này thường thuận tiện, luôn luôn nghĩ liệu chúng có phù hợp hay không trước khi bỏ quaerrcode ()
cuộc gọi.
errmsg (const char *msg, ...)
Chỉ định văn bản thông báo kèo bóng đá c1 chính và có thể các giá trị thời gian chạy để chèn vào nó. Chèn được chỉ định bởiSprintf
-Style Mã định dạng. Ngoài các mã định dạng tiêu chuẩn được chấp nhận bởiSprintf
, Mã định dạng%mCó thể được sử dụng để chèn thông báo kèo bóng đá c1 được trả về bởiStrerror
Đối với giá trị hiện tại củaerrno. [1] %MKhông yêu cầu bất kỳ mục nhập tương ứng nào kèo bóng đá c1 danh sách tham số choerrmsg
. Lưu ý rằng chuỗi tin nhắn sẽ được chạy quaGetText
Để bản địa hóa có thể trước khi mã định dạng được xử lý.
errmsg_Internal (const char *msg, ...)
giống nhưerrmsg
, ngoại trừ chuỗi tin nhắn sẽ không được dịch cũng như không được bao gồm kèo bóng đá c1 từ điển thông điệp quốc tế hóa. Điều này nên được sử dụng cho"Không thể xảy ra"Các trường hợp có lẽ không đáng để sử dụng nỗ lực dịch thuật trên.
15339_15426
giống nhưerrmsg
, nhưng với sự hỗ trợ cho các hình thức số nhiều khác nhau của thông điệp.fmt_singularlà định dạng số ít tiếng Anh,fmt_plurallà định dạng số nhiều tiếng Anh,nlà giá trị số nguyên xác định dạng số nhiều là cần thiết và các đối số còn lại được định dạng theo chuỗi định dạng đã chọn. Để biết thêm thông tin, xemPhần 52.2.2.
errdetail (const char *msg, ...)
Cung cấp tùy chọn"Chi tiết"Tin nhắn; Điều này sẽ được sử dụng khi có thêm thông tin có vẻ không phù hợp để đưa vào thông điệp chính.errmsg
.
errdetail_Internal (const char *msg, ...)
giống nhưerrdetail
, ngoại trừ chuỗi tin nhắn sẽ không được dịch cũng như không được bao gồm kèo bóng đá c1 từ điển thông điệp quốc tế hóa. Điều này nên được sử dụng cho các thông điệp chi tiết không đáng để sử dụng nỗ lực dịch thuật, vì chúng quá kỹ thuật để có ích cho hầu hết người dùng.
16780_16870
giống nhưerrdetail
, nhưng với sự hỗ trợ cho các hình thức số nhiều khác nhau của thông điệp. Để biết thêm thông tin, xemPhần 52.2.2.
errdetail_log (const char *msg, ...)
giống nhưerrdetail
Ngoại trừ chuỗi này chỉ đi đến nhật ký kèo bóng đá c1 chủ, không bao giờ với kèo bóng đá c1 khách. Nếu cả haierrdetail
(hoặc một kèo bóng đá c1 những tương đương của nó ở trên) vàerrdetail_log
được sử dụng sau đó một chuỗi đi đến máy khách và chuỗi kia vào nhật ký. Điều này rất hữu ích cho các chi tiết kèo bóng đá c1 quá nhạy cảm với bảo mật hoặc quá cồng kềnh để đưa vào báo cáo được gửi đến máy khách.
17650_17744
giống nhưerrdetail_log
, nhưng với sự hỗ trợ cho các hình thức số nhiều khác nhau của thông điệp. Để biết thêm thông tin, xemPhần 52.2.2.
errhint (const char *msg, ...)
Cung cấp tùy chọn"Gợi ý"Tin nhắn; Điều này sẽ được sử dụng khi đưa ra các đề xuất về cách khắc phục vấn đề, trái ngược với các chi tiết thực tế về những gì đã sai.errmsg
.
errcontext (const char *msg, ...)
thường không được gọi trực tiếp từEREPORT
Trang web tin nhắn; đúng hơn là nó được sử dụng kèo bóng đá c1ERROR_CONTEXT_STACKCác chức năng gọi lại để cung cấp thông tin về bối cảnh xảy ra kèo bóng đá c1, chẳng hạn như vị trí hiện tại trong hàm PL. Chuỗi thông báo được xử lý theo cách tương tự như đối vớierrmsg
. Không giống như các chức năng phụ trợ khác, điều này có thể được gọi nhiều hơn một lần mỗiEREPORT
cuộc gọi; Do đó, các chuỗi liên tiếp được cung cấp được kết hợp với việc tách các dòng mới.
errPoseition (int cursorpos)
Chỉ định vị trí văn bản của một kèo bóng đá c1 trong chuỗi truy vấn. Hiện tại nó chỉ hữu ích cho các kèo bóng đá c1 được phát hiện trong các giai đoạn phân tích từ vựng và cú pháp của xử lý truy vấn.
errtable (quan hệ rel)
Chỉ định một mối quan hệ có tên và tên lược đồ nên được đưa vào các trường phụ trong báo cáo kèo bóng đá c1.
errtableCol (quan hệ rel, int attnum)
Chỉ định một cột có tên, tên bảng và tên lược đồ nên được đưa vào dưới dạng các trường phụ trợ trong báo cáo kèo bóng đá c1.
errTableConstraint (quan hệ rel, const char *Conname)
Chỉ định một ràng buộc bảng có tên, tên bảng và tên lược đồ nên được đưa vào làm các trường phụ trong báo cáo kèo bóng đá c1. Các chỉ mục nên được coi là ràng buộc cho mục đích này, cho dù chúng có liên quan hay khôngPG_Constraintmục nhập. Cẩn thận vượt qua mối quan hệ heap cơ bản, không phải chính chỉ mục, nhưrel.
errdatatype (OID DataTypeoid)
Chỉ định loại dữ liệu có tên và tên lược đồ nên được đưa vào dưới dạng các trường phụ trong báo cáo kèo bóng đá c1.
20345_20404
Chỉ định một ràng buộc tên miền có tên, tên miền và tên lược đồ nên được đưa vào dưới dạng các trường phụ trong báo cáo kèo bóng đá c1.
errcode_for_file_access ()
là một hàm tiện lợi chọn một định danh kèo bóng đá c1 SQLState thích hợp cho kèo bóng đá c1 trong cuộc gọi hệ thống liên quan đến truy cập tệp. Nó sử dụng đã lưuerrnoĐể xác định mã kèo bóng đá c1 nào sẽ tạo. Thông thường, điều này nên được sử dụng kết hợp với%MTrong văn bản thông báo kèo bóng đá c1 chính.
errcode_for_socket_access ()
21025_21154
errHidestMt (bool hid_stmt)
Có thể được gọi để chỉ định việc đàn ápTuyên bố:Phần của một tin nhắn kèo bóng đá c1 nhật ký bưu điện. Nói chung, điều này là phù hợp nếu văn bản tin nhắn bao gồm câu lệnh hiện tại.
Lưu ý:nhiều nhất là một kèo bóng đá c1 các chức năng
errTable
,errTableCol
,errTableConstraint
,errdatatype
hoặcErrdomainConstraint
nên được sử dụng kèo bóng đá c1 mộtEREPORT
Gọi. Các chức năng này tồn tại để cho phép các ứng dụng trích xuất tên của một đối tượng cơ sở dữ liệu được liên kết với điều kiện kèo bóng đá c1 mà không phải kiểm tra văn bản thông báo kèo bóng đá c1 có khả năng local hóa.PostgreSQL9.3, phạm vi bảo hiểm hoàn chỉnh chỉ tồn tại đối với các kèo bóng đá c1 trong lớp SQLSTATE 23 (vi phạm ràng buộc toàn vẹn), nhưng điều này có thể được mở rộng trong tương lai.
Có một hàm cũELOG
Điều đó vẫn được sử dụng rất nhiều. MỘTELOG
cuộc gọi:
ELOG (cấp, "Chuỗi định dạng", ...);
hoàn toàn tương đương với:
22661_22719
Lưu ý rằng mã kèo bóng đá c1 SQLSTATE luôn được mặc định và chuỗi tin nhắn không phải là dịch. Vì thế,ELOG
Chỉ nên được sử dụng cho các kèo bóng đá c1 nội bộ và ghi nhật ký gỡ kèo bóng đá c1 cấp thấp. Bất kỳ thông điệp nào có khả năng được người dùng thông thường quan tâm nên đi quaEREPORT
. Tuy nhiên, có đủ nội bộ"Không thể xảy ra"Kiểm tra kèo bóng đá c1 trong hệ thốngELOG
vẫn được sử dụng rộng rãi; nó được ưa thích cho những tin nhắn đó vì sự đơn giản của nó.
Lời khuyên về việc viết các thông báo kèo bóng đá c1 tốt có thể được tìm thấy trongPhần 51.3.
[1] |
nghĩa là giá trị hiện tại khi |