位置: IT常识 - 正文

面试官:一千万的数据,你是怎么查询的(面试官:一千万是真的吗)

编辑:rootadmin
面试官:一千万的数据,你是怎么查询的 面试官:一千万的数据,你是怎么查询的?

推荐整理分享面试官:一千万的数据,你是怎么查询的(面试官:一千万是真的吗),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:价值千万的面试,应聘一千万的那个人怎么样了,面试者要求一千万,面试官:一千万是真的吗,面试者要求一千万,面试官:一千万是真的吗,面试者要求一千万,面试官:一千万的数据,你是怎么查询的?,内容如对您有帮助,希望把文章链接给更多的朋友!

前言面试官:来说说,一千万的数据,你是怎么查询的?B哥:直接分页查询,使用limit分页。面试官:有实操过吗?B哥:肯定有呀

此刻献上一首《凉凉》

也许有些人没遇过上千万数据量的表,也不清楚查询上千万数据量的时候会发生什么。

今天就来带大家实操一下,这次是基于MySQL 5.7.26做测试

准备数据

没有一千万的数据怎么办?

创建呗

代码创建一千万?那是不可能的,太慢了,可能真的要跑一天。可以采用数据库脚本执行速度快很多。

创建表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;创建数据脚本

采用批量插入,效率会快很多,而且每1000条数就commit,数据量太大,也会导致批量插入效率慢

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 标压渣渣i5 读写约500MB的SSD

由于配置低,本次测试只准备了3148000条数据,占用了磁盘5G(还没建索引的情况下),跑了38min,电脑配置好的同学,可以插入多点数据测试

SELECT count(1) FROM `user_operation_log`

返回结果:3148000

三次查询时间分别为:

14060 ms13755 ms13447 ms普通分页查询

MySQL 支持 LIMIT 语句来选取指定的条数数据, Oracle 可以使用 ROWNUM 来选取。

MySQL分页查询语法如下:

SELECT * FROM table LIMIT [offset,] rows | rows OFFSET offset第一个参数指定第一个返回记录行的偏移量第二个参数指定返回记录行的最大数目

下面我们开始测试查询结果:

SELECT * FROM `user_operation_log` LIMIT 10000, 10

查询3次时间分别为:

59 ms49 ms50 ms

这样看起来速度还行,不过是本地数据库,速度自然快点。

换个角度来测试

相同偏移量,不同数据量SELECT * FROM `user_operation_log` LIMIT 10000, 10SELECT * FROM `user_operation_log` LIMIT 10000, 100SELECT * FROM `user_operation_log` LIMIT 10000, 1000SELECT * FROM `user_operation_log` LIMIT 10000, 10000SELECT * FROM `user_operation_log` LIMIT 10000, 100000SELECT * FROM `user_operation_log` LIMIT 10000, 1000000

查询时间如下:

从上面结果可以得出结束:数据量越大,花费时间越长

相同数据量,不同偏移量SELECT * FROM `user_operation_log` LIMIT 100, 100SELECT * FROM `user_operation_log` LIMIT 1000, 100SELECT * FROM `user_operation_log` LIMIT 10000, 100SELECT * FROM `user_operation_log` LIMIT 100000, 100SELECT * FROM `user_operation_log` LIMIT 1000000, 100面试官:一千万的数据,你是怎么查询的(面试官:一千万是真的吗)

从上面结果可以得出结束:偏移量越大,花费时间越长

SELECT * FROM `user_operation_log` LIMIT 100, 100SELECT id, attr FROM `user_operation_log` LIMIT 100, 100如何优化

既然我们经过上面一番的折腾,也得出了结论,针对上面两个问题:偏移大、数据量大,我们分别着手优化

优化偏移量大问题采用子查询方式

我们可以先定位偏移位置的 id,然后再查询数据

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

查询结果如下:

从上面结果得出结论:

第一条花费的时间最大,第三条比第一条稍微好点子查询使用索引速度更快

缺点:只适用于id递增的情况

id非递增的情况可以使用以下写法,但这种缺点是分页查询只能放在子查询里面

注意:某些 mysql 版本不支持在 in 子句中使用 limit,所以采用了多个嵌套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必须是连续递增,而且还得计算id的范围,然后使用 between,sql如下

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

查询结果如下:

从结果可以看出这种方式非常快

