Dapper如何映射到只读属性 Dapper Readonly Property映射

admin 百科 10
Dapper 默认不映射只读属性,但可通过构造函数参数匹配、启用非公共成员访问或自定义 TypeMap 实现映射;推荐使用构造函数方式,要求 SQL 列名与参数名严格一致。

Dapper如何映射到只读属性 Dapper Readonly Property映射-第1张图片-佛山资讯网

Dapper 默认只映射 public set 的属性,遇到只读属性(比如 public string Name { get; }private set)时,不会自动赋值。但可以通过几种方式实现映射,关键是让 Dapper 知道“这个字段要写进去”,即使 setter 不公开。

用构造函数参数匹配字段名

Dapper 支持通过构造函数注入完成只读属性初始化。只要 SQL 查询列名和构造函数参数名完全一致(大小写敏感),Dapper 就会用该参数创建对象。

  • 实体类需定义含参构造函数,参数名与数据库字段/别名严格对应
  • 属性声明为只读(get;)或私有 setter(get; private set;)均可
  • 查询时使用 Query<t>()</t>,Dapper 自动绑定构造参数

示例:

public class Product
{
    public int Id { get; }
    public string Name { get; }
    public decimal Price { get; }
<pre class='brush:php;toolbar:false;'>public Product(int id, string name, decimal price)
{
    Id = id;
    Name = name;
    Price = price;
}

登录后复制

}

SQL 查询必须用别名对齐参数名:SELECT Id, Name, Price FROM Products

启用非公共成员访问(.NET Core/.NET 5+)

Dapper 在较新版本中支持通过配置开启非公共属性写入。需在应用启动时设置:

标签: app c# .net

发布评论 0条评论)

还木有评论哦,快来抢沙发吧~