V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
bthulu
V2EX  ›  .NET

efcore 中, 使用 FromSql 查询时, 如何设置 where in 参数?

  •  
  •   bthulu · 11 小时 25 分钟前 · 299 次点击

    像下面这样, 是查不出来的. 是有什么特殊姿势我不会的吗? google 了半天也没找出来怎么传递集合参数进去.

    var ids = new List<string>() { "A001", "B001" };
    appDbContext.RackTransfers.FromSql($"select * from RackTransfers where Id IN ({ids})");
    
    第 1 条附言  ·  10 小时 1 分钟前
    下面这样的我是知道的, 但是我这里问的是用 FromSql 时怎么传参. 要知道很多复杂查询, 没法用 Where 表达出来的.
    dbContext.Where(e => ids.Contains(e.Id))
    16 条回复    2024-10-09 20:25:15 +08:00
    corcre
        1
    corcre  
       10 小时 56 分钟前
    可能就是不支持的吧 之前上网搜了一下发现没解决方案就放弃了, 现在一般要不就把 ids 给先处理好传进去(处理成('A001','B001')然后字符串拼接)
    要不就根据 ids 的长度循环塞进去, 例如..... IN {@id0,@id1,@id2}然后按正常方式传参...
    反正都挺麻烦的🐶🐶🐶
    jiangzm
        2
    jiangzm  
       10 小时 37 分钟前
    EF.Functions.Like 或者 Contains
    luojianxhlxt
        3
    luojianxhlxt  
       10 小时 22 分钟前
    你这是 sql 语句,得用 string.join 拼接成 where id in('A001','A002')
    nikenidage1
        4
    nikenidage1  
       10 小时 8 分钟前
    1.支持
    2.不能用 FromSql ,你这不是 linq 了啊
    3.这样
    appDbContext. RackTransfers.Where(r=> ids.Contains(r.Id));
    nikenidage1
        5
    nikenidage1  
       10 小时 7 分钟前
    题外话,不知道你怎么搜索的,怎么会没有相关资料的呢?
    谷歌,关键字 entity framework where in ,第一条就是 stackoverflow 上的答案啊
    wu00
        6
    wu00  
       10 小时 4 分钟前
    appDbContext.RackTransfers.FromSql($"select * from RackTransfers where Id IN ('{string.Join("','", ids)}')");
    bthulu
        7
    bthulu  
    OP
       10 小时 4 分钟前
    @nikenidage1 你这个大家都知道, 但是很多情况下, 没法这样查. 比如取 group by 后组内第一条返回一个集合, 目前 ef core 还不支持这个功能, 官方说至少的 efcore10 才有可能支持.
    ```
    using AppDbContext dbContext = CreateAppDbContext();
    var queryable = dbContext.Racks.Where(e => e.Occupied == true).GroupBy(e => e.Aisle)
    .Select(g => g.OrderBy(e => e.Col).Take(1));
    // 支持
    List<IEnumerable<Rack>> list = queryable.ToList();
    // 不支持, 可能 efcore10.0 会支持, 参考 https://github.com/dotnet/efcore/issues/28002
    List<Rack> racks = queryable.SelectMany(e => e).ToList();
    ```
    bthulu
        8
    bthulu  
    OP
       10 小时 2 分钟前
    @nikenidage1 请注意看题, 使用 FromSql 查询时, 不是使用 Where 查询.
    Removable
        9
    Removable  
       9 小时 48 分钟前
    https://v2ex.com/i/XFsksX67.jpeg

    应该只能这样了吧?
    Removable
        10
    Removable  
       9 小时 45 分钟前
    @Removable #7 可以单独写个静态类去处理字符串/数字类型的拼接,省得每次都要写 string.Join 和 Linq
    a194259440
        11
    a194259440  
       9 小时 37 分钟前
    OP 用的什么版本?.NET6 现在是这样,可以用参数化进行传参,可以试试
    var ids = new List<string>() { "A001", "B001" };
    var parameters = new[]
    {
    new NhgdbParameter("@Ids ", ids )}
    };
    appDbContext.RackTransfers.FromSqlRaw($"select * from RackTransfers where Id IN @Ids ",parameters );
    a194259440
        12
    a194259440  
       9 小时 35 分钟前
    @a194259440 如果不行,建议用其他 ORM 框架,Dapper 保底可以实现
    nikenidage1
        13
    nikenidage1  
       9 小时 21 分钟前
    @bthulu 哦用 FromSql 那我理解错了
    bthulu
        14
    bthulu  
    OP
       9 小时 8 分钟前
    @a194259440 在.net8.0+efcore8.0 中实测下面两种方式都不行, 直接报错 System.NotSupportedException
    方式一:
    int[] ids = [1, 2, 3];
    List<MySqlParameter> parameters = ids.Select(e => new MySqlParameter("@Ids", e)).ToList();
    List<Rack> racks = dbContext.Racks.FromSqlRaw("select * from rack where id in (@Ids)", parameters).ToList();
    方式二:
    int[] ids = [1, 2, 3];
    MySqlParameter parameters = new MySqlParameter("@Ids", ids);
    List<Rack> racks = dbContext.Racks.FromSqlRaw("select * from rack where id in (@Ids)", parameters).ToList();
    bthulu
        15
    bthulu  
    OP
       9 小时 3 分钟前
    上面两个示例中, 将 new MySqlParameter("@Ids", ...)改为 new MySqlParameter("Ids", ...), 也是一样的报错
    PopRain
        16
    PopRain  
       7 小时 1 分钟前
    in 的参数化查询语句是这样的:where x in (@0,@1,@2..... ) ; 所以,后台需要把 List 转换为一个个的参数,不知道 efcore 是否有这个功能,我们公司是自己实现的
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1007 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 28ms · UTC 19:26 · PVG 03:26 · LAX 12:26 · JFK 15:26
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.