java - 請教一個更加優雅的實現業務中的分頁加載的問題?
問題描述
在負責學校下學期圖書館的項目的一部分,現在碰到了一個業務設計的困難。
比如說在首頁的話,我計劃當學生查詢相關的信息的時候全部采用ajax加載,不是很習慣很多網站比如知乎那種拖動到底部自動加載。我的想法是在底部設置一個分頁的選項,每一頁顯示15條記錄,文章全部采用ajax加載。
這樣sql語句大概就是select xxx from xxx condition limit 15 offset xxx。但是現在由于要做分頁,我必須要知道一個學生總共有多少條記錄在數據庫中,前端才好設計,總記錄可以通過sql語句select count(*) from xxx condition查詢出來,然后將總記錄保存在前端中。
如果這樣的話,必須要為拆分成兩條sql語句查詢,感覺不是很優雅,請問有什么更加優雅的實現方案么?
ps: 因為在系統中有很多相似的業務都是要采用類似的分頁設計,每次都這樣使用兩條sql語句分開查詢太不優雅了。
補充
答主好像都沒看請題目。一位是答的就是sql語句1,另外一位說的是前端。
多謝各位網友的回答,問題已解決,看來只能采用兩條sql語句了 ^_^
問題解答
回答1:var start = 頁標 - 1;$.get('url?start=' + start * 15,function(){});
$start = $_GET['start'];$end = $start + 15;$sql = 'select * from table limit {$start}, {$end}';
select a.*, b.count from table a, (select count(*) as count from table ) b LIMIT 1,15回答2:
不用想了,必須是兩條的.要一條也行:select * from tableunion select 0, 0...., count(*) from table
回答3:這很正常。如果想用一條sql解決,就把所有對象從數據庫里查出來再做一系列操作,但搞不好你的內存就爆掉了。
回答4:不用想了 必須是兩條 。分頁的實現 定義一個泛型類page<T> 里面放什么 需要我說的更詳細嗎?
回答5:試試PageHelper,就一條sql語句,甚至不需要limit
回答6:要優雅的分頁 分頁的插件很多的
相關文章:
1. javascript - node服務端渲染的困惑2. mysql - 一個表和多個表是多對多的關系,該怎么設計3. Mysql && Redis 并發問題4. css - 求推薦幾款好用的移動端頁面布局調試工具呢?5. python - type函數問題6. javascript - 百度echarts series數據更新問題7. html5 - h5寫的app用的webview,用手機瀏覽器打開不顯示?8. php - 第三方支付平臺在很短時間內多次異步通知,訂單多次確認收款9. mysql新建字段時 timestamp NOT NULL DEFAULT ’0000-00-00 00:00:00’ 報錯10. css3 - css before 中文亂碼?
