java JDBC 连接池
Posted SasaL
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java JDBC 连接池相关的知识,希望对你有一定的参考价值。
package cn.sasa.demo1; import javax.sql.DataSource; import org.apache.commons.dbcp2.BasicDataSource; public class DBUtils { private static BasicDataSource datasource = new BasicDataSource(); static { /** * 连接池: * 存放连接的容器 * 不需要每次都创建连接、释放连接 * * DataSource接口 * java为数据库连接池提供的公共接口:javax.sql.DataSource * 常用的连接池: DBCP C3P0 * * 导入jar包 * DBCP连接池:http://commons.apache.org/proper/commons-dbcp/download_dbcp.cgi * Commons Pool:http://commons.apache.org/proper/commons-pool/download_pool.cgi * DBCP依赖于Pool * 只导入上面两个包运行如下代码会报错:java.lang.NoClassDefFoundError: org/apache/commons/logging/LogFactory * 还需导入包commons-logging:http://commons.apache.org/proper/commons-logging/download_logging.cgi */ //数据库连接信息,必须 datasource.setDriverClassName(DBProperties.driver); datasource.setUrl(DBProperties.url); datasource.setUsername(DBProperties.user); datasource.setPassword(DBProperties.pwd); //连接池的配置,可选信息 datasource.setInitialSize(10);//初始化的连接数 //.... } public static DataSource getDataSource() { return datasource; } }
package cn.sasa.demo1; import java.sql.SQLException; import java.util.List; import org.apache.commons.dbutils.QueryRunner; import org.apache.commons.dbutils.handlers.BeanListHandler; public class ConnectionPoolDemo { static QueryRunner query = new QueryRunner(DBUtils.getDataSource()); public static void main(String[] args) { select(); } static void select() { String sql = "SELECT * FROM product"; try { List<Product> plist = query.query(sql, new BeanListHandler<Product>(Product.class)); for(Product product : plist) { System.out.print(product.getPname()+"="+product.getPrice()+" "); } } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }
package cn.sasa.demo1; import java.io.IOException; import java.io.InputStream; import java.util.Properties; public class DBProperties { public static String driver = ""; public static String url = ""; public static String user = ""; public static String pwd = ""; static { try { InputStream input = DBProperties.class.getClassLoader().getResourceAsStream("database.properties"); Properties properties = new Properties(); properties.load(input); driver = properties.getProperty("driver"); url = properties.getProperty("url"); user = properties.getProperty("user"); pwd = properties.getProperty("pwd"); }catch(IOException ex){ // ex.printStackTrace(); throw new RuntimeException("数据库信息获取失败"); } } }
package cn.sasa.demo1; public class Product { private int pid; private String pname; private double price; private String ptype; private String create_tm; public Product() {} public Product(int pid, String pname,double price, String ptype, String create_tm) { this.pid = pid; this.pname = pname; this.price = price; this.ptype = ptype; this.create_tm = create_tm; } public int getPid() { return pid; } public void setPid(int pid) { this.pid = pid; } public String getPname() { return pname; } public void setPname(String pname) { this.pname = pname; } public double getPrice() { return price; } public void setPrice(double price) { this.price = price; } public String getPtype() { return ptype; } public void setPtype(String ptype) { this.ptype = ptype; } public String getCreate_tm() { return create_tm; } public void setCreate_tm(String create_tm) { this.create_tm = create_tm; } }
以上是关于java JDBC 连接池的主要内容,如果未能解决你的问题,请参考以下文章
Java 微服务 乐优网络商城 day02 源代码 SpringBoot 实战开发 整合JDBC和事务(数据库连接池)