如何使用 Linq 和 SQL Server 进行不区分大小写的字符串搜索?

发布于 2024-09-11 05:12:30 字数 344 浏览 8 评论 0原文

这是我当前用于搜索标签的代码:

    public JsonResult TagSearch(string term) {
        if (term == null || term == "")
            return Json("");

        var tags = (from t in _session.All<Tag>() where t.Name.Contains(term) select t.Name).Take(6).ToArray();

        return Json(tags);
    }

我如何进行不区分大小写的字符串搜索?

Here is my current code for searching tags:

    public JsonResult TagSearch(string term) {
        if (term == null || term == "")
            return Json("");

        var tags = (from t in _session.All<Tag>() where t.Name.Contains(term) select t.Name).Take(6).ToArray();

        return Json(tags);
    }

How could I do case insensitive string search instead?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

和影子一齐双人舞 2024-09-18 05:12:33

使用 ToLower 方法。像这样:

var tags = (from t in _session.All<Tag>() where t.Name.ToLower().Contains(term.ToLower()) select t.Name).Take(6).ToArray();

Use the ToLower method. Like this:

var tags = (from t in _session.All<Tag>() where t.Name.ToLower().Contains(term.ToLower()) select t.Name).Take(6).ToArray();
计㈡愣 2024-09-18 05:12:31

Contains() 方法转换为 SQL 中不区分大小写的操作。我认为我发布的代码区分大小写。

The Contains() method is converted to case-insensitive operation in SQL. I think the code I posted is case insensitive.

锦爱 2024-09-18 05:12:31

改变列的排序规则是不可能的吗?

Is changing the collation of the column out of the question?

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文