原来boolean不能初始化为空和对应于mysql数据库中类型与存取

  最经在做一个项目用一个表中有一个性别的属性用tinyint(1)对应与 java中的Boolean。但是当我用反射来将result中的数据反射成对象并赋值的时候发现报IllegalArgumentException这个错误。

  原因是我在数据库中没有为这个属性设置值所以它为空值,等取出时sex属性要转化为false或true但是这个属性为空会报错我做了一个实验:

public class Test {
	private static boolean sex=(Boolean) null;
	public static void main(String[] args) {
		Person p = new Person();
		
		p.setSex(sex);
		System.out.println(p.isSex());
	}
}

   他就会报错,也是这个原因不能这样对boolean初始化为空。如果未对boolean类型初始化java会初始化boolean为false, 当java对象转换为数据库的数据时会自动变为0。所以我们在数据库中表示性别的时候最好用默认值而且不能为空1为真0为假,当从mysql数据库存取时这个属性会自动转化成对应的类型。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值