目前我正在使用 .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
在属性方面做得很好,但显然不是。
有谁知道如何解决这个问题,除了将模型属性重命名为小写?
到目前为止谢谢。