Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/ms-access/4.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# gId] 其中[AuctionId]=@{nameof(AuctionId)} 按[批次][Id]、[项目][Id]、[扩展][Id]订购;", 新类型[]{ 类型(批次), (项目)的类型, (事物)的类型, 类型(扩展), 类型(事物) }, MapResult(结果), 新的 { AuctionId=AuctionId } ); 返回result.ToList(); } } 私有函数映射结果(列表结果) { 返回(obj)=> { Lot Lot=(Lot)obj[0]; 项目=(项目)obj[1]; Thing itemDetails=(Thing)obj[2]; 子项子项=(子项)obj[3]; Thing subItemDetails=(Thing)obj[4]; 如果(批次!=null) { if(result.Any(a=>a.Id==lot.Id)) { lot=结果。第一(a=>a.Id==lot.Id); } 其他的 { 结果:添加(批次); } } 如果(项!=null) { if(lot.Items.Any(i=>i.Id==item.Id)) { item=lot.Items.First(i=>i.Id==item.Id); } 其他的 { lot.Items.Add(item.FromThing(itemDetails)); } } if(扩展!=null) { if(item.SubItems.Any(e=>e.Id==subItem.Id)==false) { item.SubItems.Add(subItem.FromThing(subItemDetails)); } } 返回null; }; }_C#_Ms Access_Orm_Dapper - Fatal编程技术网 { Lot Lot=(Lot)obj[0]; 项目=(项目)obj[1]; Thing itemDetails=(Thing)obj[2]; 子项子项=(子项)obj[3]; Thing subItemDetails=(Thing)obj[4]; 如果(批次!=null) { if(result.Any(a=>a.Id==lot.Id)) { lot=结果。第一(a=>a.Id==lot.Id); } 其他的 { 结果:添加(批次); } } 如果(项!=null) { if(lot.Items.Any(i=>i.Id==item.Id)) { item=lot.Items.First(i=>i.Id==item.Id); } 其他的 { lot.Items.Add(item.FromThing(itemDetails)); } } if(扩展!=null) { if(item.SubItems.Any(e=>e.Id==subItem.Id)==false) { item.SubItems.Add(subItem.FromThing(subItemDetails)); } } 返回null; }; },c#,ms-access,orm,dapper,C#,Ms Access,Orm,Dapper" /> { Lot Lot=(Lot)obj[0]; 项目=(项目)obj[1]; Thing itemDetails=(Thing)obj[2]; 子项子项=(子项)obj[3]; Thing subItemDetails=(Thing)obj[4]; 如果(批次!=null) { if(result.Any(a=>a.Id==lot.Id)) { lot=结果。第一(a=>a.Id==lot.Id); } 其他的 { 结果:添加(批次); } } 如果(项!=null) { if(lot.Items.Any(i=>i.Id==item.Id)) { item=lot.Items.First(i=>i.Id==item.Id); } 其他的 { lot.Items.Add(item.FromThing(itemDetails)); } } if(扩展!=null) { if(item.SubItems.Any(e=>e.Id==subItem.Id)==false) { item.SubItems.Add(subItem.FromThing(subItemDetails)); } } 返回null; }; },c#,ms-access,orm,dapper,C#,Ms Access,Orm,Dapper" />

C# gId] 其中[AuctionId]=@{nameof(AuctionId)} 按[批次][Id]、[项目][Id]、[扩展][Id]订购;", 新类型[]{ 类型(批次), (项目)的类型, (事物)的类型, 类型(扩展), 类型(事物) }, MapResult(结果), 新的 { AuctionId=AuctionId } ); 返回result.ToList(); } } 私有函数映射结果(列表结果) { 返回(obj)=> { Lot Lot=(Lot)obj[0]; 项目=(项目)obj[1]; Thing itemDetails=(Thing)obj[2]; 子项子项=(子项)obj[3]; Thing subItemDetails=(Thing)obj[4]; 如果(批次!=null) { if(result.Any(a=>a.Id==lot.Id)) { lot=结果。第一(a=>a.Id==lot.Id); } 其他的 { 结果:添加(批次); } } 如果(项!=null) { if(lot.Items.Any(i=>i.Id==item.Id)) { item=lot.Items.First(i=>i.Id==item.Id); } 其他的 { lot.Items.Add(item.FromThing(itemDetails)); } } if(扩展!=null) { if(item.SubItems.Any(e=>e.Id==subItem.Id)==false) { item.SubItems.Add(subItem.FromThing(subItemDetails)); } } 返回null; }; }