注意:这里的 LIMIT 是限制了条数,没有采用偏移量

优化数据量大问题

返回结果的数据量也会直接影响速度

SELECT * FROM `user_operation_log` LIMIT 1, 1000000SELECT id FROM `user_operation_log` LIMIT 1, 1000000SELECT 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

查询结果如下:

从结果可以看出减少不需要的列,查询效率也可以得到明显提升

第一条和第三条查询速度差不多,这时候你肯定会吐槽,那我还写那么多字段干啥呢,直接 * 不就完事了

注意本人的 MySQL 服务器和客户端是在_同一台机器_上,所以查询数据相差不多,有条件的同学可以测测客户端与MySQL分开

SELECT * 它不香吗?

在这里顺便补充一下为什么要禁止 SELECT *。难道简单无脑,它不香吗?

主要两点:

用 "SELECT * " 数据库需要解析更多的对象、字段、权限、属性等相关内容,在 SQL 语句复杂,硬解析较多的情况下,会对数据库造成沉重的负担。增大网络开销,* 有时会误带上如log、IconMD5之类的无用且大文本字段,数据传输size会几何增涨。特别是MySQL和应用程序不在同一台机器,这种开销非常明显。结束

最后还是希望大家自己去实操一下,肯定还可以收获更多,欢迎留言!!

创建脚本我给你正好了,你还在等什么!!!

本文链接地址:https://www.jiuchutong.com/zhishi/292956.html 转载请保留说明!

上一篇:【uniapp】 的事件处理详解(uniapp实战)

