| 
1.1 数据源(连接池)的作用  数据源(连接池)是提高程序性能如出现的 事先实例化数据源,初始化部分连接资源 使用连接资源时从数据源中获取 使用完毕后将连接资源归还给数据源 常见的数据源(连接池):DBCP、C3P0、BoneCP、Druid等 开发步骤 ①导入数据源的坐标和数据库驱动坐标 ②创建数据源对象 ③设置数据源的基本连接数据 ④使用数据源获取连接资源和归还连接资源 1.2 数据源的手动创建①导入c3p0和druid的坐标 <!-- C3P0连接池 --> 
<dependency> 
    <groupId>c3p0</groupId> 
    <artifactId>c3p0</artifactId> 
    <version>0.9.1.2</version> 
</dependency> 
<!-- Druid连接池 --> 
<dependency> 
    <groupId>com.alibaba</groupId> 
    <artifactId>druid</artifactId> 
    <version>1.1.10</version> 
</dependency>①导入mysql数据库驱动坐标 <!-- mysql驱动 --> 
<dependency> 
    <groupId>mysql</groupId> 
    <artifactId>mysql-connector-java</artifactId> 
    <version>5.1.39</version> 
</dependency>②创建C3P0连接池 @Test 
public void testC3P0() throws Exception { 
    //创建数据源 
    ComboPooledDataSource dataSource = new ComboPooledDataSource(); 
    //设置数据库连接参数 
    dataSource.setDriverClass("com.mysql.jdbc.Driver");                                    dataSource.setJdbcUrl("jdbc:mysql://localhost:3306/test"); 
    dataSource.setUser("root"); 
    dataSource.setPassword("root"); 
    //获得连接对象 
    Connection connection = dataSource.getConnection(); 
    System.out.println(connection); 
} 
②创建Druid连接池 @Test 
public void testDruid() throws Exception { 
    //创建数据源 
    DruidDataSource dataSource = new DruidDataSource(); 
    //设置数据库连接参数 
    dataSource.setDriverClassName("com.mysql.jdbc.Driver");  
    dataSource.setUrl("jdbc:mysql://localhost:3306/test");    
    dataSource.setUsername("root"); 
    dataSource.setPassword("root"); 
    //获得连接对象 
    Connection connection = dataSource.getConnection();     
    System.out.println(connection); 
}③提取jdbc.properties配置文件 jdbc.driver=com.mysql.jdbc.Driver 
jdbc.url=jdbc:mysql://localhost:3306/test 
jdbc.username=root 
jdbc.password=root④读取jdbc.properties配置文件创建连接池 @Test 
public void testC3P0ByProperties() throws Exception { 
    //加载类路径下的jdbc.properties 
    ResourceBundle rb = ResourceBundle.getBundle("jdbc"); 
    ComboPooledDataSource dataSource = new ComboPooledDataSource();  
    dataSource.setDriverClass(rb.getString("jdbc.driver"));    
    dataSource.setJdbcUrl(rb.getString("jdbc.url"));  
    dataSource.setUser(rb.getString("jdbc.username"));  
    dataSource.setPassword(rb.getString("jdbc.password")); 
    Connection connection = dataSource.getConnection();    
    System.out.println(connection); 
}1.3 Spring配置数据源可以将DataSource的创建权交由Spring容器去完成 DataSource有无参构造方法,而Spring默认就是通过无参构造方法实例化对象的 DataSource要想使用需要通过set方法设置数据库连接信息,而Spring可以通过set方法进行字符串注入 <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"> 
    <property name="driverClass" value="com.mysql.jdbc.Driver"/> 
    <property name="jdbcUrl" value="jdbc:mysql://localhost:3306/test"/> 
    <property name="user" value="root"/> 
    <property name="password" value="root"/> 
</bean>测试从容器当中获取数据源 ApplicationContext applicationContext = new  
           ClassPathXmlApplicationContext("applicationContext.xml"); 
               DataSource dataSource = (DataSource)  
applicationContext.getBean("dataSource"); 
Connection connection = dataSource.getConnection(); 
System.out.println(connection);1.4 抽取jdbc配置文件applicationContext.xml加载jdbc.properties配置文件获得连接信息。 首先,需要引入context命名空间和约束路径: 命名空间:xmlns:context="http://www.springframework.org/schema/context" 约束路径:http://www.springframework.org/schema/context                                           http://www.springframework.org/schema/context/spring-context.xsd <context:property-placeholder location="classpath:jdbc.properties"/> 
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"> 
    <property name="driverClass" value="${jdbc.driver}"/> 
    <property name="jdbcUrl" value="${jdbc.url}"/> 
    <property name="user" value="${jdbc.username}"/> 
    <property name="password" value="${jdbc.password}"/> 
</bean>1.5 知识要点 Spring容器加载properties文件 <context:property-placeholder location="xx.properties"/> 
<property name="" value="${key}"/>2. Spring注解开发2.1 Spring原始注解Spring是轻代码而重配置的框架,配置比较繁重,影响开发效率,所以注解开发是一种趋势,注解代替xml配置文件可以简化配置,提高开发效率。  Spring原始注解主要是替代<Bean>的配置 注解说明 
@Component使用在类上用于实例化Bean 
@Controller使用在web层类上用于实例化Bean 
@Service使用在service层类上用于实例化Bean 
@Repository使用在dao层类上用于实例化Bean 
@Autowired使用在字段上用于根据类型依赖注入 
@Qualifier结合@Autowired一起使用用于根据名称进行依赖注入 
@Resource相当于@Autowired+@Qualifier,按照名称进行注入 
@Value注入普通属性 
@Scope标注Bean的作用范围 
@PostConstruct使用在方法上标注该方法是Bean的初始化方法 
@PreDestroy使用在方法上标注该方法是Bean的销毁方法注意:  
 |