Thực hiện một truy vấn riêng biệt không phải là một giải pháp tốt (theo ý kiến của tôi) vì máy chủ sẽ tìm kiếm các hàng hai lần cho một tập kết quả.
Để ngăn truy vấn "kép", MySQL có hàm FOUND_ROWS (), nó trả về một số hàng được thiết lập cho các điều kiện hiện tại từ WHERE
mệnh đề. Điều này rất hữu ích khi bạn sử dụng LIMIT và OFFSET trong truy vấn. Tôi tin rằng sử dụng hàm này là một giải pháp tốt hơn. http://dev.mysql.com/doc/refman/5.0/en/information-functions.html# Chức năng_found-rows
Tôi đã đọc một thời gian trước đây rằng JDBC truyền trực tuyến các hàng từ máy chủ, nhưng đây không phải là tài liệu chính thức và tôi không thể biết nó hoạt động như thế nào ở hiện tại, nhưng các truy vấn có thể khác - với các truy vấn phụ và kết hợp khó. Tôi nghĩ rằng máy chủ đó có thể hoàn thành tất cả các tài nguyên nếu sẽ "phát trực tuyến" các hàng này chỉ khi khách hàng yêu cầu chúng.