Phiên bản được hỗ trợ:hiện tại(17)16 / 15 / 14 / 13
Phiên bản phát triển:18 / Devel
Phiên bản không được hỗ trợ:12 / 11 / 10 / 9.6 / 9.5 / 9.4 / 9.3

40.1. Tổng quan về hành vi kèo bóng đá hom nay

Một kèo bóng đá hom nay bắn bất cứ khi nào sự kiện được liên kết xảy ra trong cơ sở dữ liệu được xác định. Hiện tại, các sự kiện được hỗ trợ duy nhất làDDL_Command_Start, DDL_Command_end, Table_rewriteSQL_DROP. Hỗ trợ cho các sự kèo bóng đá hom nay bổ sung có thể được thêm vào trong các bản phát hành trong tương lai.

TheDDL_Command_StartSự kèo bóng đá hom nay xảy ra ngay trước khi thực hiện ATạo, ATTER, thả, Nhãn bảo mật, bình luận, Granthoặcthu hồilệnh. Không kiểm tra xem đối tượng bị ảnh hưởng có tồn tại hay không tồn tại được thực hiện trước khi kèo bóng đá hom nay.DDL_Command_Startcũng xảy ra ngay trước khi thực hiệnChọn vàolệnh, vì điều này tương đương vớiTạo bảng dưới dạng.

TheDDL_COMMAND_ENDSự kèo bóng đá hom nay xảy ra ngay sau khi thực hiện cùng một bộ lệnh này. Để có thêm chi tiết vềDDLCác kèo bóng đá hom nay động đã diễn ra, sử dụng chức năng trả lại thiết lậppg_event_trigger_ddl_commands ()từDDL_COMMAND_ENDMã kèo bóng đá hom nay (xemPhần 9,29). Lưu ý rằng các vụ cháy kích kèo bóng đá hom nay sau khi các hành động đã diễn ra (nhưng trước khi giao dịch thực hiện) và do đó, các danh mục hệ thống có thể được đọc như đã thay đổi.

TheSQL_DropSự kèo bóng đá hom nay xảy ra ngay trướcDDL_COMMAND_ENDTrình kèo bóng đá hom nay cho bất kỳ hoạt động nào làm giảm các đối tượng cơ sở dữ liệu. Để liệt kê các đối tượng đã bị loại bỏ, hãy sử dụng chức năng hoàn trả lạipg_event_trigger_dropped_objects ()từSQL_DropMã kèo bóng đá hom nay (xemPhần 9,29). Lưu ý rằng kích kèo bóng đá hom nay được thực thi sau khi các đối tượng đã bị xóa khỏi các danh mục hệ thống, vì vậy không thể tìm kiếm chúng nữa.

TheTable_rewriteSự kèo bóng đá hom nay xảy ra ngay trước khi bảng được viết lại bởi một số hành động của các lệnhBảng thay đổithay đổi loại. Trong khi các câu lệnh điều khiển khác có sẵn để viết lại một bảng, nhưcụmVACUUM, TheTable_rewriteSự kiện không được kích kèo bóng đá hom nay bởi chúng. Để tìm oid của bảng được viết lại, hãy sử dụng chức năngpg_event_trigger_table_rewrite_oid ()(xemPhần 9,29). Để khám phá (các) lý do để viết lại, hãy sử dụng chức năng.

Trình kèo bóng đá hom nay (giống như các chức năng khác) không thể được thực thi trong một giao dịch bị hủy bỏ. Do đó, nếu lệnh DDL không có lỗi, bất kỳ liên quan nàoDDL_COMMAND_ENDTriggers sẽ không được thực thi. Ngược lại, nếu mộtDDL_Command_StartTrình kích hoạt thất bại với lỗi, không có trình kèo bóng đá hom nay nào sẽ bắn và không có nỗ lực nào được thực hiện để tự thực hiện lệnh. Tương tự, nếu mộtDDL_COMMAND_END12981_13147

Để biết danh sách đầy đủ các lệnh được hỗ trợ bởi cơ chế kèo bóng đá hom nay, xemPhần 40.2.

Trình kèo bóng đá hom nay được tạo bằng lệnhTạo Trình kèo bóng đá hom nay. Để tạo trình kèo bóng đá hom nay, trước tiên bạn phải tạo chức năng với loại trả về đặc biệtevent_trigger. Hàm này không cần (và có thể không) trả về một giá trị;

Nếu có nhiều hơn một kèo bóng đá hom nay được xác định cho một sự kiện cụ thể, chúng sẽ bắn theo thứ tự bảng chữ cái bằng tên kích hoạt.

Định nghĩa kích kèo bóng đá hom nay cũng có thể chỉ định AKhiĐiều kèo bóng đá hom nay sao cho, ví dụ, ADDL_Command_StartTrigger chỉ có thể được bắn cho các lệnh cụ thể mà người dùng muốn chặn. Việc sử dụng phổ biến các kích kèo bóng đá hom nay như vậy là hạn chế phạm vi kèo bóng đá hom nay động DDL mà người dùng có thể thực hiện.

Gửi hiệu chỉnh

Nếu bạn thấy bất cứ điều gì trong tài liệu không chính xác, không khớpMẫu nàyĐể báo cáo vấn đề tài liệu.