Java Spring詳解如何配置數(shù)據(jù)源注解開(kāi)發(fā)以及整合Junit
Spring數(shù)據(jù)源的配置
數(shù)據(jù)源(連接池)的作用
數(shù)據(jù)源(連接池)是提高程序性能如出現(xiàn)的
事先實(shí)例化數(shù)據(jù)源,初始化部分連接資源
使用連接資源時(shí)從數(shù)據(jù)源中獲取
使用完畢后將連接資源歸還給數(shù)據(jù)源
常見(jiàn)的數(shù)據(jù)源(連接池):DBCP、C3PO、BoneCP、Druid等
數(shù)據(jù)源的開(kāi)發(fā)步驟
1、導(dǎo)入數(shù)據(jù)源的坐標(biāo)和數(shù)據(jù)庫(kù)驅(qū)動(dòng)坐標(biāo)
2、創(chuàng)建數(shù)據(jù)源對(duì)象
3、設(shè)置數(shù)據(jù)源的基本連接數(shù)據(jù)
4、使用數(shù)據(jù)源獲取連接資源和歸還連接資源
手動(dòng)創(chuàng)建數(shù)據(jù)源
1、導(dǎo)入c3p0和druid坐標(biāo),mysql數(shù)據(jù)庫(kù)驅(qū)動(dòng)坐標(biāo)
<dependency> <groupId>c3p0</groupId> <artifactId>c3p0</artifactId> <version>0.9.1.2</version> </dependency> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId> <version>1.1.10</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.32</version> </dependency>
2、創(chuàng)建C3P0連接池
Test public void testC3P0 ( ) throws Exception { //創(chuàng)建數(shù)據(jù)源 ComboPooledDataSource dataSource = new ComboPooledDataSource () ; //設(shè)置數(shù)據(jù)庫(kù)連接參數(shù) dataSource.setDriverClass ("com.mysql.jdbc.Driver" ) ; dataSource.setJdbcUrl ("jdbc:mysql ://localhost:3306/test" ) ; datasource.setUser ("root"); dataSource.setPassword ("root"); //獲得連接對(duì)象 Connection connection = dataSource.getConnection (); system.out.println (connection) ;
創(chuàng)建Druid連接池
@Test public void testDruid ( ) throws Exception { //創(chuàng)建數(shù)據(jù)源 DruidDataSource dataSource = new DruidDatasource () ; //設(shè)置數(shù)據(jù)庫(kù)連接參數(shù) dataSource.setDriverclassName ("com.mysql.jdbc .Driver") ; datasource.setUrl ("jdbc:mysql : //localhost:3306/test") ; datasource.setUsername ("root") ; datasource.setPassword ("root" ) ; //獲得連接對(duì)象 connection connection = dataSource.getConnection ( ) ; System.out.println (connection) ; )
3、提取jdbc.properties配置文件
jdbc .driver=com.mysql.jdbc.Driver jdbc.url=jdbc :mysql://localhost:3306/test jdbc.username=root jdbc.password=root
4、讀取jdbc.properties配置文件創(chuàng)建連接池
@Test //測(cè)試手動(dòng)創(chuàng)建 c3p0 數(shù)據(jù)源(加載properties配置文件) public void test3() throws Exception { //讀取配置文件 ResourceBundle rb = ResourceBundle.getBundle("jdbc"); String driver = rb.getString("jdbc.driver"); String url = rb.getString("jdbc.url"); String username = rb.getString("jdbc.username"); String password = rb.getString("jdbc.password"); //創(chuàng)建數(shù)據(jù)源對(duì)象 設(shè)置連接參數(shù) ComboPooledDataSource dataSource = new ComboPooledDataSource(); dataSource.setDriverClass(driver); dataSource.setJdbcUrl(url); dataSource.setUser(username); dataSource.setPassword(password); Connection connection = dataSource.getConnection(); System.out.println(connection); connection.close(); }
Spring配置數(shù)據(jù)源
可以將DataSource的創(chuàng)建權(quán)交由Spring容器去完成
DataSource有無(wú)參構(gòu)造方法,而Spring默認(rèn)就是通過(guò)無(wú)參構(gòu)造方法實(shí)例化對(duì)象的
DataSource要想使用需要通過(guò)set方法設(shè)置數(shù)據(jù)庫(kù)連接信息,而Spring可以通過(guò)set方法進(jìn)行字符串注入
<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=" root"/> </bean>
測(cè)試從容器當(dāng)中獲取數(shù)據(jù)源
ApplicationContext applicationContext = new ClassPathXmlApplicationContext ( "applicationContext.xml" ) ; DataSource dataSource = ( DataSource) applicationcontext. getBean ( "dataSource" ) ; Connection connection = dataSource.getConnection ( ) ; System.out.println ( connection) ;
抽取jdbc配置文件
applicationContext.xml加載jdbc.properties配置文件獲得連接信息。
首先,需要引入context命名空間和約束路徑:
命名空間: xmIns:context="http://www.springframework.org/schema/context"
約束路徑: 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.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>
Spring容器加載properties文件
<context:property-placeholder location="xx.properties" /> <property name=" " value="${key} " />
Spring注解開(kāi)發(fā)
Spring原始注解
Spring是輕代碼而重配置的框架,配置比較繁重,影響開(kāi)發(fā)效率,所以注解開(kāi)發(fā)是一種趨勢(shì),注解代替xml配置
文件可以簡(jiǎn)化配置,提高開(kāi)發(fā)效率。
Spring原始注解主要是替代<Bean>的配置
注意:
使用注解進(jìn)行開(kāi)發(fā)時(shí),需要在applicationContext.xml中配置組件掃描,作用是指定哪個(gè)包及其子包下的Bean需要進(jìn)行掃描以便識(shí)別使用注解配置的類(lèi)、字段和方法。
<!--注解的組件掃描--> <context:component-scan base-package="com.longdi "></context: component-scan>
使用@Compont或@Repository標(biāo)識(shí)UserDaolmpl需要Spring進(jìn)行實(shí)例化。
/ / @Component ( "userDao") @Repository ("userDao") public class UserDaoImpl implements UserDao { @override public void save ( ) { system.out.println ( "save running . . . ..." ) ; }
使用@Autowired或者@Autowired+@Qulifier或者@Resource進(jìn)行userDao的注入
// @Component ( "userservice ") @service ( "userservice" ) public class UserserviceImpl implements UserService { /*@Autowired CQualifier ( "userDao")*/ @Resource (name= "userDao" ) private UserDao userDao; @override public void save ( ) { userDao.save ( ) ; } )
使用@Value進(jìn)行字符串的注入
@Repository ( "userDao") public class UserDaoImpl implements UserDao { @value("注入普通數(shù)據(jù)") private string str; @value ("${jdbc.driver} ") private string driver; @override public void save () { system.out.println (str) ; system.out.println (driver) ; system.out.println ("save running......") ; )
使用@Scope標(biāo)注Bean的范圍
// @scope ( "prototype ") @Scope ( "singleton" ) public class UserDaoImpl implements UserDao { //此處省略代碼 )
使用@PostConstruct標(biāo)注初始化方法,使用@PreDestroy標(biāo)注銷(xiāo)毀方法
@PostConstruct public void init () { system.out.println ("初始化方法...." ); } @PreDestroy public void destroy () { system.out.println ("銷(xiāo)毀方法....." ); )
Spring新注解
使用上面的注解還不能全部替代xml配置文件,還需要使用注解替代的配置如下:
非自定義的Bean的配置: <bean>
加載properties文件的配置:<context:property-placeholder>
組件掃描的配置: <context:component-scan>
引入其他文件:<import>
@Configuration
@ComponentScan
@lmport
@Configuration @componentScan ("com.longdi" ) @Import ({DataSourceConfiguration.class}) public class SpringConfiguration { )
@PropertySource
@value
@Propertysource ( "classpath:jdbc.properties" ) public class DataSourceConfiguration { @value ("${jdbc.driver}") private string driver ; @value ("${jdbc.ur1 }") private string url; @value ("${jdbc.username}") private string username ; @value ("${jdbc.password]") private string password;
@Bean
Bean (name="dataSource " ) public DataSource getDataSource () throws PropertyvetoException { ComboPooledDataSource dataSource = new ComboPooledDataSource ( ) ; datasource.setDriverclass (driver) ; datasource.setJdbcUrl (url) ; datasource.setUser (username ) ; dataSource.setPassword(password) ; return dataSource;
測(cè)試加載核心配置類(lèi)創(chuàng)建Spring容器
Test public void testAnnoConfiguration ( ) throws Exception { ApplicationContext applicationContext = new AnnotationConfigApplicationContext (SpringConfiguration.class) ; UserService userService = (UserService)applicationContext.getBean ("userService"); userService.save () ; Datasource dataSource = (Datasource)applicationContext.getBean ("dataSource" ) ; Connection connection = dataSource.getConnection() ; System.out.println (connection);
Spring整合Junit
原始Junit測(cè)試Spring的問(wèn)題
在測(cè)試類(lèi)中,每個(gè)測(cè)試方法都有以下兩行代碼:
ApplicationContext ac = new ClassPathxmlApplicationContext ( "bean.xml "); IAccountService as = ac.getBean ("accountservice",IAccountService.class)
這兩行代碼的作用是獲取容器,如果不寫(xiě)的話(huà),直接會(huì)提示空指針異常。所以又不能輕易刪掉。
讓SpringJunit負(fù)責(zé)創(chuàng)建Spring容器,但是需要將配置文件的名稱(chēng)告訴它
將需要進(jìn)行測(cè)試Bean直接在測(cè)試類(lèi)中進(jìn)行注入
Spring集成Junit步驟
1、導(dǎo)入spring集成Junit的坐標(biāo)
2、使用@Runwith注解替換原來(lái)的運(yùn)行期
3、使用@contextConfiguration指定配置文件或配置類(lèi)
4、使用@Autowired注入需要測(cè)試的對(duì)象
5、創(chuàng)建測(cè)試方法進(jìn)行測(cè)試
1、導(dǎo)入spring集成Junit的坐標(biāo)
<dependency> <groupId>org.springframework</groupId> <artifactId>spring-test</artifactId> <version>5.0.5.RELEASE</version> </dependency> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.12</version> <scope>test</scope> </dependency>
2、使用@Runwith注解替換原來(lái)的運(yùn)行期
@RunWith(SpringJUnit4ClassRunner.class) public class SpringJunitTest { }
3、使用@contextConfiguration指定配置文件或配置類(lèi)
@RunWith(SpringJUnit4ClassRunner.class) //加載Spring核心配置文件 //@ContextConfiguration("classpath:applicationContext.xml") //加載Spring核心配置類(lèi) @ContextConfiguration(classes = {SpringCofiguration.class}) public class SpringJunitTest {
4、使用@Autowired注入需要測(cè)試的對(duì)象
@RunWith(SpringJUnit4ClassRunner.class) @ContextConfiguration(classes = {SpringCofiguration.class}) public class SpringJunitTest { @Autowired private UserService userService; }
5、創(chuàng)建測(cè)試方法進(jìn)行測(cè)試
@RunWith(SpringJUnit4ClassRunner.class) @ContextConfiguration(classes = {SpringCofiguration.class}) public class SpringJunitTest { @Autowired private UserService userService; @Test public void test1() throws SQLException { userService.save(); } }
到此這篇關(guān)于Java Spring詳解如何配置數(shù)據(jù)源注解開(kāi)發(fā)以及整合Junit的文章就介紹到這了,更多相關(guān)Java Spring內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java用接口、多態(tài)、繼承、類(lèi)計(jì)算三角形和矩形周長(zhǎng)及面積的方法
這篇文章主要介紹了java用接口、多態(tài)、繼承、類(lèi)計(jì)算三角形和矩形周長(zhǎng)及面積的方法,涉及java面向?qū)ο笾蓄?lèi)、接口、多態(tài)等的使用技巧,需要的朋友可以參考下2015-05-05從底層源碼深入分析Spring的IoC容器的實(shí)現(xiàn)原理
IoC容器負(fù)責(zé)管理對(duì)象的生命周期和依賴(lài)關(guān)系,大大簡(jiǎn)化了應(yīng)用程序的開(kāi)發(fā)和維,我們這篇文章將會(huì)從底層源碼的角度深入分析Spring的IoC容器實(shí)現(xiàn),探索它的工作原理和關(guān)鍵組件,需要的朋友可以參考下2023-07-07PowerJob的QueryConvertUtils工作流程源碼解讀
這篇文章主要為大家介紹了PowerJob的QueryConvertUtils工作流程源碼解讀,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2024-01-01詳解SpringBoot配置文件啟動(dòng)時(shí)動(dòng)態(tài)配置參數(shù)方法
這篇文章主要介紹了詳解SpringBoot配置文件啟動(dòng)時(shí)動(dòng)態(tài)配置參數(shù)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11SpringBoot常用數(shù)據(jù)庫(kù)開(kāi)發(fā)技術(shù)匯總介紹
Spring Boot常用的數(shù)據(jù)庫(kù)開(kāi)發(fā)技術(shù)有JDBCTemplate、JPA和Mybatis,它們分別具有不同的特點(diǎn)和適用場(chǎng)景,可以根據(jù)具體的需求選擇合適的技術(shù)來(lái)進(jìn)行開(kāi)發(fā)2023-04-04SpringMVC詳解如何映射請(qǐng)求數(shù)據(jù)
這篇文章主要給大家介紹了關(guān)于SpringMvc映射請(qǐng)求數(shù)據(jù)的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2022-06-06Java實(shí)現(xiàn)定時(shí)任務(wù)的方法詳解
大家都用過(guò)鬧鐘,鬧鐘可以說(shuō)是一種定時(shí)任務(wù)。那么,在?Java?中,如何實(shí)現(xiàn)這樣的功能呢?即如何實(shí)現(xiàn)定時(shí)任務(wù)呢?本文就來(lái)詳細(xì)和大家聊聊2022-10-10解決mybatis中order by排序無(wú)效問(wèn)題
這篇文章主要介紹了解決mybatis中order by排序無(wú)效問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-12-12