繁体   English   中英

H2内存数据库初始化与数据

[英]H2 in-memory database initialization with data

我正在使用H2和Hibernate来动态生成内存数据库以进行单元测试。 我成功地创建了数据库,一切正常。 但我有一个问题,我不知道如何处理。 我需要在执行测试之前将参考数据加载到DB进行测试。 我把这个数据作为SQL插件的文件存储,我需要实时运行一次envirnemnt,但是,因为每次从头开始生成数据库我需要弄清楚如何在运行时插入数据。 数据非常简单,它是国家列表,州名单等。最好的方法是什么?

顺便说一句,一切都在Spring框架下工作。

对于测试,您可以在创建连接时执行init脚本。

http://www.h2database.com/html/features.html#execute_sql_on_connection

从问题标签我看到你正在使用Hibernate。 您可以将名为“import.sql”的文件添加到类路径中(例如,如果您使用的是Maven项目布局,则在src / main / resources中)。

从Spring文档

此外,如果Hibernate从头开始创建模式(即ddl-auto属性设置为create或create-drop),则在启动时将在启动时执行类路径根目录中名为import.sql的文件。 这对于演示和测试很有用,如果你小心,但可能不是你想要在生产中的类路径上。 它是一个Hibernate功能(与Spring无关)。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM