我正在使用H2和Hibernate来动态生成内存数据库以进行单元测试。 我成功地创建了数据库,一切正常。 但我有一个问题,我不知道如何处理。 我需要在执行测试之前将参考数据加载到DB进行测试。 我把这个数据作为SQL插件的文件存储,我需要实时运行一次envirnemnt,但是,因为每次从头开始生成数据库我需要弄清楚如何在运行时插入数据。 数据非常简单,有国家名单,州名单等。 什么是最好的方法呢?
顺便说一句,一切都在Spring框架下运行。答案 0 :(得分:7)
对于测试,您可以在创建连接时执行init脚本。
http://www.h2database.com/html/features.html#execute_sql_on_connection
答案 1 :(得分:1)
从问题标签中我看到你正在使用Hibernate。您可以将名为“import.sql”的文件添加到类路径中(例如,如果您使用的是Maven项目布局,则在src / main / resources中)。
此外,类路径根目录中名为import.sql的文件将会出现 如果Hibernate从头开始创建架构,则在启动时执行 (即,如果将ddl-auto属性设置为create或create-drop)。 如果你小心,这可以用于演示和测试,但是 可能不是你想要在生产中的类路径上的东西。 这是一个Hibernate功能(与Spring无关)。