Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1503485
  • 博文数量: 3500
  • 博客积分: 6000
  • 博客等级: 准将
  • 技术积分: 43870
  • 用 户 组: 普通用户
  • 注册时间: 2008-05-03 20:31
文章分类

全部博文(3500)

文章存档

2008年(3500)

我的朋友

分类:

2008-05-04 20:27:02

一起学习
Java数据库连接(JDBC)结果集类掩盖了一个微小的bug,如果你忘记了使用wasNull方法的话。关系数据库中的NULL值的概念和Java中null的值的概念相似,前者任何类型都可以为null,但是在Java中,基本数据类型不能为null。当要读取一个数据库域赋值给一个基本类型的时候(例如resultSet.getInt(1)),可能会造成问题。这样的例子已经让JDBC规范的制订者开始研究如何解决。 当一个值通过如getInt、getLong、getFloat这样的getXxx方法从数据库中得到后,开发者可以调用wasNull()方法来找出其值是否为null。如果wasNull返回true,那么可以让开发者为基本类型选择使用合适的null值。GetXxx方法获得的值与JDBC的驱动紧密相关。 例如,在某个数据库驱动中,它返回0,另一个也许返回那一列的缺省值,也许还有一个返回驱动在那一列读取的最后一个值。 所以当你准备读取数据库中的NULL值的时候,要小心缺省值,你也许需要以下面的习惯编码: int idx = resultSet.getInt(1); if(resultSet.wasNull( )) { idx = -1; // this is our default value for idx } 下载本文示例代码


学会如何处理数据库中的null学会如何处理数据库中的null学会如何处理数据库中的null学会如何处理数据库中的null学会如何处理数据库中的null学会如何处理数据库中的null学会如何处理数据库中的null学会如何处理数据库中的null学会如何处理数据库中的null学会如何处理数据库中的null学会如何处理数据库中的null学会如何处理数据库中的null
阅读(179) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~