首页
注册
登录
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请
登录
V2EX 提问指南
广告
V2EX
›
问与答
MYSQL 数据表结构设计问题
Aluhao
·
2018-11-14 10:31:24 +08:00
· 1265 次点击
这是一个创建于 2015 天前的主题,其中的信息可能已经有所发展或是发生改变。
设计一:
设计一增加了自增 ID,数据量占用磁盘空间会稍大些,索引战胜小些;
100 万条数据磁盘占用:45.00 MB 索引占用:49.70 MB
设计二:
没有自增 ID,数据量占用磁盘空间稍小些,但索引占用会大些;
100 万条数据磁盘占用:33.00 MB 索引占用:73.10 MB
这个表以后可能会有好几 G 的大小,如果是你,你们会选择那种?
查询速度测试差异不大;
设计一
CREATE TABLE `follow` (
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
`uid` bigint(20) unsigned NOT NULL DEFAULT '0',
`aid` bigint(20) unsigned NOT NULL DEFAULT '0',
`cid` tinyint(3) unsigned NOT NULL DEFAULT '0',
`time` int(10) unsigned NOT NULL DEFAULT '0',
PRIMARY KEY (`id`),
KEY `uid` (`uid`,`time`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
设计二
CREATE TABLE `follow` (
`uid` bigint(20) unsigned NOT NULL DEFAULT '0',
`aid` bigint(20) unsigned NOT NULL DEFAULT '0',
`cid` tinyint(3) unsigned NOT NULL DEFAULT '0',
`time` int(10) unsigned NOT NULL DEFAULT '0',
PRIMARY KEY (`uid`,`aid`),
KEY `uid` (`uid`,`time`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
第 1 条附言 ·
2018-11-14 11:14:22 +08:00
经过测试,我们常用的查询就是这条,其实翻页都挺快的 基本在 0.01 秒
SELECT * FROM follow WHERE uid='1' ORDER BY time DESC LIMIT 10000, 10;
正常查最新的都是 0.001
SELECT * FROM follow WHERE uid='1' ORDER BY time DESC LIMIT 0, 10;
default
null
unsigned
uid
7 条回复
•
2018-11-14 11:47:47 +08:00
1
kslr
2018-11-14 10:54:33 +08:00
我会把 ID 和索引都开了
2
simapple
2018-11-14 11:05:55 +08:00
我会先把引擎换成 InnoDB
3
Aluhao
OP
2018-11-14 11:12:20 +08:00
@
simapple
这也是一种方法,但 InnoDB 不好维护呀
4
Aluhao
OP
2018-11-14 11:14:48 +08:00
@
kslr
表自增 ID 其实没什么用
5
kslr
2018-11-14 11:27:04 +08:00 via Android
@
Aluhao
我想表达的是优化一天时间 足够买几 t 硬盘
6
Aluhao
OP
2018-11-14 11:46:28 +08:00
@
kslr
增加硬盘能解决优化查询问题吗?
7
kslr
2018-11-14 11:47:47 +08:00
@
Aluhao
“查询速度测试差异不大”
“ 100 万条数据磁盘占用:45.00 MB 索引占用:49.70 MB ”
“ 100 万条数据磁盘占用:33.00 MB 索引占用:73.10 MB ”
“这个表以后可能会有好几 G 的大小,如果是你,你们会选择那种?”
关于
·
帮助文档
·
博客
·
API
·
FAQ
·
实用小工具
·
1243 人在线
最高记录 6679
·
Select Language
创意工作者们的社区
World is powered by solitude
VERSION: 3.9.8.5 · 26ms ·
UTC 18:12
·
PVG 02:12
·
LAX 11:12
·
JFK 14:12
Developed with
CodeLauncher
♥ Do have faith in what you're doing.