数据库优化之列选取原则
今天面试的时候遇到一个问题“数据库优化”。
感觉是个大方面,今天总结一下列选取的原则。
列选择原则:
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。