麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

關于分頁查詢和性能問題

2019-11-18 16:39:36
字體:
來源:轉載
供稿:網友

分頁查詢是經常能夠遇到的問題,我們首先看看分頁查詢存在的理由:

方便用戶:用戶不可能一次察看所有數據,所以一頁一頁的翻看比較好。
提高性能:一次從數據庫中提取所有數據會比較慢。
那么現在我來嘗試反駁上述理由:

真的方便嗎?我們考慮下面的情況
如果數據只有20條。
如果數據超過1000條。
第一種顯然不必分頁查詢。奇怪的是第二種也不必,因為沒有哪個用戶愿意一頁一頁的翻到最后,如果用戶查詢到的數據超過了他所關心的數據范圍,我認為應該讓他重新輸入查詢條件,就像我們使用google一樣。
但是作為一個友好的應用界面,我們總是希望用戶可以全面的了解他的查詢結果,所以有必要告訴用戶:“你查到了多少數據,但是,目前只能顯示前1000條,如果您希望察看所有數據,那么應該如何如何... ”
性能會提高嗎?
如果數據量很小,顯然性能不會有明顯的提升,相反,性能會大大下降。因為數據庫執行了不必要的查詢和查詢條件。
如果數據量很大,性能也不見得有明顯提升,因為你總是要執行一個額外的count查詢,并且,組合SQL的時候極有可能造成全表掃描。當然這要看數據庫的實現原理了。
可以想像,分頁查詢對于性能的影響和數據量之間的關系應該是一個曲線,數據量小的時候會降低性能,數據量大的時候可能(根據不同的數據庫)會提升性能。關鍵是通過測試,找到曲線的拐點。性能不是根據經驗和感覺得到的,而是通過測試得到的
另外,如果一次全部取出數據,的確會造成空間性能的影響,但是,現在內存很便宜...
負面影響
對于一個架構良好的web應用,將pageNo和PageSize在各個類之間傳遞實在是不爽,這兩個數據明顯屬于表現層。當然,如果你使用RoR算俺沒說。
明顯提高編程復雜度,尤其是在考慮數據庫無關性的時候。
奇怪的現象:為什么沒有一個大型數據庫直接提供分頁查詢?Oracle的RowNo不是用于分頁的,SQLServer的Top更不是。
結論
ExtremeTable、DisplayTag、JSF DataTable都提供了簡單的分頁方式,那就是在結果集合中分頁。使用非常方便,而且使得邏輯清晰,大大提高了工作效率。絕大多數情況下,可以直接使用這種方式。
如果通過測試,發現上述方式影響了性能,那么考慮使用分頁查詢。
對于用戶量很大的應用,因為內存的原因,也可以考慮分頁查詢。但是,我個人更推薦緩存方式:同樣的查詢放在一個緩存中...
采用合理的設計,屏蔽開發人員處理分頁邏輯。比如,將分頁邏輯和count查詢放在父類,開發人員負責組合查詢條件。具體看設計模式吧。
歡迎大家討論!!!


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 羞羞视频免费网站入口 | 亚洲午夜久久久久 | 国产精品久久久久久久久久久久午夜 | 久久久久久久久久综合 | 久久久久久久久91 | 国产va在线观看免费 | 久久第四色 | 色av成人天堂桃色av | 伊人在线视频 | av影院在线播放 | 成人爱爱电影 | 91久久91久久精品免观看 | 亚洲网站一区 | 91九色免费视频 | 91 在线观看| 国产免费一区二区三区视频 | 亚洲电影免费观看国语版 | 亚洲一区二区三区日本久久九 | 日韩黄色免费电影 | av免费在线播放 | 婷婷中文字幕一区二区三区 | 欧美三级短视频 | 国产精品美女久久久免费 | 精品国产一区二区三区在线观看 | 免费视频a | 久久羞羞视频 | 国产一区二区三区撒尿在线 | 亚洲黑人在线观看 | 一区二区三区国产视频 | 色污视频 | 日本在线播放一区二区三区 | 亚洲免费看片网站 | 久久国产精品久久久久久久久久 | 91,视频免费看 | 国产精品久久国产精麻豆96堂 | 在线中文字幕观看 | 久久情爱网 | 免费黄色在线 | 精品久久久久久亚洲精品 | 性爱视频免费 | 亚洲免费资源 |