MySQL参数 主从复制的类型转换slave_type_conversions

我们经常接触到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不设置任何值
任何类型转换都不允许,主从的类型必须一致,否则在数据复制时会报错并停止。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值