加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

ruby-on-rails-3 – Rails 3.验证邮件唯一性和区分大小写失败

发布时间:2020-12-16 19:52:29 所属栏目:百科 来源:网络整理
导读:我正在Rails 3开发一个应用程序,一旦注册,我需要用户输入他们的电子邮件地址,我需要它是唯一的区分大小写.即当MyEmail@yahoo.com已经存在于数据库中时,没有人可以使用myEmail@yahoo.com注册. 这是我的代码,它崩溃的应用程序: validates :email,:presence =
我正在Rails 3开发一个应用程序,一旦注册,我需要用户输入他们的电子邮件地址,我需要它是唯一的区分大小写.即当MyEmail@yahoo.com已经存在于数据库中时,没有人可以使用myEmail@yahoo.com注册.

这是我的代码,它崩溃的应用程序:

validates :email,:presence => true,:uniqueness => true,:case_sensitive => true,:format => {:with => /^([^@s]+)@((?:[-a-z0-9]+.)+[a-z]{2,})$/i}

这是怎么回事?

解决方法

请不要使用区分大小写!!!它将获取所有的用户!所以如果你有100.000个用户.首先它将用LOWER(电子邮件)获取它们.这可能非常慢,它不会在电子邮件上使用您的索引.

这里有一篇关于这个话题的文章:http://techblog.floorplanner.com/post/20528527222/case-insensitive-validates-uniqueness-of-slowness

我的建议是:运行一个查询以使所有的电子邮件都已经下载,并使之前的验证过滤器能够对电子邮件属性进行缩减,以便在该列中没有任何大写字符.

User.update_all('email = LOWER(email)')

过滤前:

before_validation :downcase_email

private

def downcase_email
  self.email = email.downcase if email.present?
end

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读