99国产精品欲av蜜臀,可以直接免费观看的AV网站,gogogo高清免费完整版,啊灬啊灬啊灬免费毛片

網(wǎng)易首頁 > 網(wǎng)易號 > 正文 申請入駐

面試官:一千萬的數(shù)據(jù),你是怎么查詢的?

0
分享至


來源:juejin.cn/post/6863668253898735629


  • 前言

  • 準(zhǔn)備數(shù)據(jù)

    • 創(chuàng)建表

    • 創(chuàng)建數(shù)據(jù)腳本

  • 開始測試

    • 普通分頁查詢

  • 如何優(yōu)化

    • 優(yōu)化偏移量大問題

    • 優(yōu)化數(shù)據(jù)量大問題

  • SELECT * 它不香嗎?

  • 結(jié)束

前言

  • 面試官:來說說,一千萬的數(shù)據(jù),你是怎么查詢的?

  • B哥:直接分頁查詢,使用limit分頁。

  • 面試官:有實(shí)操過嗎?

  • B哥:肯定有呀

此刻獻(xiàn)上一首《涼涼》

也許有些人沒遇過上千萬數(shù)據(jù)量的表,也不清楚查詢上千萬數(shù)據(jù)量的時(shí)候會發(fā)生什么。

今天就來帶大家實(shí)操一下,這次是基于MySQL 5.7.26做測試

準(zhǔn)備數(shù)據(jù)

沒有一千萬的數(shù)據(jù)怎么辦?

創(chuàng)建唄

代碼創(chuàng)建一千萬?那是不可能的,太慢了,可能真的要跑一天。可以采用數(shù)據(jù)庫腳本執(zhí)行速度快很多。

創(chuàng)建表 CREATE TABLE `user_operation_log` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`user_id` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,
`ip` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,
`op_data` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,
`attr1` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,
`attr2` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,
`attr3` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,
`attr4` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,
`attr5` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,
`attr6` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,
`attr7` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,
`attr8` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,
`attr9` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,
`attr10` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,
`attr11` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,
`attr12` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,
PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic;
創(chuàng)建數(shù)據(jù)腳本

采用批量插入,效率會快很多,而且每1000條數(shù)就commit,數(shù)據(jù)量太大,也會導(dǎo)致批量插入效率慢

DELIMITER ;;
CREATE PROCEDURE batch_insert_log()
BEGIN
DECLARE i INT DEFAULT 1;
DECLARE userId INT DEFAULT 10000000;
set @execSql = 'INSERT INTO `test`.`user_operation_log`(`user_id`, `ip`, `op_data`, `attr1`, `attr2`, `attr3`, `attr4`, `attr5`, `attr6`, `attr7`, `attr8`, `attr9`, `attr10`, `attr11`, `attr12`) VALUES';
set @execData = '';
WHILE i<=10000000 DO
set @attr = "'測試很長很長很長很長很長很長很長很長很長很長很長很長很長很長很長很長很長的屬性'";
set @execData = concat(@execData, "(", userId + i, ", '10.0.69.175', '用戶登錄操作'", ",", @attr, ",", @attr, ",", @attr, ",", @attr, ",", @attr, ",", @attr, ",", @attr, ",", @attr, ",", @attr, ",", @attr, ",", @attr, ",", @attr, ")");
if i % 1000 = 0
then
set @stmtSql = concat(@execSql, @execData,";");
prepare stmt from @stmtSql;
execute stmt;
DEALLOCATE prepare stmt;
commit;
set @execData = "";
else
set @execData = concat(@execData, ",");
end if;
SET i=i+1;
END WHILE;

END;;
DELIMITER ;
開始測試

哥的電腦配置比較低:win10 標(biāo)壓渣渣i5 讀寫約500MB的SSD

由于配置低,本次測試只準(zhǔn)備了3148000條數(shù)據(jù),占用了磁盤5G(還沒建索引的情況下),跑了38min,電腦配置好的同學(xué),可以插入多點(diǎn)數(shù)據(jù)測試

SELECT count(1) FROM `user_operation_log`

返回結(jié)果:3148000

三次查詢時(shí)間分別為:

  • 14060 ms

  • 13755 ms

  • 13447 ms

普通分頁查詢

MySQL 支持 LIMIT 語句來選取指定的條數(shù)數(shù)據(jù), Oracle 可以使用 ROWNUM 來選取。

MySQL分頁查詢語法如下:

