问题2:Inodb自增主键和业务主键优缺点

创建表

CREATE TABLE t_cic_customer1 (
id bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT ‘客户ID, 可以用客户ID或者source加mobile唯一表示用户’,
mobile varchar(20) NOT NULL COMMENT ‘客户手机号码’,
device_id varchar(64) DEFAULT ‘0’ COMMENT ‘设备号’,
cc_id int(11) DEFAULT NULL COMMENT ‘BC生成的客户ID’,
create_time datetime DEFAULT ‘0000-00-00 00:00:00’ COMMENT ‘创建时间’,
PRIMARY KEY (id),
UNIQUE KEY i_mobile_device (mobile,device_id),
KEY i_name (create_time)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT=’客户信息表’;

CREATE TABLE t_cic_customer2 (
mobile varchar(20) NOT NULL COMMENT ‘客户手机号码’,
device_id varchar(64) DEFAULT ‘0’ COMMENT ‘设备号’,
cc_id int(11) DEFAULT NULL COMMENT ‘BC生成的客户ID’,
create_time datetime DEFAULT ‘0000-00-00 00:00:00’ COMMENT ‘创建时间’,
PRIMARY KEY (mobile,device_id),
KEY i_name (create_time)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT=’客户信息表’;

插入测试数据:
insert into t_cic_customer1 select pid,mobile,device_id,cc_id,create_time from t_cic_customer;
insert into t_cic_customer2 select mobile,device_id,cc_id,create_time from t_cic_customer;

用户可以使用表t_cic_customer1和t_cic_customer2进行表设计。表1和表2有什么区别呢?
表1表3796237条记录,记录是按照顺序存储,占用空间537M,
优点:主键ID自增,在写入数据的时候,Btree分裂成本低,写性能高。
缺点:物理空间相对较多,如果根据mobile来查记录,需要走两次IO
适用场景:写操作较多的场景
表2表3796237条记录,记录是按照顺序存储,占用空间497M,
优点:物理空间相对减少,根据mobile查数据,直接走主键拿到数据,无需回表
缺点:(mobile,device_id)为随机写入,Btree分裂成本高,写性能低
适用场景:写少读多的场景,例如从hadoop回流到MySQL的统计结果表,这种统计结果一般数据较多,但主要是读。

总结:客户信息是属于读写比较多的操作,使用表1方案,设置id作为自增主键。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值