tinyint(1)的坑笔记(开发环境mysql,测试环境H2)

    菜鸟在开发时遇到的情况,开发用mysql,测试用H2,在写单元测试时发现mysql和h2数据查询结果不同,测试不通过,个人解决办法


一、mysql

mysql中没有布尔型  boolean=tinyint(1)

mysql 中 tinyint(1) 0代表false,其他数字代表true


二、H2

H2Database数据类型

tinyint(1)  值的范围为: -128 到 127.

对应到Java类型: java.lang.Byte.


解决办法:

野路子:把tyint转成int

SELECT
//...
CASE 列名 WHEN 0 THEN 0 WHEN 1 THEN 1 END AS 别名, 
//...
from
//...

正路:更改数据库配置文件或更改数据库该字段类型或长度

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值