栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

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

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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容器帮我们配置数据源的时候
//    对有不同的要求,需要注意。
    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
    Druid
    1.0-SNAPSHOT

    
        8
        8
    
    

        
            org.springframework
            spring-context
            5.3.15
        

        
            mysql
            mysql-connector-java
            8.0.25
        

        
            junit
            junit
            4.13.2
            test
        

        
            c3p0
            c3p0
            0.9.1.2
        

        
            com.alibaba
            druid
            1.0.10
        
        
            com.alibaba
            druid
            1.1.10
            test
        
    

8、重要知识总结

如何用spring容器配置数据源?怎么在xml文件里加载properties文件?Druid与c3p0的使用区别?依赖注入的步骤配置数据源的步骤千万不要觉得学的简单就不复习,我是菜鸟,水惯了.......

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/756422.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号