首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >rails-4中不区分大小写的活动记录查询

rails-4中不区分大小写的活动记录查询
EN

Stack Overflow用户
提问于 2015-02-15 12:28:39
回答 3查看 2.4K关注 0票数 4

目前,我正在进行rails 4中的一个项目,其中我在example.com/username上有一个用户页面,但是只有当我在适当的情况下使用用户名时,它才能找到记录,如何在活动记录rails中执行不区分大小写的搜索。看看下面的代码

代码语言:javascript
复制
@user = User.find_by_username(params[:username].downcase)

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2015-02-15 15:52:07

您将不得不使用类似于where("username ILIKE ?")的东西。不过,ILIKE或类似的语法依赖于您的数据库。

票数 3
EN

Stack Overflow用户

发布于 2016-03-17 17:18:17

另一种选择可以是:

代码语言:javascript
复制
def self.search(query)
    where("lower(name) LIKE lower(?)", "%#{query}%") 
end

这将在sqlite或PostgreSQL中工作。

票数 1
EN

Stack Overflow用户

发布于 2017-06-21 19:14:50

你可以使用Arel表。

代码语言:javascript
复制
# Suppose the target username in DB is 'FooBAR'.
t = User.arel_table
@user = User.find_by(t[:username].matches 'foobar')

这将找到用户名为“FOOBAR”、“FOOBAR”、“FOOBAR”等的用户。

这里有更多的细节:https://github.com/rails/arel

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28526042

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档