91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MySQL的分頁優化方案

發布時間:2021-09-16 11:41:28 來源:億速云 閱讀:130 作者:chen 欄目:云計算

本篇內容主要講解“MySQL的分頁優化方案”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“MySQL的分頁優化方案”吧!

MySQL分頁優化:

SQL: select * from t_user u order by id limit 5000000, 10

分析:mysql會讀取5000010條數據,然后只返回最后10條,查詢的時間很長。

優化方案:
	方案一:只允許查詢前面的數據,不允許查詢特別靠后的數據。eg:百度搜索出的結果,最多七十多頁。

	方案二:在查詢下一頁時把上一頁最后一條數據的id(lastId)傳過來,即:select * from t_user u where id > 5000000 order by id limit 10

		注意:如果where條件中的判斷條件還有其它非主鍵列,則需要建立復合索引,復合索引中必須包含where語句中的列。

	方案三:延遲關聯非索引列,即:select * from t_user u1 inner join (select id from t_user  order by id limit 5000000, 10 ) u2 on u1.id=u2.id

實驗:

	環境:win7下MySQL5.6
		t_user表中有6,274,934條數據,以下是t_user的建表語句:
		CREATE TABLE `t_user` (
			`id` BIGINT(20) NOT NULL AUTO_INCREMENT,
			`bu_id` INT(20) NOT NULL,
			`name` VARCHAR(255) NOT NULL,
			`age` INT(11) NOT NULL,
			`sex` VARCHAR(255) NULL DEFAULT NULL,
			PRIMARY KEY (`id`)
		)
		COLLATE='utf8_general_ci'
		ENGINE=InnoDB;

	select * from t_user u order by id limit 5000000, 10
	# 2.746 sec		只有這一個查詢sql時,查詢所需的時間。
	# 25.615 sec	有一個不斷往t_user表中插新數據的函數(或過程)一直在跑的情況下,執行上面的sql查詢出數據所需的時間。
	
	select * from t_user u where id > 5000000 order by id limit 10
	# 0.047 sec		只有這一個查詢sql時,查詢所需的時間。
	# 0.063 sec		有一個不斷往t_user表中插新數據的函數(或過程)一直在跑的情況下,執行上面的sql查詢出數據所需的時間。

	select * from t_user u1 inner join (select id from t_user  order by id limit 5000000, 10 ) u2 on u1.id=u2.id
	# 2.137 sec		只有這一個查詢sql時,查詢所需的時間。
	# 13.604 sec	有一個不斷往t_user表中插新數據的函數(或過程)一直在跑的情況下,執行上面的sql查詢出數據所需的時間。

到此,相信大家對“MySQL的分頁優化方案”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

罗甸县| 锦州市| 仪征市| 麻江县| 武强县| 保康县| 安仁县| 泰兴市| 新沂市| 洛南县| 卢湾区| 甘谷县| 钟山县| 同心县| 同江市| 重庆市| 喀喇沁旗| 扶风县| 大港区| 古田县| 大埔县| 山丹县| 梅河口市| 来宾市| 施秉县| 大姚县| 若羌县| 卢龙县| 永宁县| 河北省| 从江县| 文登市| 霍山县| 沙湾县| 雷州市| 青阳县| 南宫市| 德庆县| 大宁县| 八宿县| 磐石市|