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;
}
9 个解决方案
#1
那么我想问个问题,既然连接数据库失败了,那么自然就查不了数据,那你想返回什么?null?
#2
JDBConnection()中你看下你写的连接数据库语句,账号密码都有没有正确啊
#3
把错误信息输入出来,怎么说也不能让程序继续运行。。。那怎么处理比较好呢?谢谢了
#4
连接的异常抛出去
#5
空指针异常的trace在哪里
#6
连接数据库应该没错,前段时间服务器那边还没报数据库加载失败错误。。。昨天吃饭回来服务器那边就报错了,数据库连接加载失败,不会是服务器那边网络的问题吧。。我都没动它,以前还不会报这个错。。
#7
加个try...catch..但是要return ,返回什么呢
#8
。。。。。。
想理清楚你想干嘛
1、数据库连接异常了,就自然查不出数据,那么,你想让前台知道然后处理还是你后台自己处理
2、后台处理:既然出错了,就告诉前台,后台出问题,该怎么怎么怎么
前台处理:后台出了错,就把异常一直往外面抛,直到某个前台页面,可以处理的(WEB应用中,不现实)
想理清楚你想干嘛
1、数据库连接异常了,就自然查不出数据,那么,你想让前台知道然后处理还是你后台自己处理
2、后台处理:既然出错了,就告诉前台,后台出问题,该怎么怎么怎么
前台处理:后台出了错,就把异常一直往外面抛,直到某个前台页面,可以处理的(WEB应用中,不现实)
#9
在捕获到连接异常后,在那个catch块中,扔一个运行时异常出去。这样就直接到顶了,别人干扰不了。
throw new RuntimeException("数据库连接失败");
throw new RuntimeException("数据库连接失败");
#1
那么我想问个问题,既然连接数据库失败了,那么自然就查不了数据,那你想返回什么?null?
#2
JDBConnection()中你看下你写的连接数据库语句,账号密码都有没有正确啊
#3
把错误信息输入出来,怎么说也不能让程序继续运行。。。那怎么处理比较好呢?谢谢了
#4
连接的异常抛出去
#5
空指针异常的trace在哪里
#6
连接数据库应该没错,前段时间服务器那边还没报数据库加载失败错误。。。昨天吃饭回来服务器那边就报错了,数据库连接加载失败,不会是服务器那边网络的问题吧。。我都没动它,以前还不会报这个错。。
#7
加个try...catch..但是要return ,返回什么呢
#8
。。。。。。
想理清楚你想干嘛
1、数据库连接异常了,就自然查不出数据,那么,你想让前台知道然后处理还是你后台自己处理
2、后台处理:既然出错了,就告诉前台,后台出问题,该怎么怎么怎么
前台处理:后台出了错,就把异常一直往外面抛,直到某个前台页面,可以处理的(WEB应用中,不现实)
想理清楚你想干嘛
1、数据库连接异常了,就自然查不出数据,那么,你想让前台知道然后处理还是你后台自己处理
2、后台处理:既然出错了,就告诉前台,后台出问题,该怎么怎么怎么
前台处理:后台出了错,就把异常一直往外面抛,直到某个前台页面,可以处理的(WEB应用中,不现实)
#9
在捕获到连接异常后,在那个catch块中,扔一个运行时异常出去。这样就直接到顶了,别人干扰不了。
throw new RuntimeException("数据库连接失败");
throw new RuntimeException("数据库连接失败");