gpt4 book ai didi

c# - linq/lambda 查询中的双内连接?

转载 作者:可可西里 更新时间:2023-11-01 07:05:54 28 4
gpt4 key购买 nike

我得到了这个 SQL 查询,我想将其转换为 Linq。这是联系方式:

我正在制作一个需要从 3 个不同表返回值的 asp.net api

CREATE TABLE Locatie (
locatieId INT IDENTITY(1,1) not null,
postcode VARCHAR(10) not null,
huisnummer INT not null,
adres VARCHAR(50) not null,
plaats VARCHAR(50) not null,




CREATE TABLE Vereniging (
verenigingId INT IDENTITY(1,1) not null,
locatieId INT not null,
naam VARCHAR(50) not null,
facebookGroupId BIGINT null,


CREATE TABLE Saldo (
saldoId INT IDENTITY(1,1) not null,
lidId INT not null,
verenigingId INT not null,
bedrag SMALLMONEY not null,

我遗漏了所有的外键和主键。这只是为了澄清我想要什么。我现在的问题是我有一个函数需要从多个表中返回信息。sql查询看起来像这样=

Select v.verenigingId, l.postcode, l.huisnummer, l.adres,l.plaats,v.naam,v.facebookGroupId 
from Vereniging v inner join Saldo s
on v.verenigingId = s.verenigingId
inner join Locatie l
on v.locatieId=l.locatieId
where s.lidId = 1;

我从 lidid=1 获取所有“verenigingen”,并在表 Location 中显示“verenigingen”的所有信息。

但是当我尝试使用 linq/lambda 执行此操作时,它出错了;我的函数如下所示:

public class LibraryRepository : ILibraryRepository
{
private LibraryContext _context;

public LibraryRepository(LibraryContext context)
{
_context = context;
}

public bool Save()
{
return (_context.SaveChanges() >= 0);
}

public IEnumerable<Verenigingmodel> GetVerenigingenperLid(int lidId)
{
return _context.Vereniging
.Join(
_context.Saldo.Where(b => b.lidId == lidId),
ver => ver.verenigingId,
sal => sal.verenigingId,
(ver, sal) => new Viewmodel { Vereniging = ver, Saldo = sal })
.Join(
_context.Locatie,
verr => verr.Vereniging.locatieId,
loca => loca.locatieId,
(vr, loca) => new Viewmodel { Locatie = loca });
//this returns wrong sql information
}

我的验证模型如下所示:

public class Verenigingmodel
{
public int verenigingId { get; set; }
public string postcode { get; set; }
public int huisnummer { get; set; }
public string adres { get; set; }
public string plaats { get; set; }
public string naam { get; set; }
public int facebookGroupId { get; set; }
}

我的图书馆上下文是这样的:

public class LibraryContext : DbContext
{
public LibraryContext(DbContextOptions<LibraryContext> options)
: base(options)
{
Database.Migrate();
}

public DbSet<Gebruiker> Gebruiker { get; set; }
public DbSet<Lid> Lid { get; set; }
public DbSet<Vereniging> Vereniging { get; set; }
public DbSet<Saldo> Saldo { get; set; }
public DbSet<Locatie> Locatie { get; set; }
}

我想要实现的是,我将所有不同的信息放在 verenigingmodel 中,然后将其作为我的 rest api 的输出:

    [HttpGet("api/Vereniging/{lidId}")]

public IActionResult FindVereniGingenPerLid(int lidId)
{
var verenigingFromRepo = vlibraryRepository.GetVerenigingenperLid(lidId);

return new JsonResult(verenigingFromRepo);

}

最佳答案

我会做一些不同的功能。像这样:

public IEnumerable<Verenigingmodel> GetVerenigingenperLid(int lidId)
{
return (
from v in _context.Vereniging
join s in _context.Saldo
on v.verenigingId equals s.verenigingId
join l in _context.Locatie
on v.locatieId equals l.locatieId
select new Verenigingmodel()
{
verenigingId= v.verenigingId,
postcode=l.postcode,
huisnummer=l.huisnummer,
adres=l.adres,
naam=v.naam,
facebookGroupId=v.facebookGroupId,
plaats=l.plaats
}
).ToList();
}

我个人觉得这样更容易看到连接并将结果组合到一个对象中

关于c# - linq/lambda 查询中的双内连接?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43914634/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com