数据库优化之列选取原则

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

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

列选择原则:

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。