javaweb后端实例 dao

本文介绍了一个具体的DAO层实现案例,展示了如何通过封装SQL语句并利用PreparedStatement执行查询操作,最终将结果集转换为StationInfoDO对象列表的过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

DAO层主要作用在  封装sql语句,并将sql语句获取到的结果存进do创建的集合里面  linklist  arraylist  等


代码实现如下


public class StationDao {
private final String query_sido_by_year = "select stn,wban,station_name,latitude,longitude"
        + " from station_info where end_date >=?";


// 查多个。方法以list开头
// 查一个。方法以get开头
// 如果有查询条件,listxxxByxxx,YYY为条件手段
public List<StationInfoDO> listSIDOByYear(int year) {
List<StationInfoDO> list = new LinkedList<StationInfoDO>();
Connection conn = null;
PreparedStatement ps = null;
ResultSet rs = null;


// 通过调用工具类的静态方法获取数据库的连接对象
try {
conn = JDBCUtils.getConnnection();
ps = conn.prepareStatement(query_sido_by_year);
ps.setString(1, year + "0101");
rs = ps.executeQuery();
int index = 0;
while (rs.next()) {
StationInfoDO SIDO = new StationInfoDO();// 用对象封装散装数据
SIDO.setStn(rs.getString("stn"));
SIDO.setWban(rs.getString("wban"));
SIDO.setStationName(rs.getString("station_name"));
SIDO.setLatitude(rs.getBigDecimal("latitude"));
SIDO.setLongitude(rs.getBigDecimal("longitude"));
list.add(SIDO);
index++;
}
System.out.println(index);
} catch (SQLException e) {
e.printStackTrace();
} finally {
releaseResource(conn, ps, rs);
}
return list;
}


public void releaseResource(Connection conn, PreparedStatement ps, ResultSet rs) {
if (conn != null) {
try {
conn.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
;
if (ps != null) {
try {
ps.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if (rs != null) {
try {
rs.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}


}
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值