我正在使用 NuGet 包AsyncPoco v1.2,它是官方PetaPoco的异步分支——“为你的 POCO 准备的一个小小的 ORM-ish 东西”。选择的 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": invalid identifier"
这显然是正确的,因为标识符实际上是“name_col”,如 Column 属性值中所述。
当我更改 Poco 对象以使其包含实际的数据库列名称作为其属性名称时,插入工作正常,例如:
public class PocoModel
{
public long ID_COL { get; set; }
public long NAME_COL { get; set; }
}
是否可以使用列属性来识别表列,或者是否有其他解决问题的方法?我希望我遗漏了一些东西,否则我们将不得不放弃这个包,因为我们不能在业务代码中使用这些非常规的属性名称。将表列名称更改为 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 的 Name 属性来明确说明列的名称,但它没有改变任何东西(因为它不应该改变,因为该参数在其他地方被分配给 ColumnAttribute 的 Name 属性,但我想检查以防万一),例如:
[Column(Name = "NAME_COL")]
所有输入表示赞赏。