Druid 土办法将ResultSet结果集封装到类
数据库连接池基本介绍
1.预先在缓冲池中放入一定数量的连接, 当需要建立数据库连接时,秩序从"缓冲池"中取出一个,使用完毕之后再放回去
2.数据库连接池负责分配,管理和释放数据库连接, 它允许应用程序重复使用一个现有的数据库连接, 而不是重新建立一个
3.当应用程序想连接池请求的连接数超过最大连接数量时, 这些请求将被加入到等待队列
/*
基于德鲁伊数据库连接池的工具类
*/
public class JDBCUtilsByDruid {
private static DataSource ds;
//在静态代码块完成 ds 初始化
static {
Properties properties = new Properties();
try {
properties.load(new FileInputStream("src\\druid.properties"));
ds = DruidDataSourceFactory.createDataSource(properties);
} catch (Exception e) {
e.printStackTrace();
}
}
//编写getConnection方法
public static Connection getConnection() throws Exception{
return ds.getConnection();
}
//关闭连接
public static void closeConnection(ResultSet resultSet, Statement statement,Connection connection){
//判断是否为null
try {
if(resultSet != null){
resultSet.close();
}
if (statement != null){
statement.close();
}
if (connection != null){
connection.close();
}
} catch (SQLException e) {
throw new RuntimeException(e);
}
}
}
//使用土方法解决ResultSet 封装到 ArrayList集合中
@Test
public void testSelectToArrayList(){
System.out.println("使用 druid方式完成");
Connection connection = null;
ResultSet resultSet = null;
PreparedStatement preparedStatement =null;
String sql = "select * from actor where id >=?";
ArrayList<Actor> list = new ArrayList<>();//存放Actor对象
try {
connection = JDBCUtilsByDruid.getConnection();
preparedStatement = connection.prepareStatement(sql);
preparedStatement.setInt(1,1);
resultSet = preparedStatement.executeQuery();
//遍历结果集
while(resultSet.next()){
int id = resultSet.getInt("id");
String name = resultSet.getString("name");
String sex = resultSet.getString("sex");
Date borndate = resultSet.getDate("borndate");
String phone = resultSet.getString("phone");
//把得到的resultSet 的记录, 封装到 Actor对象, 放入list集合
list.add(new Actor(id,name,sex,borndate,phone));
}
System.out.println("list集合数据="+list);
for (Actor actor : list){
System.out.println("id="+actor.getId()+"\t"+actor.getName());
}
} catch (Exception e) {
e.printStackTrace();
} finally {
JDBCUtilsByDruid.closeConnection(resultSet,preparedStatement,connection);
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!