Java Spring详解如何配置数据源注解开发以及整合Junit

作者:龍弟-idea 时间:2021-10-31 11:03:25 

Spring数据源的配置

数据源(连接池)的作用

数据源(连接池)是提高程序性能如出现的
事先实例化数据源,初始化部分连接资源
使用连接资源时从数据源中获取
使用完毕后将连接资源归还给数据源

常见的数据源(连接池):DBCP、C3PO、BoneCP、Druid等

数据源的开发步骤

1、导入数据源的坐标和数据库驱动坐标
2、创建数据源对象
3、设置数据源的基本连接数据
4、使用数据源获取连接资源和归还连接资源

手动创建数据源

1、导入c3p0和druid坐标,mysql数据库驱动坐标


   <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、创建C3P0连接池


Test
public void testC3P0 ( ) throws Exception {
//创建数据源
ComboPooledDataSource dataSource = new ComboPooledDataSource () ;
//设置数据库连接参数
dataSource.setDriverClass ("com.mysql.jdbc.Driver" ) ;
dataSource.setJdbcUrl ("jdbc:mysql ://localhost:3306/test" ) ;
datasource.setUser ("root");
dataSource.setPassword ("root");
//获得连接对象
Connection connection = dataSource.getConnection ();
system.out.println (connection) ;

创建Druid连接池


@Test
public void testDruid ( ) throws Exception {
//创建数据源
DruidDataSource dataSource = new DruidDatasource () ;
//设置数据库连接参数
dataSource.setDriverclassName ("com.mysql.jdbc .Driver") ;
datasource.setUrl ("jdbc:mysql : //localhost:3306/test") ;
datasource.setUsername ("root") ;
datasource.setPassword ("root" ) ;
//获得连接对象
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配置文件创建连接池


   @Test
   //测试手动创建 c3p0 数据源(加载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");
       //创建数据源对象  设置连接参数
       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配置数据源

可以将DataSource的创建权交由Spring容器去完成
DataSource有无参构造方法,而Spring默认就是通过无参构造方法实例化对象的
DataSource要想使用需要通过set方法设置数据库连接信息,而Spring可以通过set方法进行字符串注入


<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>

测试从容器当中获取数据源


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注解开发

Spring原始注解

Spring是轻代码而重配置的框架,配置比较繁重,影响开发效率,所以注解开发是一种趋势,注解代替xml配置
文件可以简化配置,提高开发效率。

Spring原始注解主要是替代<Bean>的配置

Java Spring详解如何配置数据源注解开发以及整合Junit

注意:
使用注解进行开发时,需要在applicationContext.xml中配置组件扫描,作用是指定哪个包及其子包下的Bean需要进行扫描以便识别使用注解配置的类、字段和方法。


<!--注解的组件扫描-->
<context:component-scan base-package="com.longdi "></context: component-scan>

使用@Compont或@Repository标识UserDaolmpl需要Spring进行实例化。


/ / @Component ( "userDao")
@Repository ("userDao")
public class UserDaoImpl implements UserDao {
@override
public void save ( ) {
system.out.println ( "save running . . . ..." ) ;
}

使用@Autowired或者@Autowired+@Qulifier或者@Resource进行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进行字符串的注入


@Repository ( "userDao")
public class UserDaoImpl implements UserDao {
@value("注入普通数据")
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标注Bean的范围


//  @scope ( "prototype ")
   @Scope ( "singleton" )
public class UserDaoImpl implements UserDao {
//此处省略代码
)

使用@PostConstruct标注初始化方法,使用@PreDestroy标注销毁方法


@PostConstruct
public void init () {
system.out.println ("初始化方法...." );
}
@PreDestroy
public void destroy () {
system.out.println ("销毁方法....." );
)

Spring新注解

使用上面的注解还不能全部替代xml配置文件,还需要使用注解替代的配置如下:
非自定义的Bean的配置: <bean>
加载properties文件的配置:<context:property-placeholder>
组件扫描的配置: <context:component-scan>
引入其他文件:<import>

Java Spring详解如何配置数据源注解开发以及整合Junit

@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;

测试加载核心配置类创建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测试Spring的问题
在测试类中,每个测试方法都有以下两行代码:


ApplicationContext ac = new ClassPathxmlApplicationContext ( "bean.xml ");
IAccountService as = ac.getBean ("accountservice",IAccountService.class)

这两行代码的作用是获取容器,如果不写的话,直接会提示空指针异常。所以又不能轻易删掉。
让SpringJunit负责创建Spring容器,但是需要将配置文件的名称告诉它

将需要进行测试Bean直接在测试类中进行注入

Spring集成Junit步骤

1、导入spring集成Junit的坐标
2、使用@Runwith注解替换原来的运行期
3、使用@contextConfiguration指定配置文件或配置类
4、使用@Autowired注入需要测试的对象
5、创建测试方法进行测试

1、导入spring集成Junit的坐标



<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注解替换原来的运行期


@RunWith(SpringJUnit4ClassRunner.class)
public class SpringJunitTest {
}

3、使用@contextConfiguration指定配置文件或配置类


@RunWith(SpringJUnit4ClassRunner.class)
//加载Spring核心配置文件
//@ContextConfiguration("classpath:applicationContext.xml")
//加载Spring核心配置类
@ContextConfiguration(classes = {SpringCofiguration.class})
public class SpringJunitTest {

4、使用@Autowired注入需要测试的对象


@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(classes = {SpringCofiguration.class})
public class SpringJunitTest {

@Autowired
   private UserService userService;
}

5、创建测试方法进行测试


@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(classes = {SpringCofiguration.class})
public class SpringJunitTest {

@Autowired
   private UserService userService;

@Test
   public void test1() throws SQLException {
       userService.save();
   }

}

来源:https://blog.csdn.net/weixin_48838340/article/details/120769535

标签:Java,Spring,配置数据源,整合Junit
0
投稿

猜你喜欢

  • Android开发实现图片的上传下载

    2022-10-21 03:41:10
  • UnityWebRequest前后端交互实现过程解析

    2021-09-07 01:24:42
  • Java Volatile 变量详解及使用方法

    2023-03-13 13:27:10
  • 解决Eclipse创建android项目无法正常预览布局文件问题的方法

    2023-07-31 09:51:12
  • Android Flutter实现弹幕效果

    2022-07-17 16:15:17
  • 如何在Android studio 中使用单例模式

    2023-03-17 21:00:38
  • C#实现winform中RichTextBox在指定光标位置插入图片的方法

    2022-04-04 01:50:16
  • Java spring的三种注入方式详解流程

    2021-07-02 12:25:47
  • utf8编码检测方法分享

    2023-05-18 12:34:27
  • Java线程安全中的原子性浅析

    2021-09-06 16:08:13
  • Springboot动态切换数据源的具体实现与原理分析

    2022-11-24 13:45:26
  • Java集合遍历实现方法及泛型通配

    2022-02-26 13:55:54
  • Spring Boot如何使用Spring Security进行安全控制

    2022-03-26 03:59:41
  • Android 通过onDraw实现在View中绘图操作的示例

    2023-07-14 02:15:38
  • Java中通过Class类获取Class对象的方法详解

    2021-11-09 17:12:57
  • RocketMQ NameServer 核心源码解析

    2022-05-08 09:35:41
  • 一文梳理Java 8后的新功能

    2023-07-13 07:41:43
  • Android使用DrawerLayout实现仿QQ双向侧滑菜单

    2023-07-18 23:48:24
  • Java编程Nashorn实例代码

    2022-07-30 05:28:21
  • C#实现打印与打印预览功能的思路及代码

    2021-09-17 02:51:06
  • asp之家 软件编程 m.aspxhome.com