Mysql
 sql >> Cơ Sở Dữ Liệu >  >> RDS >> Mysql

Máy tính để bàn Java - làm cách nào để tách quyền truy cập cơ sở dữ liệu khỏi chuỗi giao diện người dùng?

Có vẻ như các truy vấn db của bạn được chạy từ chuỗi giao diện người dùng mặc dù bạn nói rằng một tác vụ đã lên lịch chạy các truy vấn (?). Để chắc chắn, bạn có thể in ra một stacktrace nơi bạn truy cập cơ sở dữ liệu:

new Exception().printStacktrace();

Chuyển sang giải pháp được đề xuất của bạn:nó có vẻ là một thiết kế phù hợp nếu các truy vấn db của bạn chậm và nếu không sẽ đóng băng giao diện người dùng của bạn. Bạn có thể triển khai hệ thống sự kiện giữa lớp giao diện người dùng và lớp db, có lẽ là một cách tiếp cận dựa trên hàng đợi đơn giản.

CHỈNH SỬA:

Rất có thể có những ví dụ để tìm cách triển khai giải pháp dựa trên sự kiện.

Tuyên bố từ chối trách nhiệm:Tôi đã không thực hiện bất kỳ lập trình giao diện người dùng thực nào trong nhiều năm.

  1. Người dùng nhấp vào một nút trong giao diện người dùng. Chuỗi giao diện người dùng đặt một đối tượng sự kiện (DataWANTEvent) vào hàng đợi (java.util.Queue), thay đổi nhãn ("Đang chờ dữ liệu ..."), sau đó tiếp tục và đợi các tương tác khác của người dùng.
  2. Luồng lớp db nhận dạng sự kiện làm hàng đợi và truy vấn cơ sở dữ liệu. Kết quả được đăng lại trên một hàng đợi khác trong một đối tượng kết quả.
  3. Một chuỗi giao diện người dùng (có thể không phải là chuỗi chính) lấy đối tượng kết quả từ hàng đợi kết quả và cập nhật giao diện người dùng.

Có thể không cần một hàng đợi để đăng các đối tượng kết quả trở lại giao diện người dùng. Một phương thức cập nhật có thể được gọi trực tiếp.

Nếu người dùng nhấp vào nút hủy, sự kiện cập nhật / lệnh gọi lại có thể bị bỏ qua hoặc nếu có thể, truy vấn db có thể bị hủy.



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. PDO + MySQL luôn trả về chuỗi, nhưng MsSQL thì sao?

  2. MySQL chọn một trường từ bảng điều kiện WHERE nằm trong nhiều hàng

  3. MYSQL đặt múi giờ trong mã PHP

  4. mySql - tạo liên kết bằng cách sử dụng danh sách các giá trị được phân tách bằng dấu phẩy

  5. Cố gắng đặt bàn nhiều lần