SELECT * FROM table LIMIT [offset,] rows | rows OFFSET offset

  • 第一個(gè)參數(shù)指定第一個(gè)返回記錄行的偏移量

  • 第二個(gè)參數(shù)指定返回記錄行的最大數(shù)目

下面我們開始測試查詢結(jié)果:

SELECT * FROM `user_operation_log` LIMIT 10000, 10

查詢3次時(shí)間分別為:

  • 59 ms

  • 49 ms

  • 50 ms

這樣看起來速度還行,不過是本地?cái)?shù)據(jù)庫,速度自然快點(diǎn)。

換個(gè)角度來測試

相同偏移量,不同數(shù)據(jù)量 SELECT * FROM `user_operation_log` LIMIT 10000, 10
SELECT * FROM `user_operation_log` LIMIT 10000, 100
SELECT * FROM `user_operation_log` LIMIT 10000, 1000
SELECT * FROM `user_operation_log` LIMIT 10000, 10000
SELECT * FROM `user_operation_log` LIMIT 10000, 100000
SELECT * FROM `user_operation_log` LIMIT 10000, 1000000

查詢時(shí)間如下:


圖片

從上面結(jié)果可以得出結(jié)束:數(shù)據(jù)量越大,花費(fèi)時(shí)間越長

相同數(shù)據(jù)量,不同偏移量 SELECT * FROM `user_operation_log` LIMIT 100, 100
SELECT * FROM `user_operation_log` LIMIT 1000, 100
SELECT * FROM `user_operation_log` LIMIT 10000, 100
SELECT * FROM `user_operation_log` LIMIT 100000, 100
SELECT * FROM `user_operation_log` LIMIT 1000000, 100


圖片

從上面結(jié)果可以得出結(jié)束:偏移量越大,花費(fèi)時(shí)間越長

SELECT * FROM `user_operation_log` LIMIT 100, 100
SELECT id, attr FROM `user_operation_log` LIMIT 100, 100
如何優(yōu)化

既然我們經(jīng)過上面一番的折騰,也得出了結(jié)論,針對上面兩個(gè)問題:偏移大、數(shù)據(jù)量大,我們分別著手優(yōu)化

優(yōu)化偏移量大問題 采用子查詢方式

我們可以先定位偏移位置的 id,然后再查詢數(shù)據(jù)

SELECT * FROM `user_operation_log` LIMIT 1000000, 10SELECT id FROM `user_operation_log` LIMIT 1000000, 1SELECT * FROM `user_operation_log` WHERE id >= (SELECT id FROM `user_operation_log` LIMIT 1000000, 1) LIMIT 10

查詢結(jié)果如下:


從上面結(jié)果得出結(jié)論:

  • 第一條花費(fèi)的時(shí)間最大,第三條比第一條稍微好點(diǎn)

  • 子查詢使用索引速度更快

缺點(diǎn):只適用于id遞增的情況

id非遞增的情況可以使用以下寫法,但這種缺點(diǎn)是分頁查詢只能放在子查詢里面

注意:某些 mysql 版本不支持在 in 子句中使用 limit,所以采用了多個(gè)嵌套select
SELECT * FROM `user_operation_log` WHERE id IN (SELECT t.id FROM (SELECT id FROM `user_operation_log` LIMIT 1000000, 10) AS t)
采用 id 限定方式

這種方法要求更高些,id必須是連續(xù)遞增,而且還得計(jì)算id的范圍,然后使用 between,sql如下

SELECT * FROM `user_operation_log` WHERE id between 1000000 AND 1000100 LIMIT 100

SELECT * FROM `user_operation_log` WHERE id >= 1000000 LIMIT 100

查詢結(jié)果如下:


圖片

從結(jié)果可以看出這種方式非常快

注意:這里的 LIMIT 是限制了條數(shù),沒有采用偏移量
優(yōu)化數(shù)據(jù)量大問題

返回結(jié)果的數(shù)據(jù)量也會直接影響速度

SELECT * FROM `user_operation_log` LIMIT 1, 1000000

SELECT id FROM `user_operation_log` LIMIT 1, 1000000

SELECT id, user_id, ip, op_data, attr1, attr2, attr3, attr4, attr5, attr6, attr7, attr8, attr9, attr10, attr11, attr12 FROM `user_operation_log` LIMIT 1, 1000000

查詢結(jié)果如下:


圖片

從結(jié)果可以看出減少不需要的列,查詢效率也可以得到明顯提升

第一條和第三條查詢速度差不多,這時(shí)候你肯定會吐槽,那我還寫那么多字段干啥呢,直接 * 不就完事了