C# gId] 其中[AuctionId]=@{nameof(AuctionId)} 按[批次][Id]、[项目][Id]、[扩展][Id]订购;", 新类型[]{ 类型(批次), (项目)的类型, (事物)的类型, 类型(扩展), 类型(事物) }, MapResult(结果), 新的 { AuctionId=AuctionId } ); 返回result.ToList(); } } 私有函数映射结果(列表结果) { 返回(obj)=> { Lot Lot=(Lot)obj[0]; 项目=(项目)obj[1]; Thing itemDetails=(Thing)obj[2]; 子项子项=(子项)obj[3]; Thing subItemDetails=(Thing)obj[4]; 如果(批次!=null) { if(result.Any(a=>a.Id==lot.Id)) { lot=结果。第一(a=>a.Id==lot.Id); } 其他的 { 结果:添加(批次); } } 如果(项!=null) { if(lot.Items.Any(i=>i.Id==item.Id)) { item=lot.Items.First(i=>i.Id==item.Id); } 其他的 { lot.Items.Add(item.FromThing(itemDetails)); } } if(扩展!=null) { if(item.SubItems.Any(e=>e.Id==subItem.Id)==false) { item.SubItems.Add(subItem.FromThing(subItemDetails)); } } 返回null; }; },c#,ms-access,orm,dapper,C#,Ms Access,Orm,Dapper,MapResult是代码的核心。它返回一个Func,它有两种类型:我们上面定义的类型数组和返回类型,并获取顶级对象的列表。 然后,我将对象数组中的每一项映射到它的另一个实际类型。这使代码更易于阅读,并允许访问对象的属性和方法而不会出现问题 然后是逐步降低层次结构的情况,在每一步检查是否已经存在具有匹配id的迭代器,如果已经存在,则将迭代器替换为对它的引用 在这种特殊情况下,我还添加了一个FromThing函数,以便更容易地组合对象属性 ID | Autonumeric T

MapResult是代码的核心。它返回一个Func,它有两种类型:我们上面定义的类型数组和返回类型,并获取顶级对象的列表。 然后,我将对象数组中的每一项映射到它的另一个实际类型。这使代码更易于阅读,并允许访问对象的属性和方法而不会出现问题

然后是逐步降低层次结构的情况,在每一步检查是否已经存在具有匹配id的迭代器,如果已经存在,则将迭代器替换为对它的引用

在这种特殊情况下,我还添加了一个FromThing函数,以便更容易地组合对象属性

ID            |  Autonumeric
TareaM_Id     |  Numeric
Fecha         |  Date/Time
ID            |  Autonumeric
Nombre        |  Short Text
[Table("Registros")]
public class Registro
{
    [Column("ID")]
    public virtual int ID { get; set; }

    [Column("Fecha")]
    public virtual DateTime Fecha { get; set; }

    [Column("TareaM_Id")]
    public virtual int TareaM_Id { get; set; }

    public virtual MacroTarea MacroT { get; set; }
}

[Table("Macro_tarea")]
public class MacroTarea
{
    [Column("ID")]
    public virtual int ID { get; set; }

    [Column("Nombre")]
    public virtual string Nombre{ get; set; }

    public virtual ICollection<Registro> Registros { get; set; }

}
string sql = @"SELECT reg.ID, mac.ID 
    FROM Registros as reg INNER JOIN Macro_tarea as mac on reg.TareaM_Id = mac.ID
    WHERE Fecha = @Fecha";

