怎么处理数据库连接失败异常

printf_2012 2010-09-02 10:01:15
问题:有时候数据库连接失败,程序好像还继续往下运行,会报个空指针异常,现在就是怎么处理这个数据库连接出的问题,报错直接捕获,程序不往下运行,不就不会包那个空指针异常。。代码如下,帮修改下下。很感谢!

public List selectMark(Integer mark) {
jdbc = new JDBConnection();
connection = jdbc.connection;
List list = new ArrayList();
GoodsForm goods = null;
String sql = "";
try {
if(mark==0||mark==1||mark==null){
sql = "select * from tb_goods where spsd=1 order by id DESC";
}else if(mark==2){
sql = "select * from tb_goods where mark="+mark+" and spsd=1 and sysdate between begin_time and end_time order by id DESC";
}else if(mark==3){
sql = "select * from tb_goods where mark="+mark+" and spsd=1 order by id DESC";
}else if(mark==4){
sql = "select * from tb_goods where mark="+mark+" and spsd=1 order by id DESC";
}
ps = connection.prepareStatement(sql);
//ps.setInt(1, mark.intValue());
ResultSet rs = ps.executeQuery();
while (rs.next()) {
goods = new GoodsForm();
goods.setId(Integer.valueOf(rs.getString(1)));
goods.setBig(Integer.valueOf(rs.getString(2)));
goods.setSmall(Integer.valueOf(rs.getString(3)));
goods.setName(rs.getString(4));
goods.setFrom(rs.getString(5));
goods.setIntroduce(rs.getString(6));
goods.setCreaTime(rs.getString(7));
goods.setNowPrice(Float.valueOf(rs.getString(8)));
goods.setFreePrice(Float.valueOf(rs.getString(9)));
goods.setNumber(Integer.valueOf(rs.getString(10)));
goods.setPriture(rs.getString(11));
goods.setMark(Integer.valueOf(rs.getString(12)));
goods.setSpsd(Integer.valueOf(rs.getString(13)));
if (rs.getString(14) != null) {
goods.setSalesNumber(Integer.valueOf(rs.getString(14)));
} else {
goods.setSalesNumber(0);
}
if (rs.getString(15) != null) {
goods.setSpdm(Integer.valueOf(rs.getString(15)));
} else {
goods.setSpdm(0);
}
goods.setSpec(rs.getString(16));
goods.setUnit(rs.getString(17));
goods.setBarCode(rs.getString(18));
goods.setPurchase_price(rs.getString(19));
goods.setSpecialOffer(rs.getString(20));
list.add(goods);
}
rs.close();
ps.close();
connection.close();
} catch (SQLException ex) {
ex.printStackTrace();
}
return list;
}

...全文
541 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
magong 2010-09-02
  • 打赏
  • 举报
回复
在捕获到连接异常后,在那个catch块中,扔一个运行时异常出去。这样就直接到顶了,别人干扰不了。

throw new RuntimeException("数据库连接失败");
soli11722984 2010-09-02
  • 打赏
  • 举报
回复
。。。。。。
想理清楚你想干嘛
1、数据库连接异常了,就自然查不出数据,那么,你想让前台知道然后处理还是你后台自己处理
2、后台处理:既然出错了,就告诉前台,后台出问题,该怎么怎么怎么
前台处理:后台出了错,就把异常一直往外面抛,直到某个前台页面,可以处理的(WEB应用中,不现实)
printf_2012 2010-09-02
  • 打赏
  • 举报
回复
[Quote=引用 4 楼 soli11722984 的回复:]

连接的异常抛出去
[/Quote]
加个try...catch..但是要return ,返回什么呢
printf_2012 2010-09-02
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 chao360559040 的回复:]

JDBConnection()中你看下你写的连接数据库语句,账号密码都有没有正确啊
[/Quote]
连接数据库应该没错,前段时间服务器那边还没报数据库加载失败错误。。。昨天吃饭回来服务器那边就报错了,数据库连接加载失败,不会是服务器那边网络的问题吧。。我都没动它,以前还不会报这个错。。
eagleking012 2010-09-02
  • 打赏
  • 举报
回复
空指针异常的trace在哪里
soli11722984 2010-09-02
  • 打赏
  • 举报
回复
连接的异常抛出去
printf_2012 2010-09-02
  • 打赏
  • 举报
回复
[Quote=引用楼主 printf_2012 的回复:]
问题:有时候数据库连接失败,程序好像还继续往下运行,会报个空指针异常,现在就是怎么处理这个数据库连接出的问题,报错直接捕获,程序不往下运行,不就不会包那个空指针异常。。代码如下,帮修改下下。很感谢!
Java code

public List selectMark(Integer mark) {
jdbc = new JDBConnection();
conn……
[/Quote]
把错误信息输入出来,怎么说也不能让程序继续运行。。。那怎么处理比较好呢?谢谢了
chao360559040 2010-09-02
  • 打赏
  • 举报
回复
JDBConnection()中你看下你写的连接数据库语句,账号密码都有没有正确啊
soli11722984 2010-09-02
  • 打赏
  • 举报
回复
那么我想问个问题,既然连接数据库失败了,那么自然就查不了数据,那你想返回什么?null?

81,094

社区成员

发帖
与我相关
我的任务
社区描述
Java Web 开发
社区管理员
  • Web 开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