Rails 3.验证电子邮件唯一性和区分大小写失败

Jon*_*ark 13 validation ruby-on-rails-3

我正在开发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}
Run Code Online (Sandbox Code Playgroud)

这有什么问题?

Mic*_*per 40

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

这篇文章我刚刚发现这个主题:http://techblog.floorplanner.com/post/20528527222/case-insensitive-validates-uniqueness-of-slowness

我的建议是:运行一个查询以使所有电子邮件降级,并使之前的验证过滤器为downcase的电子邮件属性,因此您在该列中没有任何大写字符.

User.update_all('email = LOWER(email)')
Run Code Online (Sandbox Code Playgroud)

过滤之前:

before_validation :downcase_email

private

def downcase_email
  self.email = email.downcase if email.present?
end
Run Code Online (Sandbox Code Playgroud)

  • 这是一种古老的方法.Rails 3允许使用哈希验证:email,:uniqueness => {:case_sensitive => false},正如Geoff Evason所写. (2认同)

Geo*_*son 32

对于Rails 3类型的验证,您需要像这样嵌套casse不敏感块

validates :email, :uniqueness => { :case_sensitive => false }
Run Code Online (Sandbox Code Playgroud)