Spring配置數據源的三種方式(小結)
一、前言
今天學習瞭用spring配置Druid數據源的三種方式,整理瞭學習筆記,希望大傢喜歡!
二、數據源的作用
- 數據源(連接池)是提高程序性能如出現的
- 事先實例化數據源,初始化部分連接資源
- 使用連接資源時從數據源中獲取
- 使用完畢後將連接資源歸還給數據源
常見的數據源:DBCP
、C3P0
、BoneCP
、Druid
等等,本文主要以Druid數據源為案例實現Spring對數據源的開發應用
三、開發數據源的方式
方式1:手動輸入
先創建一個maven工程,引入依賴,為瞭方便起見,我還導入瞭Junit的依賴,此外,還有mysql的驅動依賴、Druid數據源的依賴和spring依賴
<dependencies> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.12</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.27</version> </dependency> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId> <version>1.1.22</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>5.3.14</version> </dependency> </dependencies>
直接編寫一個測試類,開始測試
@Test public void test1() throws SQLException { //創建數據源對象 DruidDataSource dataSource = new DruidDataSource(); //設置數據源的基本連接數據 dataSource.setDriverClassName("com.mysql.cj.jdbc.Driver"); dataSource.setUrl("jdbc:mysql://localhost:3306/test"); dataSource.setUsername("root"); dataSource.setPassword("0315"); //使用數據源獲取連接資源 Connection connection = dataSource.getConnection(); //打印連接資源的信息 System.out.println(connection); //關閉連接資源 connection.close(); }
分析: setDriverClassName()
填入的是連接驅動類Driver的包路徑、setUrl()
設置要連接的數據庫的地址、setUsername()
自己的數據庫用戶名、setPassword()
數據庫密碼
運行結果:
方式2:Properties配置文件
在resources
下建一個名為jdbc.properties
的文件,填入數據源的基本連接數據
jdbc.driver=com.mysql.cj.jdbc.Driver jdbc.url=jdbc:mysql://localhost:3306/test jdbc.username=root jdbc.password=0315
編寫一個測試類,開始測試
@Test public void test2() throws SQLException { //ResourceBundle這個類專門用來讀取properties類型的文件 ResourceBundle bundle = ResourceBundle.getBundle("jdbc"); //設置數據源的基本連接數據 String driver = bundle.getString("jdbc.driver"); String url = bundle.getString("jdbc.url"); String username = bundle.getString("jdbc.username"); String password = bundle.getString("jdbc.password"); DruidDataSource dataSource = new DruidDataSource(); dataSource.setDriverClassName(driver); dataSource.setUrl(url); dataSource.setUsername(username); dataSource.setPassword(password); DruidPooledConnection connection = dataSource.getConnection(); System.out.println(connection); connection.close(); }
這種方式就比方式一好很多瞭,如果我們使用的數據庫發生瞭改變,就隻需要在Properties文件中進行修改,從而不需要從代碼中修改,提高瞭開發的效率
方式3:Spring配置數據源
繼續使用前面的jdbc.properties
文件,我們可以將數據源的創建權交由Spring容器去完成,編寫一個名為applicationContext.xml
的spring配置文件,把數據源放入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" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd"> <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource"> <property name="driverClassName" value="com.mysql.cj.jdbc.Driver"></property> <property name="url" value="jdbc:mysql://localhost:3306/test"></property> <property name="username" value="root"></property> <property name="password" value="0315"></property> </bean> </beans>
通過這種spring配置文件的方式,我們就可以獲取瞭數據源,接下來寫一個代碼用來測試
@Test public void test3() throws SQLException { ApplicationContext applicationContext = new ClassPathXmlApplicationContext("applicationContext.xml"); DruidDataSource dataSource = applicationContext.getBean(DruidDataSource.class); DruidPooledConnection connection = dataSource.getConnection(); //打印連接信息 System.out.println(connection); connection.close(); }
運行結果:
不知道小夥伴們看到value的屬性值那麼長,有沒有感覺到一絲絲的不舒服,反正我是有。那麼有沒有一種方法能夠將配置更加的清晰明瞭呢?答案是:有!那麼該如何做呢?
首先要做的是,把jdbc.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"> <context:property-placeholder location="classpath:jdbc.properties"/> <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource"> <property name="driverClassName" value="${jdbc.driver}"></property> <property name="url" value="${jdbc.url}"></property> <property name="username" value="${jdbc.username}"></property> <property name="password" value="${jdbc.password}"></property> </bean> </beans>
分析: 首先要在頭文件中引入下圖所示的名稱空間,最後value的屬性值用${key}
的方式獲取到jdbc.properties
的value值,這樣的運行結果也是跟上面一樣
四、總結
我們最需要掌握的就是最後一種方法,一定要學會這種配置方式!
到此這篇關於Spring配置數據源的三種方式(小結)的文章就介紹到這瞭,更多相關Spring配置數據源內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- 一文詳解Spring加載properties文件的方式
- Spring IOC容器基於XML外部屬性文件的Bean管理
- 帶你快速入門掌握Spring的那些註解使用
- 通過IEAD+Maven快速搭建SSM項目的過程(Spring + Spring MVC + Mybatis)
- Spring整合SpringMVC + Mybatis基礎框架的配置文件詳解