PostgreSQL: kèo chấp bóng đá | |||
---|---|---|---|
Prev | UP | Chương 31.libpq- C Thư viện | Tiếp theo |
PostgreSQLcung cấp tỷ lệ kèo bóng đá trực tuyến hôm nay bộ quaNghevàtỷ lệ kèo bóng đá trực tuyến hôm naylệnh. Một phiên khách đăng ký sự quan tâm của nó đối với một kênh tỷ lệ kèo bóng đá trực tuyến hôm nay cụ thể vớiNgheLệnh (và có thể ngừng nghe vớiUndistenlệnh). Tất cả các phiên nghe trên một kênh cụ thể sẽ được tỷ lệ kèo bóng đá trực tuyến hôm nay bộ khi Atỷ lệ kèo bóng đá trực tuyến hôm nayLệnh có tên kênh đó được thực hiện bởi bất kỳ phiên nào. MỘT"Tải trọng"Chuỗi có thể được truyền để truyền đạt dữ liệu bổ sung cho người nghe.
libpqỨng dụng gửinghe, Unlistenvàtỷ lệ kèo bóng đá trực tuyến hôm nayCác lệnh như các lệnh SQL tỷ lệ kèo bóng đá trực tuyến hôm nay thường. Sự xuất hiện củatỷ lệ kèo bóng đá trực tuyến hôm nayTin nhắn sau đó có thể được phát hiện bằng cách gọipqnotifyes
.
hàmpqnotifyes
Trả về thông báo tiếp theo từ danh sách các thông báo tỷ lệ kèo bóng đá trực tuyến hôm nay được xử lý nhận được từ máy chủ. Nó trả về một con trỏ null nếu không có thông báo đang chờ xử lý. Sau khi thông báo được trả về từpqnotify
, nó được coi là xử lý và sẽ bị xóa khỏi danh sách các tỷ lệ kèo bóng đá trực tuyến hôm nay.
pgnotify *pqnotifyes (pgconn *Conn); typedef struct pgnotify char *relname; / * Tên kênh tỷ lệ kèo bóng đá trực tuyến hôm nay */ int be_pid; / * Quy trình ID tỷ lệ kèo bóng đá trực tuyến hôm nay quy trình máy chủ */ char *thêm; / * Chuỗi tải trọng tỷ lệ kèo bóng đá trực tuyến hôm nay */ Pgnotify;
Sau khi xử lý ApgnotifyĐối tượng được trả về bởipqnotifyes
, Hãy chắc chắn giải phóng nó bằngPQFreemem
. Nó đủ để giải phóngpgnotifyCon trỏ; TherelnamevàExtraCác trường tỷ lệ kèo bóng đá trực tuyến hôm nay đại diện cho phân bổ riêng biệt. (Tên của các trường này là lịch sử; đặc biệt, tên kênh tỷ lệ kèo bóng đá trực tuyến hôm nay cần phải làm gì với tên quan hệ.)
Ví dụ 31-2Đưa ra một chương trình mẫu minh họa cho việc sử dụng tỷ lệ kèo bóng đá trực tuyến hôm nay bộ.
pqnotify
tỷ lệ kèo bóng đá trực tuyến hôm nay thực sự đọc dữ liệu từ máy chủ; nó chỉ trả về các tin nhắn được hấp thụ trước đó bởi một người kháclibpqHàm. Trong các bản phát hành trước củalibpq, Cách duy nhất để đảm bảo nhận được thời giantỷ lệ kèo bóng đá trực tuyến hôm nayTin nhắn đã liên tục gửi các lệnh, thậm chí các lệnh trống, sau đó kiểm trapqnotify
sau mỗiPQEXEC
. Mặc dù điều này vẫn hoạt động, nhưng nó tỷ lệ kèo bóng đá trực tuyến hôm nay được lãng phí sức mạnh xử lý.
Cách tốt hơn để kiểm tratỷ lệ kèo bóng đá trực tuyến hôm nayTin nhắn Khi bạn tỷ lệ kèo bóng đá trực tuyến hôm nay có lệnh hữu ích để thực thi là gọiPQConsumeInput
, sau đó kiểm trapqnotifyes
. Bạn có thể sử dụngselect ()
Để chờ dữ liệu đến từ máy chủ, do đó tỷ lệ kèo bóng đá trực tuyến hôm nay sử dụngCPUsức mạnh trừ khi có việc gì đó. (Nhìn thấyPQSocket
Để có được số mô tả tệp để sử dụng vớiselect ()
.) Lưu ý rằng điều này sẽ hoạt động OK cho dù bạn gửi các lệnh vớiPQSendQuery
/PQGetResult
hoặc đơn giản là sử dụngPQEXEC
. Tuy nhiên, bạn nên nhớ kiểm trapqnotifyes
sau mỗiPQGetResult
hoặcPQEXEC
, để xem có bất kỳ tỷ lệ kèo bóng đá trực tuyến hôm nay nào được đưa vào trong quá trình xử lý lệnh không.