0

目前我正在使用 .NET Core 和 PostgreSQL 做一个小项目。对于我的数据访问,我想使用Dapper.Contrib. 现在,我面临以下问题:

下面的代码片段显示了CREATE_DATABASE.sql

CREATE EXTENSION IF NOT EXISTS "uuid-ossp";

CREATE TABLE posts (
    id UUID DEFAULT uuid_generate_v4 (),
    created BIGINT,
    value VARCHAR NOT NULL,
    PRIMARY KEY (Id)
);

以下是我在 .NET Core 中的模型类

[Table("posts")]
public class Post
{
    [Column("id")]
    public Guid Id { get; set; }

    [Column("created")]
    public long Created { get; set; }

    [Column("value")]
    public string Value { get; set; }
}

insert 方法看起来像这样(它在基类中。在这种情况下,T 是 Post 的类型):

public void Insert(T entity)
{
    _connection.Insert(entity);
}

尝试插入Post对象时,遇到以下错误:

Ein Ausnahmefehler des Typs "Npgsql.PostgresException" ist in System.Private.CoreLib.dll aufgetreten.: '42703: column "Created" of relation "posts" does not exist

设置为时NpgsqlLogManager.Provider会记录new ConsoleLoggingProvider(NpgsqlLogLevel.Trace, true, true);以下INSERT语句:

DEBUG [14313] Executing statement(s):
        insert into posts ("Created", "Value") values ($1, $2) RETURNING Id

那么,问题出在哪里呢?我认为Dapper.Contrib在属性方面做得很好,但显然不是。

有谁知道如何解决这个问题,除了将模型属性重命名为小写?

到目前为止谢谢。

4

2 回答 2

0

使用 Dapper.Contrib,可以映射表名,但显然无法映射名。此功能计划用于 2.x 版本。2.x版本发布;但问题仍然存在。查看发行说明,尚未添加功能。

请参阅答案以了解 Dapper 支持列名映射的其他查询生成器。

于 2021-11-09T07:37:29.563 回答
0

似乎 Dapper.Contrib 不允许指定 Column 属性(但它确实允许指定Table 属性)。在这种情况下,票是开放的。但它确实支持属性映射器的自定义列。

有关如何实现此映射的更多详细信息,请参阅这篇文章。

于 2021-11-07T09:19:18.510 回答