mysql tinyint1isbit_MySQL "tinyInt1isBit or tinyint(1)" 相关问题解析

当MySQL的tinyInt数据类型长度为1时,与JAVA转换可能出现问题。官方JDBC文档指出,若tinyInt1isBit=true(默认),长度为1则转为Boolean,否则转为Integer。解决方案包括:1. 避免用tinyInt(1)存储数字,只用于Boolean,0代表False,1代表True;2. 在JDBC URL中添加tinyInt1isBit=false参数,以确保正确转换。
摘要由CSDN通过智能技术生成

问题描述

tinyInt 的数据类型,在JAVA数据类型 和 MySQL的数据类型转换,要注意存储长度为 1 的情况。查询时,该字段对应的Java类型为Boolean

源数据:

3c6bf548dddbf00ee5aa664ed45db757.png

读取后数据:

0f4cef7e06160f522ee4f93993638993.png

问题分析

MySQL官方的JDBC文档定义转换规则如下:

ad53665d576070dde08515243a954748.png

如果tinyInt1isBit=true(默认),且tinyInt存储长度为1,则转为java.lang.Boolean,否则转为java.lang.Integer。

解决方案

1、避免使用长度为 1 的 tinyint 类型字段存储数字格式的数据,tinyInt(1) 只用来代表Boolean含义的字段。其中 0 代表False,1 代表True。如果要存储多个数值,则定义为tinyInt(N), N>1。例如 tinyInt(2)

2、JDBC的URL增加 tinyInt1isBit=false参数,注意参数名区分大小写,否则不生效。

final private val URL = "jdbc:mysql://localhost:3306/test_db?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=convertToNull&tinyInt1isBit=false&serverTimezone=Asia/Shanghai&useSSL=true"

conn_str="jdbc:mysql://${hostname}/${db_name}?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=convertToNull&tinyInt1isBit=false&serverTimezone=Asia/Shanghai&useSSL=true&dontTrackOpenResources=true&defaultFetchSize=10000&useCursorFetch=true"

Amazing MySQL !~~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值