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);
}

}

posted on 2022-04-20 16:07  我要当程序源  阅读(196)  评论(0编辑  收藏  举报

导航