数据库优化之列选取原则

今天面试的时候遇到一个问题“数据库优化”。

感觉是个大方面,今天总结一下列选取的原则。

列选择原则:

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

原因:

整型: 定长,没有国家/地区之分,没有字符集的差异。

time定长,运算快,节省空间. 考虑时区,sql时不方便 where > ‘2005-10-12’;

char 定长, 考虑字符集和(排序)校对集

varchar, 不定长 要考虑字符集的转换与排序时的校对集,速度慢.

text/Blob 无法使用内存临时表,一旦有字段用blog,那么就会到磁盘排序。磁盘上建临时表。

2: 够用就行,不要慷慨 (smallint,varchar(N))

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

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

3: 尽量避免用NULL()

原因: NULL不利于索引,要用【特殊的字节】来标注.

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

null也不便于查询,

where 列名=null;   

where 列名!=null; 都查不到值,

where 列名 is null  ,is not null 才可以查询

测试

1.建立一个表t1,t2,并插入数据。我们看一下空和null两个“值”所占的长度。


2.看它们占的长度


可以看到null要比''多保存一个null,也就是多保存一个字节。所以要减少用null。


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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值