DBunit 如何在Spring Boot中使用

发布时间:2021-06-08 16:54:23 作者:Leah
来源:亿速云 阅读:288

这篇文章给大家介绍DBunit 如何在Spring Boot中使用,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

Springboot 添加 DBunit 依赖

// https://mvnrepository.com/artifact/org.dbunit/dbunit
testCompile group: 'org.dbunit', name: 'dbunit', version: '2.5.4'

编写Test.java

import org.dbunit.DBTestCase;
import org.dbunit.DatabaseUnitException;
import org.dbunit.database.DatabaseConnection;
import org.dbunit.database.IDatabaseConnection;
import org.dbunit.database.QueryDataSet;
import org.dbunit.dataset.DataSetException;
import org.dbunit.dataset.IDataSet;
import org.dbunit.dataset.xml.FlatXmlDataSet;
import org.dbunit.dataset.xml.FlatXmlDataSetBuilder;
import org.dbunit.operation.DatabaseOperation;

@RunWith(SpringRunner.class)
@SpringBootTest
public class DBunit extends DBTestCase {

  @Resource
  DataSource dataSource;
  IDatabaseConnection iDatabaseConnection;


  @Override
  protected IDataSet getDataSet() throws Exception {
    return iDatabaseConnection.createDataSet();
  }

  @Before
  public void before() throws Exception{
      iDatabaseConnection = new DatabaseConnection(dataSource.getConnection());
    
  }
}

将数据库数据转换为FlatXml

  @Test
  public void testPartialExport() throws DataSetException, IOException {
    QueryDataSet queryDataSet = new QueryDataSet(iDatabaseConnection);
    queryDataSet.addTable("user", "select * from user");
    FlatXmlDataSet.write(queryDataSet, new FileOutputStream("user.xml"));
  }

执行后,将会得到一个user.xml文件,里面记录了数据库user表的所有数据,看起来大概是这个样子

<?xml version='1.0' encoding='UTF-8'?>
<dataset>
 <user id="1" username="mechanists" password="ABA3FC1EB2997E318E43CA099AE175CA"/>
 <user id="2" username="reporter" password="ABA3FC1EB2997E318E43CA099AE175CA" />
 
</dataset>

关于DBunit 如何在Spring Boot中使用就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

推荐阅读:
  1. 如何在springboot中自定义Starter
  2. 2021的Spring Boot面试题及答案有哪些

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

springboot dbunit

上一篇:怎么在Spring boot中整合Mybatis

下一篇:Class.getMethods()和Class.getDeclaredMethods()方法在java中有什么区别

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》