JAVA数据源开发到spring配置

9 篇文章 0 订阅

这边是学习JAVA的一些学习笔记。勿喷!!!

1.创建一个测试类  DataSourceTest.java   

package com.itheima.test.dao;

2.pom.xml加入依赖

    <dependencies>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.22</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>5.0.9.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid</artifactId>
            <version>1.0.9</version>
        </dependency>
        <dependency>
            <groupId>c3p0</groupId>
            <artifactId>c3p0</artifactId>
            <version>0.9.1.2</version>
        </dependency>

    </dependencies>

3. 先测试c3p0的连接

    /*
    c3p0 直接读取数据库
     */
    @Test
    public void test_c3p0() throws PropertyVetoException, SQLException {
        ComboPooledDataSource dataSources = new ComboPooledDataSource();
        dataSources.setDriverClass("com.mysql.cj.jdbc.Driver");
        nect=true&characterEncoding=utf-8
        dataSources.setJdbcUrl("jdbc:mysql://localhost:3306/mysql?useSSL=false&useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai&zeroDateTimeBehavior=convertToNull&autoReconnect=true");
        dataSources.setUser("root");
        dataSources.setPassword("123456");
        Connection connection = dataSources.getConnection();
        System.out.println(connection + "-=======--11111");
        connection.close();
    }

这里要注意  serverTimezone=Asia/Shanghai  这个一定要写,不然得报错

打印结果  com.mchange.v2.c3p0.impl.NewProxyConnection@4909b8da-=======--11111  表示成功

4. 测试一下druid的连接

    /*
    druid 直接连接数据库
     */
    @Test
    public void test_druid() throws SQLException {
        DruidDataSource dataSource = new DruidDataSource();
        dataSource.setDriverClassName("com.mysql.cj.jdbc.Driver");
        dataSource.setUrl("jdbc:mysql://localhost:3306/mysql?useSSL=false&useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai&zeroDateTimeBehavior=convertToNull&autoReconnect=true");
        dataSource.setUsername("root");
        dataSource.setPassword("123456");
        DruidPooledConnection connection = dataSource.getConnection();
        System.out.println(connection + "22222");
        connection.close();
    }

5. 读取配置文件中的属性来配置

    5.1 先在test目录下创建 resources目录,并右键 标记目录为  测试资源根

    5.2  在资源目录下创建 jdbc.properties 这个可以自定义名字

    5.3  里面配置一下名称    

jdbc.driver=com.mysql.cj.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/mysql?useSSL=false&useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai&zeroDateTimeBehavior=convertToNull&autoReconnect=true
jdbc.username=root
jdbc.password=123456

    5.4 编写代码,这边读取配置文件有两种方式。 ResourceBundle 比较简单

/*
    读取配置文件 创建连接
     */
    @Test
    public void test_c3p0_prop() throws IOException, PropertyVetoException, SQLException {
        //读取配置文件方式一
//        Properties prop = new Properties();
//        InputStream resource = ClassLoader.getSystemResourceAsStream("jdbc.properties");
//        prop.load(resource);
//        String driver = prop.getProperty("jdbc.driver");

        ResourceBundle rb = ResourceBundle.getBundle("jdbc");
        String driver = rb.getString("jdbc.driver");
        String url = rb.getString("jdbc.url");
        String username = rb.getString("jdbc.username");
        String pwd = rb.getString("jdbc.password");
        ComboPooledDataSource dataSource = new ComboPooledDataSource();
        dataSource.setDriverClass(driver);
        dataSource.setJdbcUrl(url);
        dataSource.setUser(username);
        dataSource.setPassword(pwd);
        Connection connection = dataSource.getConnection();

        System.out.println(connection);
        //resource.close();
    }

6. 利用spring注入来实现

    6.1 在test的resources下创建spring配置 applicationContext.xml

          

    <bean id="jdbc_c3p0" class="com.mchange.v2.c3p0.ComboPooledDataSource">
        <property name="driverClass" value="com.mysql.cj.jdbc.Driver"></property>
        <property name="jdbcUrl" value="jdbc:mysql://localhost:3306/mysql?useSSL=false&amp;useUnicode=true&amp;characterEncoding=UTF-8&amp;serverTimezone=Asia/Shanghai&amp;zeroDateTimeBehavior=convertToNull&amp;autoReconnect=true"></property>
        <property name="user" value="root"></property>
        <property name="password" value="123456"></property>
    </bean>

   6.2 代码调用

       这边注释的也是可以用。DataSource dataSource = context.getBean(DataSource.class);   这个和 ComboPooledDataSource bean = context.getBean(ComboPooledDataSource.class); 在 配置文件中如果有两个,就会报错,保险起见,指定名称 jdbc_c3p0

    @Test
    public void testc3p0_ioc() throws SQLException {
        ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");
        //ComboPooledDataSource bean = context.getBean(ComboPooledDataSource.class);
        //DataSource dataSource = context.getBean(DataSource.class);
        DataSource dataSource = context.getBean("jdbc_c3p0", DataSource.class);
        Connection connection = dataSource.getConnection();
        System.out.println(connection+"9999");
        connection.close();
    }

7. 可以将数据库连接的信息,统一放到对应的配置文件去,例如 c3p0.properties, drid.properties? 然后注入配置取这里的值。

    在 applicationContext.xml 里配置如下:

    <context:property-placeholder location="jdbc.properties"></context:property-placeholder>
    <bean id="jdbc_c3p0_02" class="com.mchange.v2.c3p0.ComboPooledDataSource">
        <property name="driverClass" value="${jdbc.driver}"></property>
        <property name="jdbcUrl" value="${jdbc.url}"></property>
        <property name="user" value="${jdbc.username}"></property>
        <property name="password" value="${jdbc.password}"></property>
    </bean>

这边 context需要头部指定一下

xmlns:context="http://www.springframework.org/schema/context"

在 xsi:schemaLocation中加入以下这个,以空格分隔。 

http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd

同样程序不变

    @Test
    public void testc3p0_ioc02() throws SQLException {
        ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");
        DataSource dataSource = context.getBean("jdbc_c3p0_02", DataSource.class);
        Connection connection = dataSource.getConnection();
        System.out.println(connection+"8888");
        connection.close();
    }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值