重置h2中的自动增量

时间:2012-04-08 18:45:20

标签: java playframework h2

我正在测试一个返回json响应但是测试的控制器 第一次失败,因为h2数据库没有重置 自动增量ID。 手动使用夹具或创建对象也存在同样的问题。

@Before
public void setUp() {
    Fixtures.deleteAllModels();
    Fixtures.loadModels("data.yaml");
}

如何解决这个问题?

3 个答案:

答案 0 :(得分:18)

启动您的播放应用,使用此网址启动浏览器(如果您在本地运行播放应用):

http://localhost:9000/@db

输入你的h2 db,然后输入以下命令并运行:

ALTER TABLE <table_name> ALTER COLUMN <column_name> RESTART WITH 1

如果您想以编程方式执行此操作,Fixtures.executeSQL()可能会有用

有关详情,请查看http://www.h2database.com/html/grammar.html#alter_table_alter

答案 1 :(得分:2)

如果您使用的是Spring,我发现此blog post建议使用@DirtiesContext(classMode = DirtiesContext.ClassMode.AFTER_EACH_TEST_METHOD)

这样每个测试都使用一个新的应用程序上下文,从而重置db增量。

答案 2 :(得分:1)

在表上执行SQL脚本:

TRUNCATE TABLE my_table RESTART IDENTITY;
ALTER SEQUENCE my_table_id_seq RESTART WITH 1;

H2的版本应为1.4.200或更高版本。

请参见https://www.h2database.com/html/commands.html