1
0
mirror of https://github.com/django/django.git synced 2025-07-05 18:29:11 +00:00

queryset-refactor: Fixed some errors in Oracle regex handling that were

introduced in [7087]. Patch from Ian Kelly. Fixed #7065.


git-svn-id: http://code.djangoproject.com/svn/django/branches/queryset-refactor@7444 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
Malcolm Tredinnick 2008-04-23 07:30:59 +00:00
parent 5a9a208b7a
commit 382d31a981
2 changed files with 11 additions and 4 deletions

View File

@ -119,10 +119,17 @@ class DatabaseOperations(BaseDatabaseOperations):
def regex_lookup_10(self, lookup_type):
if lookup_type == 'regex':
match_option = 'c'
match_option = "'c'"
else:
match_option = 'i'
return 'REGEXP_LIKE(%%s %%s %s)' % match_option
match_option = "'i'"
return 'REGEXP_LIKE(%%s, %%s, %s)' % match_option
def regex_lookup(self, lookup_type):
# If regex_lookup is called before it's been initialized, then create
# a cursor to initialize it and recur.
from django.db import connection
connection.cursor()
return connection.ops.regex_lookup(lookup_type)
def sql_flush(self, style, tables, sequences):
# Return a list of 'TRUNCATE x;', 'TRUNCATE y;',

View File

@ -140,7 +140,7 @@ class WhereNode(tree.Node):
elif lookup_type == 'search':
return (connection.ops.fulltext_search_sql(field_sql), params)
elif lookup_type in ('regex', 'iregex'):
return connection.ops.regex_lookup % (field_sql, cast_sql), params
return connection.ops.regex_lookup(lookup_type) % (field_sql, cast_sql), params
raise TypeError('Invalid lookup_type: %r' % lookup_type)