无法使用 Column 属性使用 AsyncPoco 将属性关联到列名称

Unable to use the Column attribute to associate properties to the column names using AsyncPoco

我正在使用 NuGet 包 AsyncPoco v1.2, an asynchronous fork of the Official PetaPoco - "A tiny ORM-ish thing for your POCO's"。选择的 DBRM 是 Oracle,但这无关紧要。

到目前为止,经典的 PetaPoco 包一直运行得很好,但我的问题是 AsyncPoco 包没有使用 Column 属性的值,而是完全忽略它并简单地使用 属性 名称作为直接列标识符。

示例:

我创造了 Poco

[PrimaryKey("ID_COL", SequenceName = "SCHEMA.SCHEMA_TABLE_SEQ")]
[TableName("SCHEMA.SCHEMA_TABLE")]
public class PocoModel
{
    [Column("ID_COL")]
    public long Id { get; set; }

    [Column("NAME_COL")]
    public string Name { get; set; }
 }

我为所需的属性赋值,然后尝试执行 InsertAsync

public async Task InsertPoco(PocoModel model, DbConnection conn)
{
    var taskCompletionSource = new TaskCompletionSource<bool>();
    using (var database = new AsyncPoco.Database(conn))
    {
        await database.InsertAsync(model);
        taskCompletionSource.TrySetResult(true);
    }
    await taskCompletionSource.Task;
}

但是我在尝试 InsertAsync 时收到以下错误:"Oracle.ManagedDataAccess.Client.OracleException: ORA-00904: "NAME": 无效标识符"

这显然是正确的,因为标识符实际上是 "name_col",如 Column 属性值中所述。

当我更改 Poco 对象使其包含实际的数据库列名称作为其属性名称时,插入工作正常,例如:

public class PocoModel
{
    public long ID_COL { get; set; }

    public long NAME_COL { get; set; }
 }

是否可以使用列属性来识别 table 列,或者是否有其他解决问题的方法?我希望我遗漏了一些东西,否则我们将不得不放弃这个包,因为我们不能在业务代码中使用这种非常规的 属性 名称。将 table 列名称更改为 pascal/camel-case 不是一个选项,因为它违反了我使用的标准。

编辑:我查看了包的源代码,我相信名称转换可能正在发生(/AsyncPoco/Core/ColumnInfo.cs),它看起来很确实很奇怪,它没有采用 ColumnAttribute,即使它应该是,这里是代码:

// Read attribute
if (ColAttrs.Length > 0)
{
    var colattr = (ColumnAttribute)ColAttrs[0];
    ci.ColumnName = colattr.Name==null ? pi.Name : colattr.Name;
    ci.ForceToUtc = colattr.ForceToUtc;
    if ((colattr as ResultColumnAttribute) != null)
        ci.ResultColumn = true;
    if ((colattr as ComputedColumnAttribute) != null)
        ci.ComputedColumn = true;
}

我试图通过使用 ColumnAttribute 的名称 属性 来具体说明列的名称,但它没有改变任何东西(因为它不应该,因为参数被分配给了名称属性 的 ColumnAttribute,其他地方,但我想检查以防万一),例如:

[Column(Name = "NAME_COL")]

感谢所有意见。

我以前没有使用过这个特定的库,但我快速浏览了 github 上的源代码并找到了 this ColumnAttribute。您是否尝试过使用它而不是 .NET?

感谢@David 的提示,我得以解决问题。虽然我从未使用过 .NET ColumnAttribute 属性(我也没有想过),但我用错了。

问题是我仍然引用了 PetaPoco 命名空间,因此引用了 PetaPoco ColumnAttribute,而不是使用 AsyncPoco ColumnAttribute。这显然行不通。

删除对 PetaPoco 命名空间的引用就可以了,允许我使用正确的 ColumnAttribute。