我们经常接触到SQL里面用到join时,如果关联条件类型不一致,会出现类型转换,引发索引失效的性能问题。
在主从复制中,如果同一字段在主从两端不一致,也是需要进行类型转换的,如果无法进行转换,从库复制线程会报错,使得从库复制异常停止。
主库的数据在从库进行类型转换的行为,由从库侧的slave_type_conversions控制,可以指定为以下的一个或多个值:
ALL_LOSSY
ALL_NON_LOSSY
ALL_SIGNED
ALL_UNSIGNED
有几个概念需要说明一下:
1.有损转换lossy conversion,无损转换non-lossy转换
当在类型转换中需要截断源数据来适应新的列时,就是有损转换,例如在插入小数位更短的列,需要进行截断小数位时,就是有损转换;不需要截断数据的转换即是无损转换。
2.属性提升,属性退化
例如源数据是tinyint,要存入bigint的列中,即是属性提升。
slave_type_conversions各取值说明:
1.ALL_LOSSY
只允许有损转换,例如由bigint转换为tinyint;但不允许无损转换,例如tinyint转换为bigint,如果出现这种情况,从库复制会报错并停止。
2.ALL_NON_LOSSY
只允许无损转换,如果发生有损转换,从库复制会报错并停止。
3.ALL_LOSSY,ALL_NON_LOSSY
slave_type_conversions是允许同时设置多个值的,例如当前这种情况,允许所有的类型转换。
4.ALL_SIGNED
数值数据在转换时发生属性提升时,将转换后的数据视为signed。
5.ALL_UNSIGNED
数据数据在转换时发生属性提升时,将转换后的数据视为unsiged。
6.ALL_SIGNED,ALL_UNSIGNED
数值数据在转换时发生属性提升时,优先将转换后的数据视为signed,其次才视为unsigned
7.空值,即slave_type_conversions不设置任何值
任何类型转换都不允许,主从的类型必须一致,否则在数据复制时会报错并停止。