1

我在使用Dapper.FluentMap.Dommel.Mapping. 当我记录映射时,系统识别出名称为 ID 的属性已存在并引发异常。但是映射的 Id 属于另一个对象。我怎么解决这个问题?

BaseEntity.cs

public abstract class BaseEntity
{
    public virtual long Id { get; set; }
}

系统文件

public class Sistema : BaseEntity
{        
    public override long Id { get; set; }
    public string Nome { get; set; }
}

Arquivo.cs

public class Arquivo : BaseEntity
{
    public override long Id { get; set; }
    public Sistema Sistema { get; set; }
    public Banco Banco { get; set; }
    public List<Error> Erros { get; set; }
    public string FullPath { get; set; }
    public DateTime DtProcessamento { get; set; }
    public int QtRegistros { get; set; }
    public Decimal VlTotal { get; set; }
    public int Sequencial { get; set; }
    public bool isValid { get; set; }
    public TipoComunicacao tipoComunicacao { get; set; }
}

ArquivoMap.cs

public class ArquivoMap : DommelEntityMap<Entities.Arquivo>
{
    public ArquivoMap()
    {
        ToTable("Arquivo");

        Map(a => a.Id).ToColumn("arqu_id").IsKey();

        this.Map(a => a.Sistema.Id).ToColumn("sist_id"); //<-- Problm (1)
        this.Map(a => a.Banco.Id).ToColumn("banc_id");
        //this.Map(a => a.Erros).ToColumn("erro_id"); // 
        this.Map(a => a.FullPath).ToColumn("arqu_nm_fullPath");
        this.Map(a => a.DtProcessamento).ToColumn("arqu_dt_processamento");
        this.Map(a => a.QtRegistros).ToColumn("arqu_qt_registros");
        this.Map(a => a.VlTotal).ToColumn("arqu_vl_total");
        this.Map(a => a.Sequencial).ToColumn("arqu_id_sequencial");
        this.Map(a => a.isValid).ToColumn("arqu_bt_valid");
        this.Map(a => a.tipoComunicacao).ToColumn("arqu_cd_comunicacao");
    }
}

RegisterMappings.cs

public static void Register()
{
    FluentMapper.Initialize(config =>
    {
        config.AddMap(new ArquivoMap()); //<-- Call to map
        config.AddMap(new BancoMap());
        config.AddMap(new ErrorMap());
        config.AddMap(new SistemaMap());
        config.ForDommel();
    });
}

错误:

System.Exception: '检测到重复的映射。属性“Id”已映射到“Id”列。

4

1 回答 1

3

您需要单独映射每个类,首先您需要忽略 ArquivoMap 类中 Sistema 的属性:

this.Map(a => a.Sistema).Ignore();

然后使用 Sistema 类的地图创建一个单独的类:

    public class SistemaMap : DommelEntityMap<Entities.Sistema>{
    public SistemaMap()
    {
        ToTable("Sistema");        
        this.Map(a => a.Id).ToColumn("sist_id");
    }
}

对类的每个子对象执行此操作。然后要进行查询,您需要执行 MultiQuery - Mapping 以获取从数据库映射的对象:

var arquivoList=    yourConnection.Query<Arquivo,Sistema, Arquivo>(sqlQuery, 
(arquivo, sistema)=>{
        arquivo.Sistema= sistema;
        return arquivo;
    });
    return arquivoList;

在此链接中查看如何进行多查询的详细信息:http: //dapper-tutorial.net/result-multi-mapping

如果您的查询中有连接,则可能需要使用 splitOn 属性。在这篇文章中很好地解释了如何做到这一点: Correct use of Multimapping in Dapper

我希望这会有所帮助。

于 2017-10-16T17:07:32.820 回答