using (IDbConnection db = new OleDbConnection(ConnectionString))
{
    var result = db.Query<Registro,MacroTarea, Registro>(sql, 
    (reg,mac) =>
    {
        reg.MacroTarea = mac;
        return reg;
    }
    ,new { @Fecha = new DateTime(2019, 1, 4).Date }
    , splitOn: "mac.ID")
    .AsList();                                            
}
IDictionary<string, string> columnMaps = new Dictionary<string, string>()
            {
                { "Macro_tarea.ID", "ID" },
                { "Registros.ID", "ID" }
            };
var mapper = new Func<Type, string, PropertyInfo>((type, columnName) =>
            {
                if (columnMaps.ContainsKey(columnName))
                    return type.GetProperty(columnMaps[columnName]);
                else
                    return type.GetProperty(columnName);
            });
ITypeMap MacroTareaMapper = new CustomPropertyTypeMap(typeof(Macro_tarea),
                (type, columnName) => mapper(type, columnName));

ITypeMap RegistrosMapper = new CustomPropertyTypeMap(typeof(Registros),
                (type, columnName) => mapper(type, columnName));
SqlMapper.SetTypeMap(typeof(Macro_tarea), MacroTareaMapper);
SqlMapper.SetTypeMap(typeof(Registros), RegistrosMapper);
internal class Macro_tareaMap : EntityMap<Macro_tarea>
{
       internal Macro_tareaMap()
       {
            //Mi propiedad ID esta asociada a la columna Macro_tarea.ID
            Map(x => x.ID).ToColumn("Macro_tarea.ID");
       }
}
FluentMapper.Initialize((config) => 
{
    config.AddMap(new Macro_tareaMap());
});
public async Task<List<Lot>> GetAll(int auctionId)
{
    using (var connection = new SqlConnection(_appSettings.ConnectionString))
    {
        await connection.OpenAsync();
        var result = new List<Lot>();
        await connection.QueryAsync($@"
            SELECT [Lot].*, 
                [Item].[Id], 
                [Item].[LotId], 
                [Item].[Notes], 
                itemDetails.[Id],
                itemDetails.[ThingId],
                itemDetails.[Colour], 
                itemDetails.[Size], 
                [SubItem].[Id], 
                [SubItem].[ItemId], 
                [SubItem].[Notes], 
                subItemDetails.[Id],
                subItemDetails.[ThinId],
                subItemDetails.[Colour], 
                subItemDetails.[Size]
            FROM [Lot]
                INNER JOIN [Item] ON [Item].[LotId] = [Lot].[Id]
                    LEFT JOIN [Thing] AS itemDetails ON itemDetails.[Id] = [Item].[ThingId]
                LEFT JOIN [SubItem] ON [SubItem].[ItemId] = [Item].[Id]
                    LEFT JOIN [Thing] AS subItemDetails ON subItemDetails.[Id] = [SubItem].[ThingId]
            WHERE [AuctionId] = @{nameof(auctionId)}
            ORDER BY [Lot].[Id], [Item].[Id], [Expansion].[Id];",
            new Type[] {
                typeof(Lot),
                typeof(Item),
                typeof(Thing),
                typeof(Expansion),
                typeof(Thing)
            }, 
            MapResult(result),
            new
            {
                AuctionId = auctionId
            }
        );

        return result.ToList();
    }
}

private Func<object[], Lot> MapResult(List<Lot> result)
{
    return (obj) =>
    {
        Lot lot = (Lot)obj[0];
        Item item = (Item)obj[1];
        Thing itemDetails = (Thing)obj[2];
        SubItem subItem = (SubItem)obj[3];
        Thing subItemDetails = (Thing)obj[4];
        if (lot != null)
        {
            if (result.Any(a => a.Id == lot.Id))
            {
                lot = result.First(a => a.Id == lot.Id);
            }
            else
            {
                result.Add(lot);
            }
        }
        if (item != null)
        {
            if (lot.Items.Any(i => i.Id == item.Id))
            {
                item = lot.Items.First(i => i.Id == item.Id);
            }
            else
            {
                lot.Items.Add(item.FromThing(itemDetails));
            }
        }
        if (expansion != null)
        {
            if (item.SubItems.Any(e => e.Id == subItem.Id) == false)
            {
                item.SubItems.Add(subItem.FromThing(subItemDetails));
            }
        }
            return null;
    };
}