获取“关系“ schemaversions”不存在错误”

时间:2018-11-21 20:36:59

标签: c# dbup

我正在尝试使用dbup中的示例代码转换为postgres。

下面是代码。

using System;
using System.Linq;
using System.Reflection;
using DbUp;

namespace GeoServerDbManager
{
    //"Host = 1.1.1.1; User Id = postgres; Password = postgres; Database = osmdev; Port = 5432"
    class Program
    {
        static int Main(string[] args)
        {
            var connectionString =
                args.FirstOrDefault()
                ?? "Host = 1.1.1.1; User Id = postgres; Password = postgres; Database = osmdev; Port = 5432";
            EnsureDatabase.For.PostgresqlDatabase(connectionString);
            var upgrader =
                DeployChanges.To
                    .PostgresqlDatabase(connectionString)
                    .WithScriptsEmbeddedInAssembly(Assembly.GetExecutingAssembly())
                    .LogToConsole()
                    .Build();

            var result = upgrader.PerformUpgrade();

            if (!result.Successful)
            {
                Console.ForegroundColor = ConsoleColor.Red;
                Console.WriteLine(result.Error);
                Console.ResetColor();
#if DEBUG
                Console.ReadLine();
#endif
                return -1;
            }

            Console.ForegroundColor = ConsoleColor.Green;
            Console.WriteLine("Success!");
            Console.ResetColor();
            return 0;
        }
    }
}

运行此数据库时不存在。 我不断收到错误消息:

Script block number: 0; Message: 42P01: relation "schemaversions" does not exist
Npgsql.PostgresException (0x80004005): 42P01: relation "schemaversions" does not exist

表确实已创建,schemaversions表也已创建,但是schemaversions表在脚本末尾为空。

1 个答案:

答案 0 :(得分:0)

我知道这是一个古老的问题,但是今天我遇到了同样的问题,由于目前还没有答案,我正在回答以供将来参考:

我发现DbUp试图创建一个“ schemaversions”,但是没有设置默认模式。这将导致错误:

  

获取“关系“ schemaversions”不存在错误”

设置默认架构可以解决我的问题:

builder.JournalToPostgresqlTable("SCHEMA_NAME", "schemaversions")