V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
Aluhao
V2EX  ›  问与答

MYSQL 数据表结构设计问题

  •  
  •   Aluhao · 2018-11-14 10:31:24 +08:00 · 1312 次点击
    这是一个创建于 2201 天前的主题,其中的信息可能已经有所发展或是发生改变。
    设计一:
    设计一增加了自增 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;
    7 条回复    2018-11-14 11:47:47 +08:00
    kslr
        1
    kslr  
       2018-11-14 10:54:33 +08:00
    我会把 ID 和索引都开了
    simapple
        2
    simapple  
       2018-11-14 11:05:55 +08:00
    我会先把引擎换成 InnoDB
    Aluhao
        3
    Aluhao  
    OP
       2018-11-14 11:12:20 +08:00
    @simapple 这也是一种方法,但 InnoDB 不好维护呀
    Aluhao
        4
    Aluhao  
    OP
       2018-11-14 11:14:48 +08:00
    @kslr 表自增 ID 其实没什么用
    kslr
        5
    kslr  
       2018-11-14 11:27:04 +08:00 via Android
    @Aluhao 我想表达的是优化一天时间 足够买几 t 硬盘
    Aluhao
        6
    Aluhao  
    OP
       2018-11-14 11:46:28 +08:00
    @kslr 增加硬盘能解决优化查询问题吗?
    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   ·   实用小工具   ·   1249 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 18:07 · PVG 02:07 · LAX 10:07 · JFK 13:07
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.