By the way, right now I'm using a State.objects.get(name__iexact=name)
in clean_name() method in a form subclass to prevent creation of case-
insensitive duplicates. Just wondering if there is a built-in or
better way.

On Dec 6, 2:57 pm, chefsmart <moran.cors...@gmail.com> wrote:
> Reading through some discussions on this mailing list and elsewhere, I
> saw a lot of material on mysql case sensitivity and collation.
>
> Consider the following situation: -
>
> Suppose my app allows users to create the states / provinces in their
> country. Just for clarity, we are considering only ASCII characters
> here.
>
> In the US, a user could create the state called "Texas". If this app
> is being used internally, let's say the user doesn't care if it is
> spelled "texas" or "Texas"
>
> But importantly, the system should prevent creation of "texas" if
> "Texas" is already in the database.
>
> If the model is like the following:
>
> class State(models.Model):
>     name = models.CharField(max_length=50, unique=True)
>
> The uniqueness would be case-sensitive in postgres, that is, postgres
> would allow the user to create both "texas" and "Texas" as they are
> considered unique.
>
> What can be done in this situation to prevent such behavior. How does
> one go about providing case-INsenstitive uniqueness with Django and
> Postgres

--

You received this message because you are subscribed to the Google Groups 
"Django users" group.
To post to this group, send email to django-us...@googlegroups.com.
To unsubscribe from this group, send email to 
django-users+unsubscr...@googlegroups.com.
For more options, visit this group at 
http://groups.google.com/group/django-users?hl=en.


Reply via email to