gpt4 book ai didi

junit - 在表上打开 IDENTITY_INSERT 以使用 DB 单元加载它

转载 作者:行者123 更新时间:2023-12-04 17:28:10 25 4
gpt4 key购买 nike

我尝试使用 DB 单元加载一个具有标识列的表。我希望能够自己设置 id 值(我不希望数据库为我生成它)。

这是我的表的最小定义

create table X (
id numeric(10,0) IDENTITY PRIMARY KEY NOT NULL
)

要在 X 中插入一行,我执行以下 SQL
set INDENTITY_INSERT X ON
insert into X(id) VALUES(666)

没问题。但是当我尝试使用以下数据库单元 XML 数据集 (RS_7_10_minimal_ini.xml) 加载此表时
<dataset>
<X id="666"/>
</dataset>

使用以下最小的 JUnit (DBTestCase) 测试用例:
package lms.lp.functionnal_config;

import java.io.FileInputStream;
import org.dbunit.DBTestCase;
import org.dbunit.PropertiesBasedJdbcDatabaseTester;
import org.dbunit.dataset.IDataSet;
import org.dbunit.dataset.xml.FlatXmlDataSetBuilder;
import lms.DBUnitConfig;
import org.junit.Test;

public class SampleTest extends DBTestCase

{

public SampleTest(String name)

{
super( name );
System.setProperty( PropertiesBasedJdbcDatabaseTester.DBUNIT_DRIVER_CLASS, DBUnitConfig.DBUNIT_DRIVER_CLASS );
System.setProperty( PropertiesBasedJdbcDatabaseTester.DBUNIT_CONNECTION_URL, DBUnitConfig.DBUNIT_CONNECTION_URL );
System.setProperty( PropertiesBasedJdbcDatabaseTester.DBUNIT_USERNAME, DBUnitConfig.DBUNIT_USERNAME );
System.setProperty( PropertiesBasedJdbcDatabaseTester.DBUNIT_PASSWORD, DBUnitConfig.DBUNIT_PASSWORD );

}

protected IDataSet getDataSet() throws Exception

{
return new FlatXmlDataSetBuilder().build(new FileInputStream("src/test/resources/RS_7_10_minimal_ini.xml"));
}


@Test
public void testXXX() {
// ...
}
}

它失败,但出现以下异常
com.sybase.jdbc3.jdbc.SybSQLException: Explicit value specified for identity field in table 'X' when 'SET IDENTITY_INSERT' is OFF.

在插入指定了标识列值的行之前,DB 单元似乎没有打开标识。

我已经尝试在从 JdbcDataBaseTester 检索到的连接上执行自己,但没有运气。可能是一个新连接或与用于将数据推送到 de DB 的连接不同。

任何的想法?

非常感谢大家的帮助!

Octave

最佳答案

是的,实际上在 DBUnit FAQ 中找到了解决方案

Can I use DbUnit with IDENTITY or auto-increment columns?

Many RDBMSes allow IDENTITY and auto-increment columns to be implicitly overwritten with client values. DbUnit can be used with these RDBMS natively. Some databases, like MS SQL Server and Sybase, need to explicitly activate client values writing. The way to activate this feature is vendor-specific. DbUnit provides this functionality for MS SQL Server with the InsertIdentityOperation class.



虽然它是为 MS SQL Server 编写的,但也适用于 Sybase。所以我将我的数据集推送到数据库
    new InsertIndentityOperation(DatabaseOperation.CLEAN_INSERT).execute(connection,initialDataSet); 

等等。

感谢您的回答 rawheiser。

关于junit - 在表上打开 IDENTITY_INSERT 以使用 DB 单元加载它,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4205644/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com