2012-09-09 07:51:36 +08:00
|
|
|
"""
|
|
|
|
Constants specific to the SQL storage portion of the ORM.
|
|
|
|
"""
|
|
|
|
|
2012-04-30 06:50:48 +08:00
|
|
|
from collections import namedtuple
|
Merged the queryset-refactor branch into trunk.
This is a big internal change, but mostly backwards compatible with existing
code. Also adds a couple of new features.
Fixed #245, #1050, #1656, #1801, #2076, #2091, #2150, #2253, #2306, #2400, #2430, #2482, #2496, #2676, #2737, #2874, #2902, #2939, #3037, #3141, #3288, #3440, #3592, #3739, #4088, #4260, #4289, #4306, #4358, #4464, #4510, #4858, #5012, #5020, #5261, #5295, #5321, #5324, #5325, #5555, #5707, #5796, #5817, #5987, #6018, #6074, #6088, #6154, #6177, #6180, #6203, #6658
git-svn-id: http://code.djangoproject.com/svn/django/trunk@7477 bcc190cf-cafb-0310-a4f2-bffc1f526a37
2008-04-27 10:50:16 +08:00
|
|
|
import re
|
|
|
|
|
2012-09-09 07:51:36 +08:00
|
|
|
# Valid query types (a set is used for speedy lookups). These are (currently)
|
|
|
|
# considered SQL-specific; other storage systems may choose to use different
|
|
|
|
# lookup types.
|
2012-04-30 10:18:30 +08:00
|
|
|
QUERY_TERMS = set([
|
Merged the queryset-refactor branch into trunk.
This is a big internal change, but mostly backwards compatible with existing
code. Also adds a couple of new features.
Fixed #245, #1050, #1656, #1801, #2076, #2091, #2150, #2253, #2306, #2400, #2430, #2482, #2496, #2676, #2737, #2874, #2902, #2939, #3037, #3141, #3288, #3440, #3592, #3739, #4088, #4260, #4289, #4306, #4358, #4464, #4510, #4858, #5012, #5020, #5261, #5295, #5321, #5324, #5325, #5555, #5707, #5796, #5817, #5987, #6018, #6074, #6088, #6154, #6177, #6180, #6203, #6658
git-svn-id: http://code.djangoproject.com/svn/django/trunk@7477 bcc190cf-cafb-0310-a4f2-bffc1f526a37
2008-04-27 10:50:16 +08:00
|
|
|
'exact', 'iexact', 'contains', 'icontains', 'gt', 'gte', 'lt', 'lte', 'in',
|
|
|
|
'startswith', 'istartswith', 'endswith', 'iendswith', 'range', 'year',
|
2009-02-08 13:08:06 +08:00
|
|
|
'month', 'day', 'week_day', 'isnull', 'search', 'regex', 'iregex',
|
2012-04-30 10:18:30 +08:00
|
|
|
])
|
Merged the queryset-refactor branch into trunk.
This is a big internal change, but mostly backwards compatible with existing
code. Also adds a couple of new features.
Fixed #245, #1050, #1656, #1801, #2076, #2091, #2150, #2253, #2306, #2400, #2430, #2482, #2496, #2676, #2737, #2874, #2902, #2939, #3037, #3141, #3288, #3440, #3592, #3739, #4088, #4260, #4289, #4306, #4358, #4464, #4510, #4858, #5012, #5020, #5261, #5295, #5321, #5324, #5325, #5555, #5707, #5796, #5817, #5987, #6018, #6074, #6088, #6154, #6177, #6180, #6203, #6658
git-svn-id: http://code.djangoproject.com/svn/django/trunk@7477 bcc190cf-cafb-0310-a4f2-bffc1f526a37
2008-04-27 10:50:16 +08:00
|
|
|
|
|
|
|
# Size of each "chunk" for get_iterator calls.
|
|
|
|
# Larger values are slightly faster at the expense of more storage space.
|
|
|
|
GET_ITERATOR_CHUNK_SIZE = 100
|
|
|
|
|
2012-08-25 21:33:07 +08:00
|
|
|
# Namedtuples for sql.* internal use.
|
|
|
|
|
2008-09-02 10:16:41 +08:00
|
|
|
# Join lists (indexes into the tuples that are values in the alias_map
|
|
|
|
# dictionary in the Query class).
|
2012-04-30 06:50:48 +08:00
|
|
|
JoinInfo = namedtuple('JoinInfo',
|
|
|
|
'table_name rhs_alias join_type lhs_alias '
|
2012-08-25 21:33:07 +08:00
|
|
|
'lhs_join_col rhs_join_col nullable join_field')
|
|
|
|
|
2012-10-26 01:57:32 +08:00
|
|
|
# Pairs of column clauses to select, and (possibly None) field for the clause.
|
|
|
|
SelectInfo = namedtuple('SelectInfo', 'col field')
|
|
|
|
|
Merged the queryset-refactor branch into trunk.
This is a big internal change, but mostly backwards compatible with existing
code. Also adds a couple of new features.
Fixed #245, #1050, #1656, #1801, #2076, #2091, #2150, #2253, #2306, #2400, #2430, #2482, #2496, #2676, #2737, #2874, #2902, #2939, #3037, #3141, #3288, #3440, #3592, #3739, #4088, #4260, #4289, #4306, #4358, #4464, #4510, #4858, #5012, #5020, #5261, #5295, #5321, #5324, #5325, #5555, #5707, #5796, #5817, #5987, #6018, #6074, #6088, #6154, #6177, #6180, #6203, #6658
git-svn-id: http://code.djangoproject.com/svn/django/trunk@7477 bcc190cf-cafb-0310-a4f2-bffc1f526a37
2008-04-27 10:50:16 +08:00
|
|
|
# How many results to expect from a cursor.execute call
|
|
|
|
MULTI = 'multi'
|
|
|
|
SINGLE = 'single'
|
|
|
|
|
2008-04-28 10:27:19 +08:00
|
|
|
ORDER_PATTERN = re.compile(r'\?|[-+]?[.\w]+$')
|
Merged the queryset-refactor branch into trunk.
This is a big internal change, but mostly backwards compatible with existing
code. Also adds a couple of new features.
Fixed #245, #1050, #1656, #1801, #2076, #2091, #2150, #2253, #2306, #2400, #2430, #2482, #2496, #2676, #2737, #2874, #2902, #2939, #3037, #3141, #3288, #3440, #3592, #3739, #4088, #4260, #4289, #4306, #4358, #4464, #4510, #4858, #5012, #5020, #5261, #5295, #5321, #5324, #5325, #5555, #5707, #5796, #5817, #5987, #6018, #6074, #6088, #6154, #6177, #6180, #6203, #6658
git-svn-id: http://code.djangoproject.com/svn/django/trunk@7477 bcc190cf-cafb-0310-a4f2-bffc1f526a37
2008-04-27 10:50:16 +08:00
|
|
|
ORDER_DIR = {
|
|
|
|
'ASC': ('ASC', 'DESC'),
|
2012-04-30 06:50:48 +08:00
|
|
|
'DESC': ('DESC', 'ASC'),
|
|
|
|
}
|