Rails validates_uniqueness_of across multiple columns with case insensitivity
Asked Answered
A

1

14

I have a model that has two fields, which I will call first_name and last_name, and I want to make sure that the combination of the two are case-insensitively unique. I've gotten halfway there by using this:

validates_uniqueness_of :first_name, :scope => :last_name

The problem is that the uniqueness check seems to be case sensitive, even though the documentation says it should be case insensitive by default. So given an existing record:

{ :first_name => 'John', :last_name => 'Smith' }

This will be allowed:

{ :first_name => 'JOHN', :last_name => 'SMITH' }

As well as any additional record where there is any variation of case in either the first or last name. Why are these records being allowed? How can I enforce case insensitive uniqueness across both fields together?

Alister answered 6/2, 2010 at 23:50 Comment(0)
F
21

Did you try validates_uniqueness_of :first_name, :scope => :last_name, :case_sensitive => false?

The documentation says it's true by default.

(I think the link you gave is to some outdated documentation. IIRC, the default for this did change in the last couple of years.)

Favrot answered 6/2, 2010 at 23:53 Comment(6)
You're right! I was mislead by the documentation I found. Setting :case_sensitive => false made it work for the first_name, but it doesn't work the other direction. It will still accept { :first_name => 'John', :last_name => 'SMITH' }. Is there a way to make it work bi-directionally? Would I just include two validates_uniqueness_of rules with the field swapped?Alister
I tried adding another validation with the two fields swapped. It will now catch cases where one of the fields is differently cased, but not if both are, so this still gets through: { :first_name => 'JOHN', :last_name => 'SMITH' }.Alister
I'd just write a custom validation method at this point if I were you.Favrot
Yep, that's what I ended up doing. Thanks all.Alister
You should share your custom validation method for others to learn. :)Illuviation
github.com/jimmycuadra/morethingsneed.to/blob/…Alister

© 2022 - 2024 — McMap. All rights reserved.