gpt4 book ai didi

c# - 在 linq 查询中使用拆分

转载 作者:太空宇宙 更新时间:2023-11-03 19:11:50 27 4
gpt4 key购买 nike

在我的一个数据库字段中,我有如下数据:

value1, value2, value3

我的搜索参数可以是 value1 或 value2 或 value3

我想做的是使用 linq 查询来获取实体列表,例如value2在“value1,value2,value3”中

此外,值在逗号后由空格分隔。

我尝试使用以下 linq 查询,但出现错误,指出不允许进行数组操作。

List<Players> c = (from p in db.Players
where (p.Users == "Everyone" || p.Users.Split()[','].Trim().Contains(username))
orderby p.Category ascending
select p).ToList();

有什么想法可以实现吗?

最佳答案

你没有正确地进行 Split,它应该是这样的:

p.Users.Split(',').Contains(username)

如果你想修剪每个拆分值,那么:

p.Users.Split(',').Select(r=> r.Trim).Contains(username)

如果您正在使用 LINQ to Entities,那么您最终可能会遇到 string.Split 无法转换为 SQL 查询的异常。在这种情况下,您可能必须先迭代 (ToList) 您的结果,然后将其与拆分数组进行比较。

关于c# - 在 linq 查询中使用拆分,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20056557/

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