mysql中NULL值对索引的影响

时间:2025-03-11 06:58:31

mysql中NULL值对索引的影响

  • NULL的三种形式
  • innodb提供了一个系统变量:

NULL的三种形式

  1. NULL值代表一个未确定的值,每一个NULL值都是独一无二的,在统计列不重复值的时候应该都当作独立的。
  2. NULL值在业务上就是代表没有,所有的NULL值代表的意义是一样的,所以所有的NULL值都一样,在统计列不重复值的时候应该只算一个。
  3. NULL完全没有意义,在统计列不重复值的时候应该忽略NULL。

innodb提供了一个系统变量:

show global variables like '%innodb_stats_method%';~

这个变量有三个值:
最好不在索引列中存放NULL值1. nulls_equal:认为所有NULL值都是相等的。这个值也是innodb_stats_method的默认值。如果某个索引列中NULL值特别多的话,这种统计方式会让优化器认为某个列中平均一个值重复次数特别多,所以倾向于不使用索引进行访问。
2. nulls_unequal:认为所有NULL值都是不相等的。如果某个索引列中NULL值特别多的话,这种统计方式会让优化器认为某个列中平均一个值重复次数特别少,所以倾向于使用索引进行访问。
3. nulls_ignored:直接把NULL值忽略掉。

因此, 最好不在索引列中存放NULL值~