On Thu, Dec 18, 2008 at 4:53 PM, Eugene Mirotin <emiro...@gmail.com> wrote:
> > Hello. > Consider I have a simple model > > class Team(models.Model): > name = models.CharField(max_length=200) > > Then I create some team and try to look for it with iexact match: > tt = Team(name='English') > tt.save() > Team.objects.filter(name__iexact=tt.name.lower()) # this returns the > list containing my initial team object > > When I do the same from the terminal and create the Team object by > passing the unicode symbols (e.g. u'<Russian symbols>'), it works the > same. > But when created from the admin interface, the data is not saved in > unicode (at least it looks like so, cause the field is varchar). > And then name__iexact=name.lower() does not work. > The data is saved using utf-8 encoding. The issue is the SQLite doesn't support case-insensitive matching on anything other than 7-bit ASCII chars. See: http://www.sqlite.org/faq.html#q18 The last time I answered this question I only found reference to this behavior as a "bug". The answer I'm pointing to above, however, considers it a design decision and mentions that sqlite provides an extension to get case-insensitive Unicode comparisons working. So, there may actually be a way to get this working under Django, but I'm not sure of that. My guess is this extension would need to be included/supported by pysqlite (the Python interface to SQLite that Django uses). If it is, perhaps there is just some switch Django could flip to tell pysqlite to use this ICU extension to get case-insensitive unicode matching working. If pysqlite doesn't support this extension then I rather doubt this can be made to work under Django, but I'm basically just guessing here. Switching to a different database, one that supports case-insensitive unicode matching out of the box, might be an easier answer for you. Karen --~--~---------~--~----~------------~-------~--~----~ You received this message because you are subscribed to the Google Groups "Django users" group. To post to this group, send email to django-users@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 -~----------~----~----~----~------~----~------~--~---