p30连接池
基本实现;
1.标准接口 datesource
*获取方法:
getConnection()
*归还方法: close()如果获取对象是从Connection从连接池中获取,那么调动close方法归还链接
2.一般数据库厂商提供
c3p0:数据库连接技术(老)
1.导入jar包 mchange-commons-java-0.2.12.jar c3p0-0.9.5.2.jar
2.配置文件 c3p0-config.xml c3p0.properties
路径放在src下
3.创建数据库吃连接对象
4.关闭
public static void main(String[] args) throws SQLException {
// TODO Auto-generated method stub
DataSource ds=new ComboPooledDataSource();
Connection con = ds.getConnection();
for (int i = 1; i < 11; i++) {
System.out.println(i +":"+ con);
}
con.close();
}
druid:德鲁伊 数据库连接技术 阿里巴巴提供 性能最好
1.导包 druid-1.0.9.jar
2.定义配置文件
properties形式
可以叫任意名字,任意位置
//template的一个工具类
package Dbutils;
import java.io.IOException;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Properties;
import javax.sql.DataSource;
import com.alibaba.druid.pool.DruidDataSourceFactory;
public class DruidUtils {
//定义一个全局变量ds
private static DataSource ds;
//自定义代码块实现ds属性的初始化
static{
Properties pro = new Properties();
InputStream is = DruidUtils.class.getResourceAsStream("/druid.properties");
try {
pro.load(is);
ds = DruidDataSourceFactory.createDataSource(pro);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
//定义一个获取connection的方法
public static Connection getConnection() throws SQLException{
return ds.getConnection();
}
public static void close(Statement stmt,Connection con){
if(stmt!=null){
try {
stmt.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if(con!=null){
try {
con.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
//定义归还资源的方法
public static void close(Statement stmt,Connection con,ResultSet rs){
if(rs!=null){
try {
rs.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if(stmt!=null){
try {
stmt.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if(con!=null){
try {
con.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
Sping JDBC 简单封装 (灵魂框架)
提供一个jdbcTemplate对象简化开发
步骤:
1.导入jar包
2.创建template对象。依赖于数据源
3.调用方法完成操作
update 执行DMl语句
queryformap 查询结果封装为map集合
queryforlist 封装为list
queryforobject 封装为基本对象
query 封装为bean
public class classTest {
public static void main(String[] args) {
// TODO Auto-generated method stub
JdbcTemplate tem=new JdbcTemplate(DruidUtils.getDataSource());
System.out.println(tem);
String sql="update class set classname='hh' where classid=?";
int count = tem.update(sql,5);
System.out.println(count);
}
}