加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

只在内存中运行PostgreSQL

发布时间:2020-12-13 16:50:03 所属栏目:百科 来源:网络整理
导读:我想运行一个小的PostgreSQL数据库,在内存中运行,对于我写的每个单元测试。例如: @Beforevoid setUp() { String port = runPostgresOnRandomPort(); connectTo("postgres://localhost:"+port+"/in_memory_db"); // ...} 理想情况下,我将有一个postgres可
我想运行一个小的PostgreSQL数据库,在内存中运行,对于我写的每个单元测试。例如:
@Before
void setUp() {
    String port = runPostgresOnRandomPort();
    connectTo("postgres://localhost:"+port+"/in_memory_db");
    // ...
}

理想情况下,我将有一个postgres可执行文件检入版本控制,单元测试将使用。

类似于HSQL,但是对于postgres。我怎样才能做到这一点?

我能得到这样的Postgres版本吗?我如何指示它不使用磁盘?

这是不可能与Postgres。它不提供像HSQLDB或MySQL这样的进程内/内存引擎。

如果你想创建一个自包含的环境,你可以把Postgres二进制SVN(但它不仅仅是一个可执行文件)。

您需要运行initdb来设置测试数据库,然后才能对此进行任何操作。这可以从批处理文件或通过使用Runtime.exec()。但是请注意,initdb不是快速的。你绝对不想为每个测试运行它。你可能会逃避在你的测试套件之前运行这个。

但是,虽然这可以做到,我建议有一个专门的Postgres安装,您只需重新创建测试数据库,然后运行测试。

您可以使用模板数据库重新创建测试数据库,这使得创建它相当快(比每个测试运行运行initdb快得多)

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读