下一篇:从观景台俯瞰格雷梅,格雷梅国家公园,土耳其卡帕多西亚省 (© Anton Petrus/Getty Images)(观景台俯视图)

  • 微信积分怎么开通(微信积分怎么开通积分功能)

    微信积分怎么开通(微信积分怎么开通积分功能)

  • 小天才可以下载微信吗(小天才可以下载美团吗)

    小天才可以下载微信吗(小天才可以下载美团吗)

  • 快手直播怎么挂小黄车(快手直播怎么挂小铃铛)

    快手直播怎么挂小黄车(快手直播怎么挂小铃铛)

  • 钉钉签到禁止位置微调是什么情况(钉钉签到不定位)

    钉钉签到禁止位置微调是什么情况(钉钉签到不定位)

  • 为什么软件打不开(为什么软件打不开电脑)

    为什么软件打不开(为什么软件打不开电脑)

  • zenly位置不更新是为什么(zenly位置不更新电量不更新)

    zenly位置不更新是为什么(zenly位置不更新电量不更新)

  • oneplusa5000是什么手机(oneplusa5000是什么型号中文名字)

    oneplusa5000是什么手机(oneplusa5000是什么型号中文名字)

  • 拼多多需要营业执照吗(拼多多代运营收费标准)

    拼多多需要营业执照吗(拼多多代运营收费标准)

  • 华为平板matepad pro可以用windows系统吗(华为平板matepadpro12.6英寸)

    华为平板matepad pro可以用windows系统吗(华为平板matepadpro12.6英寸)

  • 电源适配器损坏的表现(电源适配器损坏原因及对策)

    电源适配器损坏的表现(电源适配器损坏原因及对策)

  • 电脑上网课总是卡是什么原因(电脑上网课总是卡手机不卡)

    电脑上网课总是卡是什么原因(电脑上网课总是卡手机不卡)

  • qq升一级需要多少天(qq升一级加多少能量)

    qq升一级需要多少天(qq升一级加多少能量)

  • 兼容模式有什么好处(兼容模式有什么好处和坏处)

    兼容模式有什么好处(兼容模式有什么好处和坏处)

  • 手机分享热点会中毒吗(手机分享热点会不会给手机带来厉害)

    手机分享热点会中毒吗(手机分享热点会不会给手机带来厉害)

  • 苹果手机换手机怎么转移照片(苹果手机换手机通讯录怎么导入)

    苹果手机换手机怎么转移照片(苹果手机换手机通讯录怎么导入)

  • 抖音如何添加相册视频(抖音如何添加相同的文字)

    抖音如何添加相册视频(抖音如何添加相同的文字)

  • ppt配色的原则与分类(ppt常见的配色方法)

    ppt配色的原则与分类(ppt常见的配色方法)

  • 借别人的腾讯vip咋登录(借别人的腾讯vip咋登录手机)

    借别人的腾讯vip咋登录(借别人的腾讯vip咋登录手机)

  • 快手可以分身吗(华为手机快手可以分身吗)

    快手可以分身吗(华为手机快手可以分身吗)

  • 苹果相机闪光灯不亮(苹果相机闪光灯怎么设置方法)

    苹果相机闪光灯不亮(苹果相机闪光灯怎么设置方法)

  • 苹果官网在哪里打开(苹果官网在哪里查)

    苹果官网在哪里打开(苹果官网在哪里查)

  • iphonex失灵乱跳(苹果x手机失灵屏幕乱跳)

    iphonex失灵乱跳(苹果x手机失灵屏幕乱跳)

  • 三星dex模式怎么开启(三星dex模式怎么用键盘)

    三星dex模式怎么开启(三星dex模式怎么用键盘)

  • autonavi是什么文件夹

    autonavi是什么文件夹

  • 和月薪5W的阿里程序员聊过后,才知道自己一直在打杂...(阿里月薪3万到手多少)

    和月薪5W的阿里程序员聊过后,才知道自己一直在打杂...(阿里月薪3万到手多少)

  • 支付给员工的工资属于什么科目
  • 出口退税分类管理办法最新
  • 视同销售的销项税怎么计算?
  • 海运报文是什么意思
  • 汇票签收后可以撤回吗
  • 建筑公司没有资质可以施工吗
  • 资产季末值
  • 加计扣除企业所得税季报申报
  • 开办费抵扣多少企业所得税
  • 转让固定资产发生的费用可以税前扣除吗
  • 两免三减半的概率是多少
  • 企业所得有哪些税种
  • 税收返还要交税吗
  • 材料采购发生的合理损耗计入
  • 计提水利建设基金的依据
  • 合同印花税进哪个科目
  • 个体户怎么申请核定征收
  • 交社保公积金需要劳动合同吗
  • 个税申报系统的备份保留几份数据
  • 小规模纳税人缴纳增值税的会计科目
  • 税务机关代码不能为空怎么解决
  • 当收到转账支票时,应该如何处理?
  • 钱打到对公账户
  • 收到别人的文章或书,应该怎样表示
  • 员工可以一起辞职吗
  • 回收站右键菜单修改
  • 出口货物收汇核销流程
  • Win10新版21364发布: 可直接运行Linux图形程序
  • 怎么在bios里设置usb开关
  • 杜鹃花怎么养家庭养法视频
  • 显卡性能排行榜2023
  • 高新企业研发费用占比规定
  • edi文件怎么打开
  • 提前支付的费用记账
  • 怎么处理坏账准备的问题
  • php文本分割
  • linux+php
  • 快递行业一般纳税人税率是多少
  • php不同用户登录不同页面
  • php css教程下载
  • 带有折扣的增值税怎么算
  • 企业销售旧固定资产税票开票
  • 企业财务报表有附注吗
  • 原材料月底结转到制造费用吗
  • 小微企业免征增值税政策2022
  • 个人所得税可以取出来用吗
  • 综合所得申报是个人所得税申报吗
  • 个人所得税进一步改革方向
  • mysql数据库如何升级
  • SQL设置外键
  • 招待客人有什么讲究
  • 土地使用权的使用是什么意思
  • 单位购买的化妆品怎么用
  • 增值税免税优惠梳理
  • 烈士祭扫仪式
  • 个税手续费返还比例
  • 出口抵减内销产品应纳税额分录
  • 记账凭证后面附发票第几联
  • 购买的税控盘可以全额抵扣,怎么报
  • 内账税金如何做分录
  • 冲回上年度费用分录
  • 新开办的企业怎么做账
  • 企业优惠政策是什么意思
  • 企业建账的流程是什么
  • hyper怎么用
  • 如何让计算机自动关机
  • win1020h2版本千万别更新
  • win7开机出现两个系统选项
  • dos怎么开启
  • Unity3D游戏开发基础
  • 用来检测程序小错误的测试方法
  • jquery教程chm
  • angular.js
  • 简述javascript
  • 没工作个人所得税
  • 版权登记条件
  • 免税证明如何办理
  • 怎么绑定办税员
  • 水利基金要收滞纳金吗
  • 二手房个税怎么算
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设