注意本人的 MySQL 服務(wù)器和客戶端是在_同一臺機(jī)器_上,所以查詢數(shù)據(jù)相差不多,有條件的同學(xué)可以測測客戶端與MySQL分開

SELECT * 它不香嗎?

在這里順便補(bǔ)充一下為什么要禁止 SELECT *。難道簡單無腦,它不香嗎?

主要兩點(diǎn):

  • 用 "SELECT * " 數(shù)據(jù)庫需要解析更多的對象、字段、權(quán)限、屬性等相關(guān)內(nèi)容,在 SQL 語句復(fù)雜,硬解析較多的情況下,會對數(shù)據(jù)庫造成沉重的負(fù)擔(dān)。

  • 增大網(wǎng)絡(luò)開銷,* 有時(shí)會誤帶上如log、IconMD5之類的無用且大文本字段,數(shù)據(jù)傳輸size會幾何增漲。特別是MySQL和應(yīng)用程序不在同一臺機(jī)器,這種開銷非常明顯。

結(jié)束

最后還是希望大家自己去實(shí)操一下,肯定還可以收獲更多,歡迎留言!!

創(chuàng)建腳本我給你正好了,你還在等什么!!!

特別聲明:以上內(nèi)容(如有圖片或視頻亦包括在內(nèi))為自媒體平臺“網(wǎng)易號”用戶上傳并發(fā)布,本平臺僅提供信息存儲服務(wù)。

Notice: The content above (including the pictures and videos if any) is uploaded and posted by a user of NetEase Hao, which is a social media platform and only provides information storage services.

相關(guān)推薦
熱點(diǎn)推薦
美國儲量全球第一,中國卻95%靠進(jìn)口,若美斷供中國如何應(yīng)對?

美國儲量全球第一,中國卻95%靠進(jìn)口,若美斷供中國如何應(yīng)對?

慎獨(dú)贏
2025-06-01 02:35:03
杜建英同學(xué)發(fā)聲,稱宗馥莉沒教養(yǎng)是惡人,杜建英多年一直愁眉不展

杜建英同學(xué)發(fā)聲,稱宗馥莉沒教養(yǎng)是惡人,杜建英多年一直愁眉不展

大笑江湖史
2025-07-18 07:37:43
師長抗命進(jìn)攻,救下十萬志愿軍,彭總夸贊:不愧是粟裕的頭號王牌

師長抗命進(jìn)攻,救下十萬志愿軍,彭總夸贊:不愧是粟裕的頭號王牌

老謝談史
2025-07-23 09:17:21
央企職工副高職稱,工齡 39 年,養(yǎng)老金有多少?

央企職工副高職稱,工齡 39 年,養(yǎng)老金有多少?

古裝影視解說阿兇
2025-07-23 14:05:57
不到24小時(shí)!雅魯藏布江工程剛動(dòng)工,印主持人:派飛機(jī)炸中國工地

不到24小時(shí)!雅魯藏布江工程剛動(dòng)工,印主持人:派飛機(jī)炸中國工地

南宗歷史
2025-07-23 16:59:28
“內(nèi)地劉鑾雄”玩脫了?過億家底拿不出2萬債款,20年資本難支撐

“內(nèi)地劉鑾雄”玩脫了?過億家底拿不出2萬債款,20年資本難支撐

科技説説説
2025-07-08 17:43:10
“我們才不要你的238億遺產(chǎn)”,邵逸夫離世,4個(gè)子女不送終不繼承

“我們才不要你的238億遺產(chǎn)”,邵逸夫離世,4個(gè)子女不送終不繼承

聚合大娛
2025-05-08 11:55:09
老祖宗常告誡“勿近白虎”,“白虎”究竟是什么?真有這么可怕嗎

老祖宗常告誡“勿近白虎”,“白虎”究竟是什么?真有這么可怕嗎

大千世界觀
2025-05-22 16:57:05
德布勞內(nèi)社媒:很高興今天上演首秀,比賽有助于恢復(fù)狀態(tài)

德布勞內(nèi)社媒:很高興今天上演首秀,比賽有助于恢復(fù)狀態(tài)

直播吧
2025-07-23 05:48:04
酒桌上敬酒,低情商的人只會說我敬你,高情商的人這么說

酒桌上敬酒,低情商的人只會說我敬你,高情商的人這么說

于觀潭
2023-11-23 21:10:03
吹捧美國空氣香甜的楊舒平,已被驅(qū)逐出境,如今回國下場大快人心

