常規的分頁寫法如下
```sql
select id,title,type from tablename order by id limit 100,10;
```
經測試,如果數據量比較大的時候,如近百萬的時候。查詢語句就變成了如下
```sql
select id,title,subtitle from tablename order by id limit 990000,10;
```
這時候查詢就耗時較長了。
主鍵id為連續數據,網上推薦的方法一般是子查詢和between(,初測BETWEEN速度更快) 寫法如下:
```sql
select id,title,subtitle from tablename id >=(select id from tablename limit 1000000,1) limit 10;
select id,title,subtitle from tablename BETWEEN 1000000 AND 1000010;
select id,title,subtitle from tablename where id>= 1000000 AND id<=1000010;
```
主鍵為非連續數據。一般是先查出ids 然后用in查詢較快
```sql
select id.title,subtitle from tablename in(100000,9999999,8548685,100);
```
看到segmentfault上一個問答,
> 至于優化查詢,本質上說,先要優化數據結構,仔細想想你是否必須非要用兩個表,一個行不行。還有你對數據庫內置函數的了解程度,比如left(), right(), substring(), substring_index()。還有 mid(), substr()。不要動不動就LIKE等等,主要還是多寫,根據實際應用場景來做出最優判斷。
順便一說MYSQL配置本身也可以進行很多優化,比如query_cache等等
看來應該抽時間,再次好好研讀一下mysql的知識了,基礎不牢,地動山搖啊!
- 說明
- PHP
- 數組操作
- file操作的常用方法
- PHP字符串輸出之Heredoc說明
- require(_once)和include(_once)的理解
- file_get_contents和curl
- PHP的json問題
- PHP提高效率的幾點
- PHP/異步任務隊列處理
- HTTP_AUTHORIZATION
- php中 intval和string的一些轉換問題
- 變量在 PHP7 內部的實現
- 關于exit和die
- php獲取微秒
- php高性能日志擴展seaslog的使用
- Curl使用說明
- echo的數據自動增加換行或其他
- php-memcache
- 根據18位數校驗前17位身份證號是否正確
- 將一個老項目升級到php7
- ord獲取ASCII碼
- 框架
- thinkphp5
- THINKPHP5常見問題
- Laravel5學習筆記
- homestead總結
- easywechat學習筆記
- wechat公眾號
- 獲取用戶信息的實現方式
- 前端
- HTML
- CSS
- 偽類和偽元素的區別
- Bootstrap使用
- Javascript
- Javascript梳理總結
- 巧用history.pushState無刷新改變頁面url
- jquery日期時間選擇器組件datepicker的使用說明
- 基本操作
- 比較
- 后端/Nodejs
- 多nodejs版本管理
- 小功能
- URLAPI
- 二維碼轉換
- 地圖URL直接實現導航
- 字體生成
- 網址長短互轉
- 百度短網址
- Fiddle模擬測試百度短網址api
- Composer備忘錄
- composer安裝配置
- Composer 錯誤集錦
- Composer使用自己的庫
- GIT簡單操作命令
- Git記住密碼
- git 顯示錯誤詳情和請求信息
- 工具軟件
- PHPStorm
- VI簡單操作命令
- ATOM
- browser提示shockwave false加載失敗
- Cmder使用說明
- Windows軟件總結
- 瀏覽器插件
- 支付
- 微信支付
- 支付寶
- 銀聯支付
- Ping++
- Beecloud支付
- Map
- 百度地圖BaiduMap
- RESTfulAPI設計實踐
- HTTP
- GET/POST 的請求大小
- 常見狀態碼說明
- Ubuntu
- 命令行中的>>和>的區別
- 筆記
- 正則
- Hybrid的使用記錄
- H5+和mui
- HTML5+和mui使用
- APP開發過程中藍牙問題總結
- Cordova的使用
- 服務器
- URL重寫
- 目錄限制訪問
- 軟鏈接和硬鏈接
- 票務系統對接資料和總結
- qunar去哪兒門票對接
- qunar對接case介紹及錯誤代碼
- tuniu門票對接總結
- 途牛小結
- 聯合票務對接途牛文檔說明
- 途牛簽名流程
- meituan美團
- 大眾點評
- 聯合票務
- 安卓使用技巧
- 安卓清理電池信息
- 安卓6.0使用時發現的問題
- 數據庫
- 數據庫mysql
- 分頁數據優化
- 手機號用不到索引的問題分析
- mysql配置的localhost和127.0.0.1的區別
- mysql5.5升級mysql5.7
- 數據庫MongoDB
- Redis使用說明
- phpredis使用說明
- 環境變量
- Twig使用
- 經典的文章
- 用超人的故事講解 IoC(控制反轉) 和 DI(依賴注入)