Mysql字符超出限制问题

本文介绍了如何通过设置sessionVariables中的sql_mode为NO_ENGINE_SUBSTITUTION来避免因数据过长导致的Datatruncation问题,同时提到将jdbcCompliantTruncation设置为false以允许JDBC在必要时进行非严格字符串截断以防止异常。
摘要由CSDN通过智能技术生成

Data truncation: Data too long for column 'column_name'

解决方案:

sessionVariables=sql_mode='NO_ENGINE_SUBSTITUTION'&jdbcCompliantTruncation=false

解释:

  1. sessionVariables=sql_mode='NO_ENGINE_SUBSTITUTION':这部分定义了会话变量,其中sql_mode='NO_ENGINE_SUBSTITUTION'设置了MySQL的sql_mode参数。sql_mode参数用于设置MySQL服务器的SQL模式,这里设置为NO_ENGINE_SUBSTITUTION,表示在严格模式下禁用了ENGINE=DEFAULT选项。这意味着如果表类型(例如InnoDB或MyISAM)不可用时,MySQL不会隐式更改表的存储引擎。

  2. jdbcCompliantTruncation=false:这部分是JDBC的一个参数,用于指示当通过JDBC截断字符串时是否严格遵循JDBC规范。如果设置为false,则JDBC可能会允许截断字符串,而不会抛出DataTruncation异常。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值