spring框架学习 java JDBC相关与spring配置数据源

上次的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容器帮我们配置数据源的时候
//    对<prototype name="set后属性名头字母小写形式"/>有不同的要求,需要注意。
    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配置数据源的关键技术)

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
                           http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">
<!--这个是要想在xml文件里读取到properties文件的内容就需要加上这样的命名空间
    xmlns:context="http://www.springframework.org/schema/context"
    http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd-->
<!--
    加载外部的properties文件,读取文件中变量的值去给prototype赋值
   <context:property-placeholder location="jdbc.properties" />
   可以发现现在的prototype的value值是直接读取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>-->
<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="123456"/>
</bean>

</beans>

6、properties文件代码展示(个人感觉也是有作用的,毕竟做的项目都这样子搞)

jdbc.driver = com.mysql.jdbc.Driver
jdbc.url = jdbc:mysql://localhost:3306/test
jdbc.username = root
jdbc.password = 123456

7.pom文件(一些坐标的导入,也是有微弱参考的)

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>org.example</groupId>
    <artifactId>Druid</artifactId>
    <version>1.0-SNAPSHOT</version>

    <properties>
        <maven.compiler.source>8</maven.compiler.source>
        <maven.compiler.target>8</maven.compiler.target>
    </properties>
    <dependencies>
<!--导入spring框架的坐标,测试spring配置数据源-->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>5.3.15</version>
        </dependency>
<!--因为这次实验需要测试数据源,所以数据库驱动mysql需要导入坐标-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.25</version>
        </dependency>
<!--这里需要做测试,当然要导入Junit单元测试框架-->
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.13.2</version>
            <scope>test</scope>
        </dependency>
<!--测试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.0.10</version>
        </dependency>
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid</artifactId>
            <version>1.1.10</version>
            <scope>test</scope>
        </dependency>
    </dependencies>

</project>

8、重要知识总结

  • 如何用spring容器配置数据源?怎么在xml文件里加载properties文件?
  • Druid与c3p0的使用区别?
  • 依赖注入的步骤
  • 配置数据源的步骤
  • 千万不要觉得学的简单就不复习,我是菜鸟,水惯了.......
  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ForestSpringH

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值