表的优化与列类型索引

列选择原则:

  1. 字段类型优先级,整形 >date,time>char,varchar >blob

  2. 原因:整形time运算快,节省空间

char/varchar 要考虑字符集的转换与排序时的校对集,速度慢。

Blob无法使用内存临时表。

   2.够用就行,不求慷慨(如smallint,varchar(N))

原因:大的字段浪费内存,影响速度。

以varchar(10),varchar(300)存储的内容相同,但在表联查时,varchar(300)要花更多内存。


3。尽量避免使用null

原因:null不利于索引,要用特殊的字节来标注

在磁盘上占据的空间其实更大

可以自己建两张表进行测试,一个表允许为null,一个表不允许为null,explain的时候可以发现带null的表ken_len为4个字节,不为null的表ken_len为3个字节。

Enum的说明:

  1. enum列在内部是用整形来存储的。

  2. enum列与enum列相关联速度更快

  3. enum列 比(varchar,char)的弱势,在碰到与char关联时,要转化,要花时

  4. 优势在于,当char非常长时,enum依然是整型固定长度。当查询的数据量越大时,enum的优势越明显

  5. enum与char/varchar关联,因为要转化,速度要比enum->enum,cahr->cahr要慢但有时候也这么用,就是在数据量特别大时,可以节省IO.

  6. 列<---->列时间
    enum10.53
    char<-->char24.65
    varchar<-->varchar24.04
    enum<-->enum18.22




转载于:https://my.oschina.net/u/1414906/blog/284332

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值