JAVA学习网首页 把生活查询网加入收藏 把JAVA学习网设为首页 联系方式
    Hi,JAVA学习
JAVA基础 设计模式 数据库 JavaBeans J2EE JavaDelphi 用户界面 综合文章  
学会如何处理数据库中的null
时间:22/04/2007
作者:网络
来源:网络
小提示点这里把文章加入您的收藏夹,方便下次查看
设置文章字体大小:[ ]
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
}
上一篇:使用PreparedStatement减少开发时间

下一篇:Java技术实现数据库应用系统慨述

  • 好的JAVA风格(英译)
  • jbuilder 2005 update 4
  • Java 数据对象(JDO)介绍(二)
  • Apusic1.1.2安装过程中遇到的jdk相关问题解答
  • 告别System.out.print()—J2SDK1.4新增Java日志框架(三)
  • Javamail操作指南(二)
  • 一个聊天室中遇到的问题!
  • 告别System.out.print()—J2SDK1.4新增Java日志框架(一)
  • 一个用JAVA开发的会话密钥程序,可能对你有所帮助
  • Ajax: Java BluePrints 和 Rails对它的封装
  • 设计模式的点滴(二)
  • 连接 Java 与 COM,连接 J2EE 与 .NET
  • 七条对于中国大学软件专业同学一些建议 作者: 梁振,严诺
  • Java Thread Programming 1.8.2 - Inter-thread Communication
  • 走向J2EE,漫长的道路
  • 《Java语言程序设计》reference
  • 在LINUX下配置JAVA开发环境
  • class Prime
  • 返回】 【顶部】 【关闭
    Copyright © 2005-2010 www.594k.com All Rights Reserved.
    版权所有:JAVA学习网 备案序号:皖ICP备06004238号