吹捧美國空氣香甜的楊舒平,已被驅(qū)逐出境,如今回國下場大快人心

跳跳歷史
2025-06-06 16:41:00
三名女子在空調(diào)房吃烤魚全部暈倒

三名女子在空調(diào)房吃烤魚全部暈倒

極目新聞
2025-07-23 08:31:09
鞏俐在巴黎和朋友聚會,臉部素顏皮膚超好,76歲老公外表很顯年輕

鞏俐在巴黎和朋友聚會,臉部素顏皮膚超好,76歲老公外表很顯年輕

興史興談
2025-07-23 12:57:49
3年換5隊(duì),曝葡萄牙金童告別切爾西,“C羅接班人”將回歸本菲卡

3年換5隊(duì),曝葡萄牙金童告別切爾西,“C羅接班人”將回歸本菲卡

夏侯看英超
2025-07-23 18:38:50
剛剛!武商集團(tuán)官宣!

剛剛!武商集團(tuán)官宣!

越喬
2025-07-23 16:56:39
特斯拉為Model 3/Y推出前備箱氛圍燈:369 元起,7月28日開售

特斯拉為Model 3/Y推出前備箱氛圍燈:369 元起,7月28日開售

IT之家
2025-07-23 16:02:21
顏駿凌談范德薩的祝福:非常感動(dòng)能收到來自兒時(shí)偶像的祝福

顏駿凌談范德薩的祝福:非常感動(dòng)能收到來自兒時(shí)偶像的祝福

懂球帝
2025-07-23 15:39:51
這次印度訪華全是反效果,幫中國徹底下決心,在西藏開工重大工程

這次印度訪華全是反效果,幫中國徹底下決心,在西藏開工重大工程

荷蘭豆愛健康
2025-07-22 11:45:09
毛岸英犧牲后,劉思齊改嫁河北青年楊茂之生四子,他究竟是什么人

毛岸英犧牲后,劉思齊改嫁河北青年楊茂之生四子,他究竟是什么人

萬物知識圈
2025-07-16 11:29:01
75歲港星宣布征婚,自曝37歲兒子內(nèi)地求學(xué)失敗,回家躺平需要他養(yǎng)

75歲港星宣布征婚,自曝37歲兒子內(nèi)地求學(xué)失敗,回家躺平需要他養(yǎng)

探源歷史
2025-07-21 07:29:49
2025-07-23 19:59:00
Meta
Meta
關(guān)注java進(jìn)階架構(gòu)師送架構(gòu)
1059文章數(shù) 9856關(guān)注度
往期回顧 全部

頭條要聞

印度、孟加拉關(guān)切雅魯藏布江下游水電站工程 中方回應(yīng)

頭條要聞

印度、孟加拉關(guān)切雅魯藏布江下游水電站工程 中方回應(yīng)

體育要聞

英格蘭最紅球星 也是加勒比島國驕傲

娛樂要聞

汪峰森林北同游日本 各帶各娃互不耽誤

財(cái)經(jīng)要聞

律師解析娃哈哈遺產(chǎn)案:遺囑是最大變數(shù)

科技要聞

別自嗨了!XREAL徐馳:AI眼鏡只有5歲智商

汽車要聞

德系大招放盡 場地極限測試全新奧迪A5L

態(tài)度原創(chuàng)

本地
時(shí)尚
教育
親子
公開課

本地新聞

這雙丑鞋“泰”辣眼,跪求內(nèi)娛不要抄作業(yè)

看來看去還是這些穿搭適合普通人!配色不艷、衣服不花,好得體

教育要聞

2025年天津高考提前批投檔線分析:中國民航大學(xué)訂單班受熱捧

親子要聞

新年吃什么爸爸說交給孩子們自己決定,又是有趣的一餐

公開課

李玫瑾:為什么性格比能力更重要?

無障礙瀏覽 進(jìn)入關(guān)懷版 主站蜘蛛池模板: 元朗区| 衡阳市| 桓仁| 阿坝县| 兴业县| 秀山| 合阳县| 长春市| 潜江市| 江油市| 全州县| 万源市| 高安市| 白城市| 曲阳县| 长宁县| 雅江县| 颍上县| 广元市| 克什克腾旗| 芜湖市| 漠河县| 泗洪县| 屏边| 远安县| 呼图壁县| 莱州市| 普兰店市| 余江县| 浦城县| 进贤县| 昌吉市| 改则县| 鹤山市| 周口市| 石阡县| 靖边县| 海阳市| 天镇县| 阳城县| 龙井市|