mirror of
https://github.com/sqlalchemy/sqlalchemy.git
synced 2026-05-30 12:34:52 -04:00
d6ce68727f
to rely upon server generated version identifiers, using triggers or other database-provided versioning features, by passing the value ``False``. The ORM will use RETURNING when available to immediately load the new version identifier, else it will emit a second SELECT. [ticket:2793] - The ``eager_defaults`` flag of :class:`.Mapper` will now allow the newly generated default values to be fetched using an inline RETURNING clause, rather than a second SELECT statement, for backends that support RETURNING. - Added a new variant to :meth:`.ValuesBase.returning` called :meth:`.ValuesBase.return_defaults`; this allows arbitrary columns to be added to the RETURNING clause of the statement without interfering with the compilers usual "implicit returning" feature, which is used to efficiently fetch newly generated primary key values. For supporting backends, a dictionary of all fetched values is present at :attr:`.ResultProxy.returned_defaults`. - add a glossary entry for RETURNING - add documentation for version id generation, [ticket:867]
127 lines
5.3 KiB
Python
127 lines
5.3 KiB
Python
# sql/expression.py
|
|
# Copyright (C) 2005-2013 the SQLAlchemy authors and contributors <see AUTHORS file>
|
|
#
|
|
# This module is part of SQLAlchemy and is released under
|
|
# the MIT License: http://www.opensource.org/licenses/mit-license.php
|
|
|
|
"""Defines the public namespace for SQL expression constructs.
|
|
|
|
Prior to version 0.9, this module contained all of "elements", "dml",
|
|
"default_comparator" and "selectable". The module was broken up
|
|
and most "factory" functions were moved to be grouped with their associated
|
|
class.
|
|
|
|
"""
|
|
|
|
__all__ = [
|
|
'Alias', 'ClauseElement', 'ColumnCollection', 'ColumnElement',
|
|
'CompoundSelect', 'Delete', 'FromClause', 'Insert', 'Join', 'Select',
|
|
'Selectable', 'TableClause', 'Update', 'alias', 'and_', 'asc', 'between',
|
|
'bindparam', 'case', 'cast', 'column', 'delete', 'desc', 'distinct',
|
|
'except_', 'except_all', 'exists', 'extract', 'func', 'modifier',
|
|
'collate', 'insert', 'intersect', 'intersect_all', 'join', 'label',
|
|
'literal', 'literal_column', 'not_', 'null', 'nullsfirst', 'nullslast',
|
|
'or_', 'outparam', 'outerjoin', 'over', 'select', 'subquery',
|
|
'table', 'text',
|
|
'tuple_', 'type_coerce', 'union', 'union_all', 'update']
|
|
|
|
|
|
from .visitors import Visitable
|
|
from .functions import func, modifier, FunctionElement
|
|
from ..util.langhelpers import public_factory
|
|
from .elements import ClauseElement, ColumnElement,\
|
|
BindParameter, UnaryExpression, BooleanClauseList, \
|
|
Label, Cast, Case, ColumnClause, TextClause, Over, Null, \
|
|
True_, False_, BinaryExpression, Tuple, TypeClause, Extract, \
|
|
Grouping, and_, or_, not_, \
|
|
collate, literal_column, between,\
|
|
literal, outparam, type_coerce, ClauseList
|
|
|
|
from .elements import SavepointClause, RollbackToSavepointClause, \
|
|
ReleaseSavepointClause
|
|
|
|
from .base import ColumnCollection, Generative, Executable, \
|
|
PARSE_AUTOCOMMIT
|
|
|
|
from .selectable import Alias, Join, Select, Selectable, TableClause, \
|
|
CompoundSelect, FromClause, FromGrouping, SelectBase, \
|
|
alias, \
|
|
subquery, HasPrefixes, Exists, ScalarSelect
|
|
|
|
|
|
from .dml import Insert, Update, Delete, UpdateBase, ValuesBase
|
|
|
|
# factory functions - these pull class-bound constructors and classmethods
|
|
# from SQL elements and selectables into public functions. This allows
|
|
# the functions to be available in the sqlalchemy.sql.* namespace and
|
|
# to be auto-cross-documenting from the function to the class itself.
|
|
|
|
bindparam = public_factory(BindParameter, ".expression.bindparam")
|
|
select = public_factory(Select, ".expression.select")
|
|
text = public_factory(TextClause, ".expression.tet")
|
|
table = public_factory(TableClause, ".expression.table")
|
|
column = public_factory(ColumnClause, ".expression.column")
|
|
over = public_factory(Over, ".expression.over")
|
|
label = public_factory(Label, ".expression.label")
|
|
case = public_factory(Case, ".expression.case")
|
|
cast = public_factory(Cast, ".expression.cast")
|
|
extract = public_factory(Extract, ".expression.extract")
|
|
tuple_ = public_factory(Tuple, ".expression.tuple_")
|
|
except_ = public_factory(CompoundSelect._create_except, ".expression.except_")
|
|
except_all = public_factory(CompoundSelect._create_except_all, ".expression.except_all")
|
|
intersect = public_factory(CompoundSelect._create_intersect, ".expression.intersect")
|
|
intersect_all = public_factory(CompoundSelect._create_intersect_all, ".expression.intersect_all")
|
|
union = public_factory(CompoundSelect._create_union, ".expression.union")
|
|
union_all = public_factory(CompoundSelect._create_union_all, ".expression.union_all")
|
|
exists = public_factory(Exists, ".expression.exists")
|
|
nullsfirst = public_factory(UnaryExpression._create_nullsfirst, ".expression.nullsfirst")
|
|
nullslast = public_factory(UnaryExpression._create_nullslast, ".expression.nullslast")
|
|
asc = public_factory(UnaryExpression._create_asc, ".expression.asc")
|
|
desc = public_factory(UnaryExpression._create_desc, ".expression.desc")
|
|
distinct = public_factory(UnaryExpression._create_distinct, ".expression.distinct")
|
|
true = public_factory(True_, ".expression.true")
|
|
false = public_factory(False_, ".expression.false")
|
|
null = public_factory(Null, ".expression.null")
|
|
join = public_factory(Join._create_join, ".expression.join")
|
|
outerjoin = public_factory(Join._create_outerjoin, ".expression.outerjoin")
|
|
insert = public_factory(Insert, ".expression.insert")
|
|
update = public_factory(Update, ".expression.update")
|
|
delete = public_factory(Delete, ".expression.delete")
|
|
|
|
|
|
|
|
# internal functions still being called from tests and the ORM,
|
|
# these might be better off in some other namespace
|
|
from .base import _from_objects
|
|
from .elements import _literal_as_text, _clause_element_as_expr,\
|
|
_is_column, _labeled, _only_column_elements, _string_or_unprintable, \
|
|
_truncated_label, _clone, _cloned_difference, _cloned_intersection,\
|
|
_column_as_key, _literal_as_binds, _select_iterables, \
|
|
_corresponding_column_or_error
|
|
from .selectable import _interpret_as_from
|
|
|
|
|
|
|
|
# old names for compatibility
|
|
_Executable = Executable
|
|
_BindParamClause = BindParameter
|
|
_Label = Label
|
|
_SelectBase = SelectBase
|
|
_BinaryExpression = BinaryExpression
|
|
_Cast = Cast
|
|
_Null = Null
|
|
_False = False_
|
|
_True = True_
|
|
_TextClause = TextClause
|
|
_UnaryExpression = UnaryExpression
|
|
_Case = Case
|
|
_Tuple = Tuple
|
|
_Over = Over
|
|
_Generative = Generative
|
|
_TypeClause = TypeClause
|
|
_Extract = Extract
|
|
_Exists = Exists
|
|
_Grouping = Grouping
|
|
_FromGrouping = FromGrouping
|
|
_ScalarSelect = ScalarSelect
|