MYSQL哪种查询更快一点

php中文网
发布: 2016-06-23 14:05:56
原创
1072人浏览过


第一种:
表1:主键为A(20位bigint类型),字段B为字符串(表2的自增ID,多个以“,”分开)
表2:记录

第二种:
记录表,字段A自增,字段B为(20位bigint类型,可重复,加索引)


假设数据都很大,为了拿到某一个20位bigint类型的数据列表,哪种设计查询快?

造点AI
造点AI

夸克 · 造点AI

造点AI 325
查看详情 造点AI

回复讨论(解决方案)

没看懂,建议贴出表结构,举例说明。

20位bigint,有必要那么大吗?小心 64bit Integer 事件。

20位bigint,有必要那么大吗?小心 64bit Integer 事件。
什么事件呀?没听说过,求解释
是把字符串转成BIGINT的,为了查询快一点

haowen

引用 2 楼 changjay 的回复:20位bigint,有必要那么大吗?小心 64bit Integer 事件。
什么事件呀?没听说过,求解释
是把字符串转成BIGINT的,为了查询快一点


$large_number = 922337203685477580800;
echo $large_number; //9.2233720368548E+20

真的有必要生成那么多位的数字吗?

查询快,一般加index就可以了。INT(11) 11位数字最合理,多了其实也用不上,反而消耗内存资源。

楼上们都歪了...
针对你的问题: 第二种

当然是第二种!
虽然 mysql 提供了 find_in_set 函数可以方便的从逗号分隔的串中提起成员,但函数的执行总是要花点时间的。
哪能比直接读取来的快呢?

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号