Opened 18 years ago

Closed 17 years ago

#2422 closed defect (invalid)

unique_together on SQLite uses 'iexact' matching, I expected this to be 'exact'

Reported by: scanner@… Owned by: Adrian Holovaty
Component: contrib.admin Version:
Severity: normal Keywords: SQlite
Cc: Triage Stage: Unreviewed
Has patch: no Needs documentation: no
Needs tests: no Patch needs improvement: no
Easy pickings: no UI/UX: no

Description

I have a model that has:

    class Meta:
        unique_together = (('gecko_engine_instance', 'name'), ('gecko_engine_instance', 'dhcp_client_identifier'), )

For the 'dhcp_client_identifier' "foo" is different from "Foo."

However the query that was enforcing uniqueness ends up looking line:

SELECT "dcs_client"."id" ... blah blah ..  WHERE ("dcs_client__gecko_engine_instance"."id" ILIKE '1' AND  dcs_client"."dhcp_client_identifier" ILIKE 'blarg')

which will fail if I have another client object with a dhcp_client_identifier of 'Blarg.' I figure there must be a reason for this although it causes me problems. Perhaps it is some strange compatibility with sqlite3.

I need to know if this is a bug, a workaround, or working as intended so I can modify my code appropriately?

Change History (8)

comment:1 by mir@…, 18 years ago

Cc: mir@… added

comment:2 by scanner@…, 18 years ago

Oh, another note - this can be related to ticket #2417 - when I define a binary type field (in my own project subclassing models.CharField, and defining the appropriate db type in the db creation.py module, 'ilike' is not a valid operator for on such a field for obvious reasons whereas 'like' is.

comment:3 by mir@…, 17 years ago

Cc: mir@… removed

removed myself from Cc since ticket starts to get spammed :-(

comment:4 by Robert Myers <myer0052@…>, 17 years ago

SQLite doesn't support case-sensitive LIKE statements. From the Django documentation itself. This ticket should be closed.

comment:5 by Robert Myers <myer0052@…>, 17 years ago

Should have provided a handy link, here goes: http://www.djangoproject.com/documentation/db_api/#iexact maybe the text below contains should be copied to exact as well.

  • SQLite doesn't support case-sensitive LIKE statements; exact acts like iexact for SQLite.

comment:6 by Gary Wilson <gary.wilson@…>, 17 years ago

Resolution: invalid
Status: newclosed

What Robert said.

comment:7 by Bastian Kleineidam <calvin@…>, 17 years ago

Resolution: invalid
Status: closedreopened

I encountered the same bug today as the original submitter: I specified uniqueness, but django complained about duplicate field values.

I don't use sqlite, but postgresql, and I fixed the bug by replacing all 'iexact' with 'exact' in db/models/manipulators.py:manipulator_validator_unique_together().

comment:8 by Simon G. <dev@…>, 17 years ago

Keywords: SQlite added
Resolution: invalid
Status: reopenedclosed
Summary: unique_together uses 'iexact' matching, I expected this to be 'exact'unique_together on SQLite uses 'iexact' matching, I expected this to be 'exact'

Hi Bastian, I don't think these issues are related other than the case sensitivity. The original bug here was to do with SQLite's lack of a case sensitive match, whilst your problem is in the manipulators (which directly specifies iexact). This is a design issue I think, IMO case insensitive matches are the most common idea (i.e. we don't want a "Simon" and a "SImon" in the database), but this might be nice to have as an option.

Long story short - Can you create a new ticket for this issue?

Thanks :)
Simon

Note: See TracTickets for help on using tickets.
Back to Top