[英]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中)。
此外,如果Hibernate从头开始创建模式(即ddl-auto属性设置为create或create-drop),则在启动时将在启动时执行类路径根目录中名为import.sql的文件。 这对于演示和测试很有用,如果你小心,但可能不是你想要在生产中的类路径上。 它是一个Hibernate功能(与Spring无关)。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.