JDBC ResultSet.getxxx,基本数值型如何区分是0还是null
1个回答
推荐于2018-03-07 · 知道合伙人数码行家
huanglenzhi
知道合伙人数码行家
向TA提问 私信TA
知道合伙人数码行家
采纳数:117538
获赞数:517199
长期从事计算机组装,维护,网络组建及管理。对计算机硬件、操作系统安装、典型网络设备具有详细认知。
向TA提问 私信TA
关注
展开全部
JDBC中,对于ResultSet.getInt(), getLong()等获取基本数值型的函数,如果数据库中该字段是null,则函数的返回值是0。函数的返回值类型就已经决定了,不管怎么弄,也不可能返回null。
很多时候,通过在应用层限制不能在该字段中插入0值,可以实现是否为null的判断。如果应用无法限制,那该怎么办?
有一个勉强可用的方法:
1 在进行数值获取前,先通过ResultSet.getObject()来判断是否为null,这个函数可以明确地区分是null还是0;
2 如果不为null,则再通过ResultSet.getxxx()把值拿到,或者自己对ResultSet.getObject()返回的结果进行处理也可以。
从MySQL Connector/J的源码来看,getObject()返回的已经是进行解码并进行封装的基本值类对象,例如Integer,Long等。如果再通过ResultSet.getxxx()获取,Connector/J会再次进行解码,纯属浪费运算时间。
另一个方法是:
通过getxxx()把值拿到,然后通过wasNull()方法可确认刚获取到的值是否为null。这个方法能避免重复解码,也避免需要自己进行强制类型转换。唯一的限制是wasNull()方法只能在getxxx()后执行。
很多时候,通过在应用层限制不能在该字段中插入0值,可以实现是否为null的判断。如果应用无法限制,那该怎么办?
有一个勉强可用的方法:
1 在进行数值获取前,先通过ResultSet.getObject()来判断是否为null,这个函数可以明确地区分是null还是0;
2 如果不为null,则再通过ResultSet.getxxx()把值拿到,或者自己对ResultSet.getObject()返回的结果进行处理也可以。
从MySQL Connector/J的源码来看,getObject()返回的已经是进行解码并进行封装的基本值类对象,例如Integer,Long等。如果再通过ResultSet.getxxx()获取,Connector/J会再次进行解码,纯属浪费运算时间。
另一个方法是:
通过getxxx()把值拿到,然后通过wasNull()方法可确认刚获取到的值是否为null。这个方法能避免重复解码,也避免需要自己进行强制类型转换。唯一的限制是wasNull()方法只能在getxxx()后执行。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询