2

我一直在尝试将我的 PostgreSQL 数据库链接到一个 Swift Vapor 项目,所以我创建了到它的路由。我要访问的第一个表是my_databasecalls中的表users。它具有属性user_id(主整数键)和created_on(带有时区的时间戳)。

我已将我的 Vapor 项目链接到,my_database以便我可以创建新模型。但是,如果我想访问预先存在的表怎么办users。以下是我从文档和一些教程中拼凑出来的内容:

我的初始模型:

final class Users: Model {

static let name = "users"

typealias ID = Int
typealias Database = PostgreSQLDatabase

static let idKey: WritableKeyPath<Users, Int?> = \.user_id

var user_id: Int?
var created_on: Date
}

extension Users: Content { }

我的迁移(我认为这只是一个“空白”迁移,只是为了将项目挂到表上?):

struct FirstMigration: PostgreSQLMigration {
static func prepare(on conn: PostgreSQLConnection) -> EventLoopFuture<Void> {
    return conn.future()
}

static func revert(on conn: PostgreSQLConnection) -> EventLoopFuture<Void> {
    return Future<Void>.done(on: conn)
   }
}

还有我的配置:

var migrations = MigrationConfig()
migrations.add(migration: FirstMigration.self, database: .psql)
services.register(migrations)

非常感谢任何指导!

4

1 回答 1

2

您不需要迁移。您要么需要确认Migration模型并将模型添加为迁移,要么设置静态defaultDatabase属性。那么你应该很高兴。

PS - 我想你不想entity告诉name它表名是什么。

于 2020-02-07T10:39:17.540 回答