Spring使用c3p0数据源
2016-03-11 17:02
344 查看
bean.xml
<?xml version="1.0" encoding="UTF-8"?> <!-- Spring配置文件的根元素,使用spring-beans-3.0.xsd语义约束 --> <beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://www.springframework.org/schema/beans" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd"> <!-- 定义数据源Bean,使用C3P0数据源实现 --> <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"> <!-- 指定链接数据库的驱动 --> <property name="driverClass" value="com.mysql.jdbc.Driver"/> <!-- 指定链接数据库的URl --> <property name="jdbcUrl" value="jdbc:mysql://localhost/mytest1"/> <!-- 指定数据库的用户名 --> <property name="user" value="root"/> <!-- 指定链接数据库的密码 --> <property name="password" value=""/> <!-- 指定链接数据库链接池的最大连接数 --> <property name="maxPoolSize" value="40"/> <!-- 指定链接数据库链接池的最大连接数 --> <property name="minPoolSize" value="1"/> <!-- 指定链接数据库链接池的初始化连接数 --> <property name="initialPoolSize" value="1"/> <!-- 指定链接数据库链接池的最大空闲时间 --> <property name="maxIdleTime" value="20"/> </bean> </beans>
/** * */ /** * @author c * */ package qi; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import javax.sql.DataSource; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; public class BeanTest{ public static void main(String[] args) throws Exception{ //实例化Spring容器 Spring容器负责实例化Bean ApplicationContext ctx = new ClassPathXmlApplicationContext("bean.xml"); //通过Bean id获得Bean实例,强制类型转换为DataSource DataSource ds = ctx.getBean("dataSource", DataSource.class); //通过DataSource来获取数据库链接 Connection conn = ds.getConnection(); //通过数据库链接获取PreparedStatement PreparedStatement pstmt = conn.prepareStatement("insert into user values(?,?)"); pstmt.setString(1, "java4S"); pstmt.setString(2, "dizhi "); //执行SQL语句 pstmt.executeUpdate(); //清理资源,回收数据库链接资源 if(pstmt != null)pstmt.close(); pstmt = conn.prepareStatement("select * from user where userId = ?"); pstmt.setString(1, "chc0618"); ResultSet rs = pstmt.executeQuery(); while(rs.next()){ System.out.println(rs.getString("userId")+" , 密码:"+rs.getString("uPS") ); } if(conn != null)conn.close(); } }
相关文章推荐
- java 模仿原版坦克大战
- java设计模式——结构型之适配器模式
- CXF+Spring 发布SOAP服务
- java工具类小知识
- [Java代码] Java 面向对象
- Eclipse 使用配置记录,快捷键
- [Java代码] Java排序算法之——希尔排序
- Eclipse中配置Struts2
- Spring+WebSocket整合(SSM)
- SpringMVC - 页面form表单绑定对象
- java中的闭包
- java 的3DES解密和加密
- Java_Iterable_Iterator_foreach学习笔记
- spark.driver.maxResultSize || java.lang.OutOfMemoryError
- SVN--(Eclipse)在历史记录中比较版本差异
- java的if-else和while用法
- 使用java反射机制对类字段进行选择性校验示例
- Java_移位运算
- Java常用类库--观察者设计模式( Observable类Observer接口)
- Java 获取类名,函数名,行数