上次的Bean其实后面也有一些重要的知识没有说到:先做个补充:
ApplicationContext是spring框架中接口家族的一个子接口。它的具体实现有三种分别是ClassPathXMLApplicationContext(".xml文件名") 、FileSystemPathApplicationContext("磁盘绝对路径,如C://User/stu/h.xml")、注解里的实现方法,后续更新会提到。用的最多的就是第一个。
getBean();反射的两种实现第一种是getBean("id");这个id在上一文章里的id里有提到,具体说一说第二种getBean("id所属bean标签指向的全限定名代表的java类名.class");字节码文件反射,需要注意的是字节码文件是jvm实现一次编译多次执行的重要翻译过程,也就是说,后续的字节码文件不会更改,一次翻译多次使用,所以在bean实例化采取scope=“prototype”时,字节码文件不变,但是对象却不是实例化单例bean对象,他就会出问题报错误。 bean标签中的集合与列表以及properties三种标签的使用,其实很简单的,事先在javabean的类里面定义的变量属性如果为List、Map、properties后续的bean里的注入属性值就要相应的语法对应使用,当然我个人理解Map的键值对,会有比较好的实用性,因为它可以带着ref指向性就比较花里胡哨。开始正题了,今天不水了,早上八点起来就来图书馆开始往死里学:
导入的测试类的一些类或者接口以及框架的目录
package test; import com.alibaba.druid.pool.DruidDataSource; import com.mchange.v2.c3p0.ComboPooledDataSource; import org.junit.Test; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; import javax.sql.DataSource; import java.sql.Connection; import java.sql.SQLException; import java.util.ResourceBundle;
1、用java JDBC知识测试c3p0数据源(在代码里我会有自己的注解,如果有问题希望大家帮我指正一下)
public class DataReSourcesTest {
@Test
// 测试c3p0数据源
public void test1() throws Exception{
// new一个c3p0数据源
ComboPooledDataSource dataSource = new ComboPooledDataSource();
// 这里设置驱动会抛出异常,当然用try与catch环绕也可以,我在这里抛出最大的异常就比较懒。
dataSource.setDriverClass("com.mysql.jdbc.Driver");
// 设置数据源地址,本地3306。
dataSource.setJdbcUrl("jdbc:mysql://localhost:3306/test");
// 设置用户与密码
dataSource.setUser("root");
dataSource.setPassword("123456");
// 获取资源进行输出地址测试
Connection connection = dataSource.getConnection();
System.out.println(connection);
// 使用之后关闭
connection.close();
}
2、用java JDBC测试Druid数据源
@Test // 测试Druid数据源,我比较在意它与c3p0的区别。特别是set跟的属性名,后续在测试spring容器帮我们配置数据源的时候 // 对有不同的要求,需要注意。 public void test2(){ DruidDataSource dataSource = new DruidDataSource(); dataSource.setDriverClassName("com.mysql.jdbc.Driver"); dataSource.setUrl("jdbc:mysql://localhost:3306/test"); dataSource.setUsername("root"); dataSource.setPassword("123456"); // 这里获取资源的语句会抛出异常,我添加try与catch环绕吧,不能太懒。 try { Connection connection = dataSource.getConnection(); System.out.println(connection); connection.close(); } catch (SQLException e) { e.printStackTrace(); } }
3、测试数properties文件读取并创建c3p0数据源
@Test
// 测试数据库properties配置文件的读取
// 说一下为什么要采用读取配置文件的方式来创建与使用数据源呢?个人理解像上述的在java文件中直接
// 设置参数创建的方式在后期由于jvm特性都会变成class字节码文件,再想进行debug以及修改的话返工
// 的可能性比较大,采用配置文件的话,修改就很简单,直接修改配置文件就可以完成,也有一定的解耦作用。
public void test3() throws Exception{
// ResourceBundle方法专门用来对付properties文件的读取,所以不需要跟后缀,直接写文件名就行
ResourceBundle resourceBundle = ResourceBundle.getBundle("jdbc");
String driver = resourceBundle.getString("jdbc.driver");
String url = resourceBundle.getString("jdbc.url");
String username = resourceBundle.getString("jdbc.username");
String password = resourceBundle.getString("jdbc.password");
// 这里是测试一下是否正确
// System.out.println(driver);
// System.out.println(url);
// System.out.println(username);
// System.out.println(password);
// 创建数据源datasource
ComboPooledDataSource dataSource = new ComboPooledDataSource();
// 这里会抛出异常,和上述的两个测试一样采用抛出大异常吧
dataSource.setDriverClass(driver);
dataSource.setJdbcUrl(url);
dataSource.setUser(username);
dataSource.setPassword(password);
// 获取资源connection并测试输出
Connection connection = dataSource.getConnection();
System.out.println(connection);
connection.close();
}
4、测试spring容器为我们配置数据源(有DI注入,这里也展示了两种getBean();犯法的使用)
@Test
// 测试spring配置c3p0数据源,关于sprig配置Druid数据源的代码就不敲了哈哈哈哈
public void test4(){
ApplicationContext app = new ClassPathXmlApplicationContext("DataSource.xml");
ComboPooledDataSource dataSource = (ComboPooledDataSource) app.getBean("dataSource");
DataSource dataSource1 = app.getBean(DataSource.class);
try {
Connection connection1 = dataSource1.getConnection();
System.out.println(connection1);
connection1.close();
Connection connection = dataSource.getConnection();
System.out.println(connection);
connection.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
5、xml文件(有在xml文件中加载properties文件的方法,也是最后spring配置数据源的关键技术)
6、properties文件代码展示(个人感觉也是有作用的,毕竟做的项目都这样子搞)
jdbc.driver = com.mysql.jdbc.Driver jdbc.url = jdbc:mysql://localhost:3306/test jdbc.username = root jdbc.password = 123456
7.pom文件(一些坐标的导入,也是有微弱参考的)
4.0.0 org.example Druid1.0-SNAPSHOT 8 8 org.springframework spring-context5.3.15 mysql mysql-connector-java8.0.25 junit junit4.13.2 test c3p0 c3p00.9.1.2 com.alibaba druid1.0.10 com.alibaba druid1.1.10 test
8、重要知识总结
如何用spring容器配置数据源?怎么在xml文件里加载properties文件?Druid与c3p0的使用区别?依赖注入的步骤配置数据源的步骤千万不要觉得学的简单就不复习,我是菜鸟,水惯了.......



