Column Elements and Expressions
The expression API consists of a series of classes each of which represents aspecific lexical element within a SQL string. Composed togetherinto a larger structure, they form a statement construct that maybe compiled into a string representation that can be passed to a database.The classes are organized into ahierarchy that begins at the basemost ClauseElement class. Key subclassesinclude ColumnElement, which represents the role of any column-based expressionin a SQL statement, such as in the columns clause, WHERE clause, and ORDER BYclause, and FromClause, which represents the role of a token that is placed inthe FROM clause of a SELECT statement.
This may apply to an array type for some dialects (e.g. postgresql),or to a subquery for others (e.g. mysql). e.g.:
- # postgresql '5 = ALL (somearray)'
- expr = 5 == all_(mytable.c.somearray)
- # mysql '5 = ALL (SELECT value FROM table)'
- expr = 5 == all_(select([table.c.value]))
New in version 1.1.
See also
sqlalchemy.sql.expression.
and
(*clauses)[](https://docs.sqlalchemy.org/en/13/core/#sqlalchemy.sql.expression.and)- Produce a conjunction of expressions joined by
AND
.
E.g.:
- from sqlalchemy import and_
- stmt = select([users_table]).where(
- and_(
- users_table.c.name == 'wendy',
- users_table.c.enrolled == True
- )
- )
The and_()
conjunction is also available using thePython &
operator (though note that compound expressionsneed to be parenthesized in order to function with Pythonoperator precedence behavior):
- stmt = select([users_table]).where(
- (users_table.c.name == 'wendy') &
- (users_table.c.enrolled == True)
- )
The and_()
operation is also implicit in some cases;the Select.where()
method for example can be invoked multipletimes against a statement, which will have the effect of eachclause being combined using and_()
:
- stmt = select([users_table]). where(users_table.c.name == 'wendy'). where(users_table.c.enrolled == True)
See also
This may apply to an array type for some dialects (e.g. postgresql),or to a subquery for others (e.g. mysql). e.g.:
- # postgresql '5 = ANY (somearray)'
- expr = 5 == any_(mytable.c.somearray)
- # mysql '5 = ANY (SELECT value FROM table)'
- expr = 5 == any_(select([table.c.value]))
New in version 1.1.
See also
e.g.:
- from sqlalchemy import asc
- stmt = select([users_table]).order_by(asc(users_table.c.name))
will produce SQL as:
- SELECT id, name FROM user ORDER BY name ASC
The asc()
function is a standalone version of theColumnElement.asc()
method available on all SQL expressions,e.g.:
- stmt = select([users_table]).order_by(users_table.c.name.asc())
- Parameters
- column – A
ColumnElement
(e.g. scalar SQL expression)with which to apply theasc()
operation.
See also
sqlalchemy.sql.expression.
between
(expr, lower_bound, upper_bound, symmetric=False)- Produce a
BETWEEN
predicate clause.
E.g.:
- from sqlalchemy import between
- stmt = select([users_table]).where(between(users_table.c.id, 5, 7))
Would produce SQL resembling:
- SELECT id, name FROM user WHERE id BETWEEN :id_1 AND :id_2
The between()
function is a standalone version of theColumnElement.between()
method available on allSQL expressions, as in:
- stmt = select([users_table]).where(users_table.c.id.between(5, 7))
All arguments passed to between()
, including the left sidecolumn expression, are coerced from Python scalar values if athe value is not a ColumnElement
subclass. For example,three fixed values can be compared as in:
- print(between(5, 3, 7))
Which would produce:
- :param_1 BETWEEN :param_2 AND :param_3
- Parameters
expr – a column expression, typically a
ColumnElement
instance or alternatively a Python scalar expression to be coercedinto a column expression, serving as the left side of theBETWEEN
expression.lower_bound – a column or Python scalar expression serving as thelower bound of the right side of the
BETWEEN
expression.upper_bound – a column or Python scalar expression serving as theupper bound of the right side of the
BETWEEN
expression.
if True, will render ” BETWEEN SYMMETRIC “. Notethat not all databases support this syntax.
New in version 0.9.5.
See also
sqlalchemy.sql.expression.
bindparam
(key, value=symbol('NO_ARG'), type=None, _unique=False, required=symbol('NO_ARG'), quote=None, callable=None, _expanding=False, isoutparam=False, comparedto_operator=None, comparedto_type=None)- Produce a “bound expression”.
The return value is an instance of BindParameter
; thisis a ColumnElement
subclass which represents a so-called“placeholder” value in a SQL expression, the value of which issupplied at the point at which the statement in executed against adatabase connection.
In SQLAlchemy, the bindparam()
construct hasthe ability to carry along the actual value that will be ultimatelyused at expression time. In this way, it serves not just asa “placeholder” for eventual population, but also as a means ofrepresenting so-called “unsafe” values which should not be rendereddirectly in a SQL statement, but rather should be passed alongto the DBAPI as values which need to be correctly escapedand potentially handled for type-safety.
When using bindparam()
explicitly, the use case is typicallyone of traditional deferment of parameters; the bindparam()
construct accepts a name which can then be referred to at executiontime:
- from sqlalchemy import bindparam
- stmt = select([users_table]).\
- where(users_table.c.name == bindparam('username'))
The above statement, when rendered, will produce SQL similar to:
- SELECT id, name FROM user WHERE name = :username
In order to populate the value of :username
above, the valuewould typically be applied at execution time to a methodlike Connection.execute()
:
- result = connection.execute(stmt, username='wendy')
Explicit use of bindparam()
is also common when producingUPDATE or DELETE statements that are to be invoked multiple times,where the WHERE criterion of the statement is to change on eachinvocation, such as:
- stmt = (users_table.update().
- where(user_table.c.name == bindparam('username')).
- values(fullname=bindparam('fullname'))
- )
- connection.execute(
- stmt, [{"username": "wendy", "fullname": "Wendy Smith"},
- {"username": "jack", "fullname": "Jack Jones"},
- ]
- )
SQLAlchemy’s Core expression system makes wide use ofbindparam()
in an implicit sense. It is typical that Pythonliteral values passed to virtually all SQL expression functions arecoerced into fixed bindparam()
constructs. For example, givena comparison operation such as:
- expr = users_table.c.name == 'Wendy'
The above expression will produce a BinaryExpression
construct, where the left side is the Column
objectrepresenting the name
column, and the right side is aBindParameter
representing the literal value:
- print(repr(expr.right))
- BindParameter('%(4327771088 name)s', 'Wendy', type_=String())
The expression above will render SQL such as:
- user.name = :name_1
Where the :name_1
parameter name is an anonymous name. Theactual string Wendy
is not in the rendered string, but is carriedalong where it is later used within statement execution. If weinvoke a statement like the following:
- stmt = select([users_table]).where(users_table.c.name == 'Wendy')
- result = connection.execute(stmt)
We would see SQL logging output as:
- SELECT "user".id, "user".name
- FROM "user"
- WHERE "user".name = %(name_1)s
- {'name_1': 'Wendy'}
Above, we see that Wendy
is passed as a parameter to the database,while the placeholder :name_1
is rendered in the appropriate formfor the target database, in this case the PostgreSQL database.
Similarly, bindparam()
is invoked automaticallywhen working with CRUD statements as far as the “VALUES”portion is concerned. The insert()
construct produces anINSERT
expression which will, at statement execution time,generate bound placeholders based on the arguments passed, as in:
- stmt = users_table.insert()
- result = connection.execute(stmt, name='Wendy')
The above will produce SQL output as:
- INSERT INTO "user" (name) VALUES (%(name)s)
- {'name': 'Wendy'}
The Insert
construct, at compilation/execution time,rendered a single bindparam()
mirroring the columnname name
as a result of the single name
parameterwe passed to the Connection.execute()
method.
- Parameters
key – the key (e.g. the name) for this bind param.Will be used in the generatedSQL statement for dialects that use named parameters. Thisvalue may be modified when part of a compilation operation,if other
BindParameter
objects exist with the samekey, or if its length is too long and truncation isrequired.value – Initial value for this bind param. Will be used at statementexecution time as the value for this parameter passed to theDBAPI, if no other value is indicated to the statement executionmethod for this particular parameter name. Defaults to
None
.callable_ – A callable function that takes the place of “value”. The functionwill be called at statement execution time to determine theultimate value. Used for scenarios where the actual bindvalue cannot be determined at the point at which the clauseconstruct is created, but embedded bind values are still desirable.
A TypeEngine
class or instance representing an optionaldatatype for this bindparam()
. If not passed, a typemay be determined automatically for the bind, based on the givenvalue; for example, trivial Python types such as str
,int
, bool
may result in the String
, Integer
orBoolean
types being automatically selected.
The type of a bindparam()
is significant especially in thatthe type will apply pre-processing to the value before it ispassed to the database. For example, a bindparam()
whichrefers to a datetime value, and is specified as holding theDateTime
type, may apply conversion needed to thevalue (such as stringification on SQLite) before passing the valueto the database.
-
unique – if True, the key name of this BindParameter
will bemodified if another BindParameter
of the same namealready has been located within the containingexpression. This flag is used generally by the internalswhen producing so-called “anonymous” bound expressions, itisn’t generally applicable to explicitly-named bindparam()
constructs.
-
required – If True
, a value is required at execution time. If not passed,it defaults to True
if neither bindparam.value
or bindparam.callable
were passed. If either of theseparameters are present, then bindparam.required
defaults to False
.
-
quote – True if this parameter name requires quoting and is notcurrently known as a SQLAlchemy reserved word; this currentlyonly applies to the Oracle backend, where bound names mustsometimes be quoted.
-
isoutparam – if True, the parameter should be treated like a stored procedure“OUT” parameter. This applies to backends such as Oracle whichsupport OUT parameters.
-
if True, this parameter will be treated as an “expanding” parameterat execution time; the parameter value is expected to be a sequence,rather than a scalar value, and the string SQL statement willbe transformed on a per-execution basis to accommodate the sequencewith a variable number of parameter slots passed to the DBAPI.This is to allow statement caching to be used in conjunction withan IN clause.
See also
Using IN expressions - with baked queries
Note
The “expanding” feature does not support “executemany”-style parameter sets.
New in version 1.2.
Changed in version 1.3: the “expanding” bound parameter feature nowsupports empty lists.
See also
The CASE
construct in SQL is a conditional object thatacts somewhat analogously to an “if/then” construct in otherlanguages. It returns an instance of Case
.
case()
in its usual form is passed a list of “when”constructs, that is, a list of conditions and results as tuples:
- from sqlalchemy import case
- stmt = select([users_table]).\
- where(
- case(
- [
- (users_table.c.name == 'wendy', 'W'),
- (users_table.c.name == 'jack', 'J')
- ],
- else_='E'
- )
- )
The above statement will produce SQL resembling:
- SELECT id, name FROM user
- WHERE CASE
- WHEN (name = :name_1) THEN :param_1
- WHEN (name = :name_2) THEN :param_2
- ELSE :param_3
- END
When simple equality expressions of several values against a singleparent column are needed, case()
also has a “shorthand” formatused via thecase.value
parameter, which is passed a columnexpression to be compared. In this form, the case.whens
parameter is passed as a dictionary containing expressions to becompared against keyed to result expressions. The statement below isequivalent to the preceding statement:
- stmt = select([users_table]).\
- where(
- case(
- {"wendy": "W", "jack": "J"},
- value=users_table.c.name,
- else_='E'
- )
- )
The values which are accepted as result values incase.whens
as well as with case.else_
arecoerced from Python literals into bindparam()
constructs.SQL expressions, e.g. ColumnElement
constructs, are acceptedas well. To coerce a literal string expression into a constantexpression rendered inline, use the literal_column()
construct,as in:
- from sqlalchemy import case, literal_column
- case(
- [
- (
- orderline.c.qty > 100,
- literal_column("'greaterthan100'")
- ),
- (
- orderline.c.qty > 10,
- literal_column("'greaterthan10'")
- )
- ],
- else_=literal_column("'lessthan10'")
- )
The above will render the given constants without using boundparameters for the result values (but still for the comparisonvalues), as in:
- CASE
- WHEN (orderline.qty > :qty_1) THEN 'greaterthan100'
- WHEN (orderline.qty > :qty_2) THEN 'greaterthan10'
- ELSE 'lessthan10'
- END
The criteria to be compared against,case.whens
accepts two different forms, based onwhether or not case.value
is used.
In the first form, it accepts a list of 2-tuples; each 2-tupleconsists of (<sql expression>, <value>)
, where the SQLexpression is a boolean expression and “value” is a resulting value,e.g.:
- case([
- (users_table.c.name == 'wendy', 'W'),
- (users_table.c.name == 'jack', 'J')
- ])
In the second form, it accepts a Python dictionary of comparisonvalues mapped to a resulting value; this form requirescase.value
to be present, and values will be comparedusing the ==
operator, e.g.:
- case(
- {"wendy": "W", "jack": "J"},
- value=users_table.c.name
- )
-
value – An optional SQL expression which will be used as afixed “comparison point” for candidate values within a dictionarypassed to case.whens
.
-
else_ – An optional SQL expression which will be the evaluatedresult of the CASE
construct if all expressions withincase.whens
evaluate to false. When omitted, mostdatabases will produce a result of NULL if none of the “when”expressions evaluate to true.
cast()
returns an instance of Cast
.
E.g.:
- from sqlalchemy import cast, Numeric
- stmt = select([
- cast(product_table.c.unit_price, Numeric(10, 4))
- ])
The above statement will produce SQL resembling:
- SELECT CAST(unit_price AS NUMERIC(10, 4)) FROM product
The cast()
function performs two distinct functions whenused. The first is that it renders the CAST
expression withinthe resulting SQL string. The second is that it associates the giventype (e.g. TypeEngine
class or instance) with the columnexpression on the Python side, which means the expression will takeon the expression operator behavior associated with that type,as well as the bound-value handling and result-row-handling behaviorof the type.
Changed in version 0.9.0: cast()
now applies the given typeto the expression such that it takes effect on the bound-value,e.g. the Python-to-database direction, in addition to theresult handling, e.g. database-to-Python, direction.
An alternative to cast()
is the type_coerce()
function.This function performs the second task of associating an expressionwith a specific type, but does not render the CAST
expressionin SQL.
- Parameters
expression – A SQL expression, such as a
ColumnElement
expression or a Python string which will be coerced into a boundliteral value.type_ – A
TypeEngine
class or instance indicatingthe type to which theCAST
should apply.
See also
type_coerce()
- an alternative to CAST that coerces the typeon the Python side only, which is often sufficient to generate thecorrect SQL and data coercion.
sqlalchemy.sql.expression.
column
(text, type=None, _is_literal=False, _selectable=None)- Produce a
ColumnClause
object.
The ColumnClause
is a lightweight analogue to theColumn
class. The column()
function canbe invoked with just a name alone, as in:
- from sqlalchemy import column
- id, name = column("id"), column("name")
- stmt = select([id, name]).select_from("user")
The above statement would produce SQL like:
- SELECT id, name FROM user
Once constructed, column()
may be used like any other SQLexpression element such as within select()
constructs:
- from sqlalchemy.sql import column
- id, name = column("id"), column("name")
- stmt = select([id, name]).select_from("user")
The text handled by column()
is assumed to be handledlike the name of a database column; if the string contains mixed case,special characters, or matches a known reserved word on the targetbackend, the column expression will render using the quotingbehavior determined by the backend. To produce a textual SQLexpression that is rendered exactly without any quoting,use literal_column()
instead, or pass True
as thevalue of column.is_literal
. Additionally, full SQLstatements are best handled using the text()
construct.
column()
can be used in a table-likefashion by combining it with the table()
function(which is the lightweight analogue to Table
) to producea working table construct with minimal boilerplate:
- from sqlalchemy import table, column, select
- user = table("user",
- column("id"),
- column("name"),
- column("description"),
- )
- stmt = select([user.c.description]).where(user.c.name == 'wendy')
A column()
/ table()
construct like that illustratedabove can be created in anad-hoc fashion and is not associated with anyschema.MetaData
, DDL, or events, unlike itsTable
counterpart.
Changed in version 1.0.0: expression.column()
can nowbe imported from the plain sqlalchemy
namespace like anyother SQL element.
- Parameters
type –
types.TypeEngine
object which can associatethisColumnClause
with a type.is_literal – if True, the
ColumnClause
is assumed tobe an exact expression that will be delivered to the output with noquoting rules applied regardless of case sensitive settings. theliteral_column()
function essentially invokescolumn()
while passingis_literal=True
.
See also
Using More Specific Text with table(), literal_column(), and column()
sqlalchemy.sql.expression.
collate
(expression, collation)- Return the clause
expression COLLATE collation
.
e.g.:
- collate(mycolumn, 'utf8_bin')
produces:
- mycolumn COLLATE utf8_bin
The collation expression is also quoted if it is a case sensitiveidentifier, e.g. contains uppercase characters.
Changed in version 1.2: quoting is automatically applied to COLLATEexpressions if they are case sensitive.
e.g.:
- from sqlalchemy import desc
- stmt = select([users_table]).order_by(desc(users_table.c.name))
will produce SQL as:
- SELECT id, name FROM user ORDER BY name DESC
The desc()
function is a standalone version of theColumnElement.desc()
method available on all SQL expressions,e.g.:
- stmt = select([users_table]).order_by(users_table.c.name.desc())
- Parameters
- column – A
ColumnElement
(e.g. scalar SQL expression)with which to apply thedesc()
operation.
See also
This applies the DISTINCT
keyword to an individual columnexpression, and is typically contained within an aggregate function,as in:
- from sqlalchemy import distinct, func
- stmt = select([func.count(distinct(users_table.c.name))])
The above would produce an expression resembling:
- SELECT COUNT(DISTINCT name) FROM user
The distinct()
function is also available as a column-levelmethod, e.g. ColumnElement.distinct()
, as in:
- stmt = select([func.count(users_table.c.name.distinct())])
The distinct()
operator is different from theSelect.distinct()
method of Select
,which produces a SELECT
statementwith DISTINCT
applied to the result set as a whole,e.g. a SELECT DISTINCT
expression. See that method for furtherinformation.
See also
sqlalchemy.sql.expression.
extract
(field, expr, **kwargs)- Return a
Extract
construct.
This is typically available as extract()
as well as func.extract
from thefunc
namespace.
sqlalchemy.sql.expression.
false
()- Return a
False_
construct.
E.g.:
- >>> from sqlalchemy import false
- >>> print select([t.c.x]).where(false())
- SELECT x FROM t WHERE false
A backend which does not support true/false constants will render asan expression against 1 or 0:
- >>> print select([t.c.x]).where(false())
- SELECT x FROM t WHERE 0 = 1
The true()
and false()
constants also feature“short circuit” operation within an and_()
or or_()
conjunction:
- >>> print select([t.c.x]).where(or_(t.c.x > 5, true()))
- SELECT x FROM t WHERE true
- >>> print select([t.c.x]).where(and_(t.c.x > 5, false()))
- SELECT x FROM t WHERE false
Changed in version 0.9: true()
and false()
featurebetter integrated behavior within conjunctions and on dialectsthat don’t support true/false constants.
See also
sqlalchemy.sql.expression.
func
=- Generate
Function
objects based on getattr calls. sqlalchemy.sql.expression.
funcfilter
(func, *criterion)- Produce a
FunctionFilter
object against a function.
Used against aggregate and window functions,for database backends that support the “FILTER” clause.
E.g.:
- from sqlalchemy import funcfilter
- funcfilter(func.count(1), MyClass.name == 'some name')
Would produce “COUNT(1) FILTER (WHERE myclass.name = ‘some name’)”.
This function is also available from the func
construct itself via the FunctionElement.filter()
method.
New in version 1.0.0.
See also
sqlalchemy.sql.expression.
label
(name, element, type=None_)- Return a
Label
object for thegivenColumnElement
.
A label changes the name of an element in the columns clause of aSELECT
statement, typically via the AS
SQL keyword.
This functionality is more conveniently available via theColumnElement.label()
method on ColumnElement
.
- Parameters
obj – a
ColumnElement
.
sqlalchemy.sql.expression.
literal
(value, type=None_)- Return a literal clause, bound to a bind parameter.
Literal clauses are created automatically when non-ClauseElement
objects (such as strings, ints, dates, etc.) areused in a comparison operation with a ColumnElement
subclass,such as a Column
object. Use this functionto force the generation of a literal clause, which will be created as aBindParameter
with a bound value.
- Parameters
value – the value to be bound. Can be any Python object supported bythe underlying DB-API, or is translatable via the given type argument.
type_ – an optional
TypeEngine
whichwill provide bind-parameter translation for this literal.
sqlalchemy.sql.expression.
literalcolumn
(_text, type=None_)- Produce a
ColumnClause
object that has thecolumn.is_literal
flag set to True.
literal_column()
is similar to column()
, except thatit is more often used as a “standalone” column expression that rendersexactly as stated; while column()
stores a string name thatwill be assumed to be part of a table and may be quoted as such,literal_column()
can be that, or any other arbitrary column-orientedexpression.
- Parameters
text – the text of the expression; can be any SQL expression.Quoting rules will not be applied. To specify a column-name expressionwhich should be subject to quoting rules, use the
column()
function.type_ – an optional
TypeEngine
object which willprovide result-set translation and additional expression semantics forthis column. If left as None the type will be NullType.
See also
Using More Specific Text with table(), literal_column(), and column()
The ~
operator is also overloaded on allColumnElement
subclasses to produce thesame result.
sqlalchemy.sql.expression.
null
()Return a constant
Null
construct.- Produce the
NULLS FIRST
modifier for anORDER BY
expression.
nullsfirst()
is intended to modify the expression producedby asc()
or desc()
, and indicates how NULL valuesshould be handled when they are encountered during ordering:
- from sqlalchemy import desc, nullsfirst
- stmt = select([users_table]). order_by(nullsfirst(desc(users_table.c.name)))
The SQL expression from the above would resemble:
- SELECT id, name FROM user ORDER BY name DESC NULLS FIRST
Like asc()
and desc()
, nullsfirst()
is typicallyinvoked from the column expression itself usingColumnElement.nullsfirst()
, rather than as its standalonefunction version, as in:
- stmt = (select([users_table]).
- order_by(users_table.c.name.desc().nullsfirst())
- )
See also
sqlalchemy.sql.expression.
nullslast
(column)- Produce the
NULLS LAST
modifier for anORDER BY
expression.
nullslast()
is intended to modify the expression producedby asc()
or desc()
, and indicates how NULL valuesshould be handled when they are encountered during ordering:
- from sqlalchemy import desc, nullslast
- stmt = select([users_table]). order_by(nullslast(desc(users_table.c.name)))
The SQL expression from the above would resemble:
- SELECT id, name FROM user ORDER BY name DESC NULLS LAST
Like asc()
and desc()
, nullslast()
is typicallyinvoked from the column expression itself usingColumnElement.nullslast()
, rather than as its standalonefunction version, as in:
- stmt = select([users_table]). order_by(users_table.c.name.desc().nullslast())
See also
sqlalchemy.sql.expression.
or
(*clauses)[](https://docs.sqlalchemy.org/en/13/core/#sqlalchemy.sql.expression.or)- Produce a conjunction of expressions joined by
OR
.
E.g.:
- from sqlalchemy import or_
- stmt = select([users_table]).where(
- or_(
- users_table.c.name == 'wendy',
- users_table.c.name == 'jack'
- )
- )
The or_()
conjunction is also available using thePython |
operator (though note that compound expressionsneed to be parenthesized in order to function with Pythonoperator precedence behavior):
- stmt = select([users_table]).where(
- (users_table.c.name == 'wendy') |
- (users_table.c.name == 'jack')
- )
See also
sqlalchemy.sql.expression.
outparam
(key, type=None_)- Create an ‘OUT’ parameter for usage in functions (stored procedures),for databases which support them.
The outparam
can be used like a regular function parameter.The “output” value will be available from theResultProxy
object via its out_parameters
attribute, which returns a dictionary containing the values.
sqlalchemy.sql.expression.
over
(element, partition_by=None, order_by=None, range=None, _rows=None)- Produce an
Over
object against a function.
Used against aggregate or so-called “window” functions,for database backends that support window functions.
over()
is usually called usingthe FunctionElement.over()
method, e.g.:
- func.row_number().over(order_by=mytable.c.some_column)
Would produce:
- ROW_NUMBER() OVER(ORDER BY some_column)
Ranges are also possible using the expression.over.range_
and expression.over.rows
parameters. Thesemutually-exclusive parameters each accept a 2-tuple, which containsa combination of integers and None:
- func.row_number().over(
- order_by=my_table.c.some_column, range_=(None, 0))
The above would produce:
- ROW_NUMBER() OVER(ORDER BY some_column
- RANGE BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW)
A value of None indicates “unbounded”, avalue of zero indicates “current row”, and negative / positiveintegers indicate “preceding” and “following”:
- RANGE BETWEEN 5 PRECEDING AND 10 FOLLOWING:
- func.row_number().over(order_by='x', range_=(-5, 10))
- ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW:
- func.row_number().over(order_by='x', rows=(None, 0))
- RANGE BETWEEN 2 PRECEDING AND UNBOUNDED FOLLOWING:
- func.row_number().over(order_by='x', range_=(-2, None))
- RANGE BETWEEN 1 FOLLOWING AND 3 FOLLOWING:
- func.row_number().over(order_by='x', range_=(1, 3))
New in version 1.1: support for RANGE / ROWS within a window
- Parameters
element – a
FunctionElement
,WithinGroup
,or other compatible construct.partition_by – a column element or string, or a listof such, that will be used as the PARTITION BY clauseof the OVER construct.
order_by – a column element or string, or a listof such, that will be used as the ORDER BY clauseof the OVER construct.
optional range clause for the window. This is atuple value which can contain integer values or None, and willrender a RANGE BETWEEN PRECEDING / FOLLOWING clause
New in version 1.1.
-
optional rows clause for the window. This is a tuplevalue which can contain integer values or None, and will rendera ROWS BETWEEN PRECEDING / FOLLOWING clause.
New in version 1.1.
This function is also available from the func
construct itself via the FunctionElement.over()
method.
See also
sqlalchemy.sql.expression.
text
(text, bind=None, bindparams=None, typemap=None, autocommit=None)- Construct a new
TextClause
clause, representinga textual SQL string directly.
E.g.:
- from sqlalchemy import text
- t = text("SELECT * FROM users")
- result = connection.execute(t)
The advantages text()
provides over a plain string arebackend-neutral support for bind parameters, per-statementexecution options, as well asbind parameter and result-column typing behavior, allowingSQLAlchemy type constructs to play a role when executinga statement that is specified literally. The construct can alsobe provided with a .c
collection of column elements, allowingit to be embedded in other SQL expression constructs as a subquery.
Bind parameters are specified by name, using the format :name
.E.g.:
- t = text("SELECT * FROM users WHERE id=:user_id")
- result = connection.execute(t, user_id=12)
For SQL statements where a colon is required verbatim, as withinan inline string, use a backslash to escape:
- t = text("SELECT * FROM users WHERE name='\:username'")
The TextClause
construct includes methods which canprovide information about the bound parameters as well as the columnvalues which would be returned from the textual statement, assumingit’s an executable SELECT type of statement. TheTextClause.bindparams()
method is used to provide boundparameter detail, and TextClause.columns()
method allowsspecification of return columns including names and types:
- t = text("SELECT * FROM users WHERE id=:user_id").\
- bindparams(user_id=7).\
- columns(id=Integer, name=String)
- for id, name in connection.execute(t):
- print(id, name)
The text()
construct is used in cases whena literal string SQL fragment is specified as part of a larger query,such as for the WHERE clause of a SELECT statement:
- s = select([users.c.id, users.c.name]).where(text("id=:user_id"))
- result = connection.execute(s, user_id=12)
text()
is also used for the constructionof a full, standalone statement using plain text.As such, SQLAlchemy refersto it as an Executable
object, and it supportsthe Executable.execution_options()
method. For example,a text()
construct that should be subject to “autocommit”can be set explicitly so using theConnection.execution_options.autocommit
option:
- t = text("EXEC my_procedural_thing()").\
- execution_options(autocommit=True)
Note that SQLAlchemy’s usual “autocommit” behavior applies totext()
constructs implicitly - that is, statements which beginwith a phrase such as INSERT
, UPDATE
, DELETE
,or a variety of other phrases specific to certain backends, willbe eligible for autocommit if no transaction is in progress.
the text of the SQL statement to be created. use :<param>
to specify bind parameters; they will be compiled to theirengine-specific format.
Warning
The text.text
argument to text()
can be passed as a Python string argument, which will be treated as trusted SQL text and rendered as given. DO NOT PASS UNTRUSTED INPUT TO THIS PARAMETER.
-
whether or not to set the “autocommit” executionoption for this TextClause
object.
Deprecated since version 0.6: The text.autocommit
parameter is deprecated and will be removed in a future release. Please use the Connection.execution_options.autocommit
parameter in conjunction with the Executable.execution_options()
method.
-
bind – an optional connection or engine to be used for this text query.
-
A list of bindparam()
instances used toprovide information about parameters embedded in the statement.
Deprecated since version 0.9: The text.bindparams
parameter is deprecated and will be removed in a future release. Please refer to the TextClause.bindparams()
method.
E.g.:
- stmt = text("SELECT * FROM table WHERE id=:id",
- bindparams=[bindparam('id', value=5, type_=Integer)])
-
A dictionary mapping the names of columns represented in the columnsclause of a SELECT
statement to type objects.
Deprecated since version 0.9: The text.typemap
parameter is deprecated and will be removed in a future release. Please refer to the TextClause.columns()
method.
E.g.:
- stmt = text("SELECT * FROM table",
- typemap={'id': Integer, 'name': String},
- )
See also
Using Textual SQL - in the Core tutorial
Using Textual SQL - in the ORM tutorial
sqlalchemy.sql.expression.
true
()- Return a constant
True_
construct.
E.g.:
- >>> from sqlalchemy import true
- >>> print select([t.c.x]).where(true())
- SELECT x FROM t WHERE true
A backend which does not support true/false constants will render asan expression against 1 or 0:
- >>> print select([t.c.x]).where(true())
- SELECT x FROM t WHERE 1 = 1
The true()
and false()
constants also feature“short circuit” operation within an and_()
or or_()
conjunction:
- >>> print select([t.c.x]).where(or_(t.c.x > 5, true()))
- SELECT x FROM t WHERE true
- >>> print select([t.c.x]).where(and_(t.c.x > 5, false()))
- SELECT x FROM t WHERE false
Changed in version 0.9: true()
and false()
featurebetter integrated behavior within conjunctions and on dialectsthat don’t support true/false constants.
See also
sqlalchemy.sql.expression.
tuple
(clauses, *kw)[](https://docs.sqlalchemy.org/en/13/core/#sqlalchemy.sql.expression.tuple)- Return a
Tuple
.
Main usage is to produce a composite IN construct usingColumnOperators.in_()
- from sqlalchemy import tuple_
- tuple_(table.c.col1, table.c.col2).in_(
- [(1, 2), (5, 12), (10, 19)]
- )
Changed in version 1.3.6: Added support for SQLite IN tuples.
Warning
The composite IN construct is not supported by all backends, and iscurrently known to work on PostgreSQL, MySQL, and SQLite.Unsupported backends will raise a subclass ofDBAPIError
when such an expression isinvoked.
sqlalchemy.sql.expression.
typecoerce
(_expression, type_)- Associate a SQL expression with a particular type, without rendering
CAST
.
E.g.:
- from sqlalchemy import type_coerce
- stmt = select([
- type_coerce(log_table.date_string, StringDateTime())
- ])
The above construct will produce a TypeCoerce
object, whichrenders SQL that labels the expression, but otherwise does notmodify its value on the SQL side:
- SELECT date_string AS anon_1 FROM log
When result rows are fetched, the StringDateTime
typewill be applied to result rows on behalf of the date_string
column.The rationale for the “anon_1” label is so that the type-coercedcolumn remains separate in the list of result columns vs. othertype-coerced or direct values of the target column. In order toprovide a named label for the expression, useColumnElement.label()
:
- stmt = select([
- type_coerce(
- log_table.date_string, StringDateTime()).label('date')
- ])
A type that features bound-value handling will also have that behaviortake effect when literal values or bindparam()
constructs arepassed to type_coerce()
as targets.For example, if a type implements theTypeEngine.bind_expression()
method or TypeEngine.bind_processor()
method or equivalent,these functions will take effect at statement compilation/executiontime when a literal value is passed, as in:
- # bound-value handling of MyStringType will be applied to the
- # literal value "some string"
- stmt = select([type_coerce("some string", MyStringType)])
type_coerce()
is similar to the cast()
function,except that it does not render the CAST
expression in the resultingstatement.
- Parameters
expression – A SQL expression, such as a
ColumnElement
expression or a Python string which will be coerced into a boundliteral value.type_ – A
TypeEngine
class or instance indicatingthe type to which the expression is coerced.
See also
sqlalchemy.sql.expression.
withingroup
(_element, *order_by)- Produce a
WithinGroup
object against a function.
Used against so-called “ordered set aggregate” and “hypotheticalset aggregate” functions, including percentile_cont
,rank
, dense_rank
, etc.
within_group()
is usually called usingthe FunctionElement.within_group()
method, e.g.:
- from sqlalchemy import within_group
- stmt = select([
- department.c.id,
- func.percentile_cont(0.5).within_group(
- department.c.salary.desc()
- )
- ])
The above statement would produce SQL similar toSELECT department.id, percentile_cont(0.5)WITHIN GROUP (ORDER BY department.salary DESC)
.
- Parameters
element – a
FunctionElement
construct, typicallygenerated byfunc
.*order_by – one or more column elements that will be usedas the ORDER BY clause of the WITHIN GROUP construct.
New in version 1.1.
See also
- class
sqlalchemy.sql.expression.
BinaryExpression
(left, right, operator, type=None, _negate=None, modifiers=None) - Bases:
sqlalchemy.sql.expression.ColumnElement
Represent an expression that is LEFT <operator> RIGHT
.
A BinaryExpression
is generated automaticallywhenever two column expressions are used in a Python binary expression:
- >>> from sqlalchemy.sql import column
- >>> column('a') + column('b')
- <sqlalchemy.sql.expression.BinaryExpression object at 0x101029dd0>
- >>> print column('a') + column('b')
- a + b
compare
(other, **kw)Compare this
BinaryExpression
against thegivenBinaryExpression
.- Return immediate child elements of this
ClauseElement
.
This is used for visit traversal.
**kwargs may contain flags that change the collection that isreturned, for example to return a subset of items in order tocut down on larger traversals, or to return child items from adifferent context (such as schema-level collections instead ofclause-level).
selfgroup
(_against=None)- Apply a ‘grouping’ to this
ClauseElement
.
This method is overridden by subclasses to return a“grouping” construct, i.e. parenthesis. In particularit’s used by “binary” expressions to provide a groupingaround themselves when placed into a larger expression,as well as by select()
constructs when placed intothe FROM clause of another select()
. (Note thatsubqueries should be normally created using theSelect.alias()
method, as many platforms requirenested SELECT statements to be named).
As expressions are composed together, the application ofself_group()
is automatic - end-user code should neverneed to use this method directly. Note that SQLAlchemy’sclause constructs take operator precedence into account -so parenthesis might not be needed, for example, inan expression like x OR (y AND z)
- AND takes precedenceover OR.
The base self_group()
method of ClauseElement
just returns self.
- class
sqlalchemy.sql.expression.
BindParameter
(key, value=symbol('NO_ARG'), type=None, _unique=False, required=symbol('NO_ARG'), quote=None, callable=None, _expanding=False, isoutparam=False, comparedto_operator=None, comparedto_type=None) - Bases:
sqlalchemy.sql.expression.ColumnElement
Represent a “bound expression”.
BindParameter
is invoked explicitly using thebindparam()
function, as in:
- from sqlalchemy import bindparam
- stmt = select([users_table]).\
- where(users_table.c.name == bindparam('username'))
Detailed discussion of how BindParameter
is used isat bindparam()
.
See also
init
(key, value=symbol('NO_ARG'), type=None, _unique=False, required=symbol('NO_ARG'), quote=None, callable=None, _expanding=False, isoutparam=False, comparedto_operator=None, comparedto_type=None)- Construct a new
BindParameter
object.
This constructor is mirrored as a public API function; see bindparam()
for a full usage and argument description.
compare
(other, **kw)Compare this
BindParameter
to the givenclause.- Return the value of this bound parameter,taking into account if the
callable
parameterwas set.
The callable
value will be evaluatedand returned if present, else value
.
- class
sqlalchemy.sql.expression.
Case
(whens, value=None, else=None_) - Bases:
sqlalchemy.sql.expression.ColumnElement
Represent a CASE
expression.
Case
is produced using the case()
factory function,as in:
- from sqlalchemy import case
- stmt = select([users_table]). where(
- case(
- [
- (users_table.c.name == 'wendy', 'W'),
- (users_table.c.name == 'jack', 'J')
- ],
- else_='E'
- )
- )
Details on Case
usage is at case()
.
See also
init
(whens, value=None, else=None)[](https://docs.sqlalchemy.org/en/13/core/#sqlalchemy.sql.expression.Case.__init_)- Construct a new
Case
object.
This constructor is mirrored as a public API function; see case()
for a full usage and argument description.
getchildren
(**kwargs_)- Return immediate child elements of this
ClauseElement
.
This is used for visit traversal.
**kwargs may contain flags that change the collection that isreturned, for example to return a subset of items in order tocut down on larger traversals, or to return child items from adifferent context (such as schema-level collections instead ofclause-level).
- class
sqlalchemy.sql.expression.
Cast
(expression, type_) - Bases:
sqlalchemy.sql.expression.ColumnElement
Represent a CAST
expression.
Cast
is produced using the cast()
factory function,as in:
- from sqlalchemy import cast, Numeric
- stmt = select([
- cast(product_table.c.unit_price, Numeric(10, 4))
- ])
Details on Cast
usage is at cast()
.
See also
type_coerce()
- an alternative to CAST that coerces the typeon the Python side only, which is often sufficient to generate thecorrect SQL and data coercion.
init
(expression, type)[](https://docs.sqlalchemy.org/en/13/core/#sqlalchemy.sql.expression.Cast.init_)- Construct a new
Cast
object.
This constructor is mirrored as a public API function; see cast()
for a full usage and argument description.
getchildren
(**kwargs_)- Return immediate child elements of this
ClauseElement
.
This is used for visit traversal.
**kwargs may contain flags that change the collection that isreturned, for example to return a subset of items in order tocut down on larger traversals, or to return child items from adifferent context (such as schema-level collections instead ofclause-level).
- class
sqlalchemy.sql.expression.
ClauseElement
- Bases:
sqlalchemy.sql.visitors.Visitable
Base class for elements of a programmatically constructed SQLexpression.
Subclasses should override the default behavior, which is astraight identity comparison.
**kw are arguments consumed by subclass compare() methods andmay be used to modify the criteria for comparison.(see ColumnElement
)
The return value is a Compiled
object.Calling str()
or unicode()
on the returned value will yield astring representation of the result. TheCompiled
object also can return adictionary of bind parameter names and valuesusing the params
accessor.
- Parameters
-
-
bind – An Engine
or Connection
from which aCompiled
will be acquired. This argument takes precedence overthis ClauseElement
’s bound engine, if any.
-
column_keys – Used for INSERT and UPDATE statements, a list ofcolumn names which should be present in the VALUES clause of thecompiled statement. If None
, all columns from the target tableobject are rendered.
-
dialect – A Dialect
instance from which a Compiled
will be acquired. This argument takes precedence over the _bind_argument as well as this ClauseElement
’s bound engine,if any.
-
inline – Used for INSERT statements, for a dialect which doesnot support inline retrieval of newly generated primary keycolumns, will force the expression used to create the new primarykey value to be rendered inline within the INSERT statement’sVALUES clause. This typically refers to Sequence execution but mayalso refer to any server-side default generation functionassociated with a primary key Column.
-
optional dictionary of additional parametersthat will be passed through to the compiler within all “visit”methods. This allows any custom flag to be passed through toa custom compilation construct, for example. It is also usedfor the case of passing the literal_binds
flag through:
- from sqlalchemy.sql import table, column, select
- t = table('t', column('x'))
- s = select([t]).where(t.c.x == 5)
- print s.compile(compile_kwargs={"literal_binds": True})
New in version 0.9.0.
See also
How do I render SQL expressions as strings, possibly with bound parameters inlined?
getchildren
(**kwargs_)- Return immediate child elements of this
ClauseElement
.
This is used for visit traversal.
**kwargs may contain flags that change the collection that isreturned, for example to return a subset of items in order tocut down on larger traversals, or to return child items from adifferent context (such as schema-level collections instead ofclause-level).
params
(*optionaldict, **kwargs)- Return a copy with
bindparam()
elements replaced.
Returns a copy of this ClauseElement with bindparam()
elements replaced with values taken from the given dictionary:
- >>> clause = column('x') + bindparam('foo')
- >>> print clause.compile().params
- {'foo':None}
- >>> print clause.params({'foo':7}).compile().params
- {'foo':7}
selfgroup
(_against=None)- Apply a ‘grouping’ to this
ClauseElement
.
This method is overridden by subclasses to return a“grouping” construct, i.e. parenthesis. In particularit’s used by “binary” expressions to provide a groupingaround themselves when placed into a larger expression,as well as by select()
constructs when placed intothe FROM clause of another select()
. (Note thatsubqueries should be normally created using theSelect.alias()
method, as many platforms requirenested SELECT statements to be named).
As expressions are composed together, the application ofself_group()
is automatic - end-user code should neverneed to use this method directly. Note that SQLAlchemy’sclause constructs take operator precedence into account -so parenthesis might not be needed, for example, inan expression like x OR (y AND z)
- AND takes precedenceover OR.
The base self_group()
method of ClauseElement
just returns self.
uniqueparams
(optionaldict, *kwargs_)- Return a copy with
bindparam()
elements replaced.
Same functionality as params()
, except adds _unique=True_to affected bind parameters so that multiple statements can beused.
- class
sqlalchemy.sql.expression.
ClauseList
(*clauses, **kwargs) - Bases:
sqlalchemy.sql.expression.ClauseElement
Describe a list of clauses, separated by an operator.
By default, is comma-separated, such as a column listing.
compare
(other, **kw)Compare this
ClauseList
to the givenClauseList
,including a comparison of all the clause items.- Return immediate child elements of this
ClauseElement
.
This is used for visit traversal.
**kwargs may contain flags that change the collection that isreturned, for example to return a subset of items in order tocut down on larger traversals, or to return child items from adifferent context (such as schema-level collections instead ofclause-level).
selfgroup
(_against=None)- Apply a ‘grouping’ to this
ClauseElement
.
This method is overridden by subclasses to return a“grouping” construct, i.e. parenthesis. In particularit’s used by “binary” expressions to provide a groupingaround themselves when placed into a larger expression,as well as by select()
constructs when placed intothe FROM clause of another select()
. (Note thatsubqueries should be normally created using theSelect.alias()
method, as many platforms requirenested SELECT statements to be named).
As expressions are composed together, the application ofself_group()
is automatic - end-user code should neverneed to use this method directly. Note that SQLAlchemy’sclause constructs take operator precedence into account -so parenthesis might not be needed, for example, inan expression like x OR (y AND z)
- AND takes precedenceover OR.
The base self_group()
method of ClauseElement
just returns self.
- class
sqlalchemy.sql.expression.
ColumnClause
(text, type=None, _is_literal=False, _selectable=None) - Bases:
sqlalchemy.sql.expression.Immutable
,sqlalchemy.sql.expression.ColumnElement
Represents a column expression from any textual string.
The ColumnClause
, a lightweight analogue to theColumn
class, is typically invoked using thecolumn()
function, as in:
- from sqlalchemy import column
- id, name = column("id"), column("name")
- stmt = select([id, name]).select_from("user")
The above statement would produce SQL like:
- SELECT id, name FROM user
ColumnClause
is the immediate superclass of the schema-specificColumn
object. While the Column
class has all thesame capabilities as ColumnClause
, the ColumnClause
class is usable by itself in those cases where behavioral requirementsare limited to simple SQL expression generation. The object has none ofthe associations with schema-level metadata or with execution-timebehavior that Column
does, so in that sense is a “lightweight”version of Column
.
Full details on ColumnClause
usage is at column()
.
See also
init
(text, type=None, _is_literal=False, selectable=None_)[](https://docs.sqlalchemy.org/en/13/core/#sqlalchemy.sql.expression.ColumnClause.init__)- Construct a new
ColumnClause
object.
This constructor is mirrored as a public API function; see column()
for a full usage and argument description.
- class
sqlalchemy.sql.expression.
ColumnCollection
(*columns) - Bases:
sqlalchemy.util._collections.OrderedProperties
An ordered dictionary that stores a list of ColumnElementinstances.
Overrides the eq()
method to produce SQL clauses betweensets of correlated columns.
The key attribute of the column will be used as the hash keyfor this dictionary.
as_immutable
()Return an immutable proxy for this
Properties
.- add the given column to this collection, removing unaliasedversions of this column as well as existing columns with thesame key.
e.g.:
- t = Table('sometable', metadata, Column('col1', Integer))t.columns.replace(Column('col1', Integer, key='columnone'))
will remove the original ‘col1’ from the collection, and addthe new column under the name ‘columnname’.
Used by schema.Column to override columns during table reflection.
- class
sqlalchemy.sql.expression.
ColumnElement
- Bases:
sqlalchemy.sql.operators.ColumnOperators
,sqlalchemy.sql.expression.ClauseElement
Represent a column-oriented SQL expression suitable for usage in the“columns” clause, WHERE clause etc. of a statement.
While the most familiar kind of ColumnElement
is theColumn
object, ColumnElement
serves as the basisfor any unit that may be present in a SQL expression, includingthe expressions themselves, SQL functions, bound parameters,literal expressions, keywords such as NULL
, etc.ColumnElement
is the ultimate base class for all such elements.
A wide variety of SQLAlchemy Core functions work at the SQL expressionlevel, and are intended to accept instances of ColumnElement
asarguments. These functions will typically document that they accept a“SQL expression” as an argument. What this means in terms of SQLAlchemyusually refers to an input which is either already in the form of aColumnElement
object, or a value which can be coerced intoone. The coercion rules followed by most, but not all, SQLAlchemy Corefunctions with regards to SQL expressions are as follows:
a literal Python value, such as a string, integer or floatingpoint value, boolean, datetime,
Decimal
object, or virtuallyany other Python object, will be coerced into a “literal boundvalue”. This generally means that abindparam()
will beproduced featuring the given value embedded into the construct; theresultingBindParameter
object is an instance ofColumnElement
. The Python value will ultimately be sentto the DBAPI at execution time as a parameterized argument to theexecute()
orexecutemany()
methods, after SQLAlchemytype-specific converters (e.g. those provided by any associatedTypeEngine
objects) are applied to the value.any special object value, typically ORM-level constructs, whichfeature a method called
clause_element()
. The Coreexpression system looks for this method when an object of otherwiseunknown type is passed to a function that is looking to coerce theargument into aColumnElement
expression. Theclause_element()
method, if present, should return aColumnElement
instance. The primary use ofclause_element()
within SQLAlchemy is that of class-boundattributes on ORM-mapped classes; aUser
class which contains amapped attribute named.name
will have a methodUser.name.clause_element()
which when invoked returns theColumn
calledname
associated with the mapped table.The Python
None
value is typically interpreted asNULL
,which in SQLAlchemy Core produces an instance ofnull()
.
A ColumnElement
provides the ability to generate newColumnElement
objects using Python expressions. This means that Python operatorssuch as ==
, !=
and <
are overloaded to mimic SQL operations,and allow the instantiation of further ColumnElement
instanceswhich are composed from other, more fundamental ColumnElement
objects. For example, two ColumnClause
objects can be addedtogether with the addition operator +
to producea BinaryExpression
.Both ColumnClause
and BinaryExpression
are subclassesof ColumnElement
:
- >>> from sqlalchemy.sql import column
- >>> column('a') + column('b')
- <sqlalchemy.sql.expression.BinaryExpression object at 0x101029dd0>
- >>> print column('a') + column('b')
- a + b
See also
inherited from theeq()
method ofColumnOperators
Implement the ==
operator.
In a column context, produces the clause a = b
.If the target is None
, produces a IS NULL
.
inherited from the init()
method of object
Initialize self. See help(type(self)) for accurate signature.
inherited from thele()
method ofColumnOperators
Implement the <=
operator.
In a column context, produces the clause a <= b
.
inherited from thelt()
method ofColumnOperators
Implement the <
operator.
In a column context, produces the clause a < b
.
inherited from thene()
method ofColumnOperators
Implement the !=
operator.
In a column context, produces the clause a != b
.If the target is None
, produces a IS NOT NULL
.
inherited from theall_()
method ofColumnOperators
Produce a all_()
clause against theparent object.
This operator is only appropriate against a scalar subqueryobject, or for some backends an column expression that isagainst the ARRAY type, e.g.:
- # postgresql '5 = ALL (somearray)'
- expr = 5 == mytable.c.somearray.all_()
- # mysql '5 = ALL (SELECT value FROM table)'
- expr = 5 == select([table.c.value]).as_scalar().all_()
See also
all_()
- standalone version
any_()
- ANY operator
New in version 1.1.
This is a label() expression which will be named at compile time.The same label() is returned each time anon_label is called sothat expressions can reference anon_label multiple times, producingthe same label name at compile time.
the compiler uses this function automatically at compile timefor expressions that are known to be ‘unnamed’ like binaryexpressions and function calls.
inherited from theany_()
method ofColumnOperators
Produce a any_()
clause against theparent object.
This operator is only appropriate against a scalar subqueryobject, or for some backends an column expression that isagainst the ARRAY type, e.g.:
- # postgresql '5 = ANY (somearray)'
- expr = 5 == mytable.c.somearray.any_()
- # mysql '5 = ANY (SELECT value FROM table)'
- expr = 5 == select([table.c.value]).as_scalar().any_()
See also
any_()
- standalone version
all_()
- ALL operator
New in version 1.1.
inherited from theasc()
method ofColumnOperators
Produce a asc()
clause against theparent object.
inherited from thebetween()
method ofColumnOperators
Produce a between()
clause againstthe parent object, given the lower and upper range.
inherited from thebool_op()
method ofOperators
Return a custom boolean operator.
This method is shorthand for callingOperators.op()
and passing theOperators.op.is_comparison
flag with True.
New in version 1.2.0b3.
See also
This is a shortcut to the cast()
function.
See also
New in version 1.0.7.
inherited from thecollate()
method ofColumnOperators
Produce a collate()
clause againstthe parent object, given the collation string.
See also
comparator
compare
(other, use_proxies=False, equivalents=None, **kw)- Compare this ColumnElement to another.
Special arguments understood:
- Parameters
-
-
use_proxies – when True, consider two columns thatshare a common base column as equivalent (i.e. shares_lineage())
-
equivalents – a dictionary of columns as keys mapped to setsof columns. If the given “other” column is present in thisdictionary, if any of the columns in the corresponding set() passthe comparison test, the result is True. This is used to expand thecomparison to other columns that may be known to be equivalent tothis one via foreign key or other criterion.
inherited from thecompile()
method ofClauseElement
Compile this SQL expression.
The return value is a Compiled
object.Calling str()
or unicode()
on the returned value will yield astring representation of the result. TheCompiled
object also can return adictionary of bind parameter names and valuesusing the params
accessor.
- Parameters
-
-
bind – An Engine
or Connection
from which aCompiled
will be acquired. This argument takes precedence overthis ClauseElement
’s bound engine, if any.
-
column_keys – Used for INSERT and UPDATE statements, a list ofcolumn names which should be present in the VALUES clause of thecompiled statement. If None
, all columns from the target tableobject are rendered.
-
dialect – A Dialect
instance from which a Compiled
will be acquired. This argument takes precedence over the _bind_argument as well as this ClauseElement
’s bound engine,if any.
-
inline – Used for INSERT statements, for a dialect which doesnot support inline retrieval of newly generated primary keycolumns, will force the expression used to create the new primarykey value to be rendered inline within the INSERT statement’sVALUES clause. This typically refers to Sequence execution but mayalso refer to any server-side default generation functionassociated with a primary key Column.
-
optional dictionary of additional parametersthat will be passed through to the compiler within all “visit”methods. This allows any custom flag to be passed through toa custom compilation construct, for example. It is also usedfor the case of passing the literal_binds
flag through:
- from sqlalchemy.sql import table, column, select
- t = table('t', column('x'))
- s = select([t]).where(t.c.x == 5)
- print s.compile(compile_kwargs={"literal_binds": True})
New in version 0.9.0.
See also
How do I render SQL expressions as strings, possibly with bound parameters inlined?
inherited from theconcat()
method ofColumnOperators
Implement the ‘concat’ operator.
In a column context, produces the clause a || b
,or uses the concat()
operator on MySQL.
inherited from thecontains()
method ofColumnOperators
Implement the ‘contains’ operator.
Produces a LIKE expression that tests against a match for the middleof a string value:
- column LIKE '%' || <other> || '%'
E.g.:
- stmt = select([sometable]).\
- where(sometable.c.column.contains("foobar"))
Since the operator uses LIKE
, wildcard characters"%"
and "_"
that are present inside the ColumnOperators.contains.autoescape
flagmay be set to True
to apply escaping to occurrences of thesecharacters within the string value so that they match as themselvesand not as wildcard characters. Alternatively, theColumnOperators.contains.escape
parameter will establisha given character as an escape character which can be of use whenthe target expression is not a literal string.
- Parameters
-
-
other – expression to be compared. This is usually a plainstring value, but can also be an arbitrary SQL expression. LIKEwildcard characters %
and _
are not escaped by default unlessthe ColumnOperators.contains.autoescape
flag isset to True.
-
boolean; when True, establishes an escape characterwithin the LIKE expression, then applies it to all occurrences of"%"
, "_"
and the escape character itself within thecomparison value, which is assumed to be a literal string and not aSQL expression.
An expression such as:
- somecolumn.contains("foo%bar", autoescape=True)
Will render as:
- somecolumn LIKE '%' || :param || '%' ESCAPE '/'
With the value of :param as "foo/%bar"
.
New in version 1.2.
Changed in version 1.2.0: TheColumnOperators.contains.autoescape
parameter is now a simple boolean rather than a character; the escape character itself is also escaped, and defaults to a forwards slash, which itself can be customized using the ColumnOperators.contains.escape
parameter.
-
a character which when given will render with theESCAPE
keyword to establish that character as the escapecharacter. This character can then be placed preceding occurrencesof %
and _
to allow them to act as themselves and notwildcard characters.
An expression such as:
- somecolumn.contains("foo/%bar", escape="^")
Will render as:
- somecolumn LIKE '%' || :param || '%' ESCAPE '^'
The parameter may also be combined withColumnOperators.contains.autoescape
:
- somecolumn.contains("foo%bar^bat", escape="^", autoescape=True)
Where above, the given literal parameter will be converted to"foo^%bar^^bat"
before being passed to the database.
See also
inherited from thedesc()
method ofColumnOperators
Produce a desc()
clause against theparent object.
inherited from thedistinct()
method ofColumnOperators
Produce a distinct()
clause against theparent object.
inherited from theendswith()
method ofColumnOperators
Implement the ‘endswith’ operator.
Produces a LIKE expression that tests against a match for the endof a string value:
- column LIKE '%' || <other>
E.g.:
- stmt = select([sometable]).\
- where(sometable.c.column.endswith("foobar"))
Since the operator uses LIKE
, wildcard characters"%"
and "_"
that are present inside the ColumnOperators.endswith.autoescape
flagmay be set to True
to apply escaping to occurrences of thesecharacters within the string value so that they match as themselvesand not as wildcard characters. Alternatively, theColumnOperators.endswith.escape
parameter will establisha given character as an escape character which can be of use whenthe target expression is not a literal string.
- Parameters
-
-
other – expression to be compared. This is usually a plainstring value, but can also be an arbitrary SQL expression. LIKEwildcard characters %
and _
are not escaped by default unlessthe ColumnOperators.endswith.autoescape
flag isset to True.
-
boolean; when True, establishes an escape characterwithin the LIKE expression, then applies it to all occurrences of"%"
, "_"
and the escape character itself within thecomparison value, which is assumed to be a literal string and not aSQL expression.
An expression such as:
- somecolumn.endswith("foo%bar", autoescape=True)
Will render as:
- somecolumn LIKE '%' || :param ESCAPE '/'
With the value of :param as "foo/%bar"
.
New in version 1.2.
Changed in version 1.2.0: TheColumnOperators.endswith.autoescape
parameter is now a simple boolean rather than a character; the escape character itself is also escaped, and defaults to a forwards slash, which itself can be customized using the ColumnOperators.endswith.escape
parameter.
-
a character which when given will render with theESCAPE
keyword to establish that character as the escapecharacter. This character can then be placed preceding occurrencesof %
and _
to allow them to act as themselves and notwildcard characters.
An expression such as:
- somecolumn.endswith("foo/%bar", escape="^")
Will render as:
- somecolumn LIKE '%' || :param ESCAPE '^'
The parameter may also be combined withColumnOperators.endswith.autoescape
:
- somecolumn.endswith("foo%bar^bat", escape="^", autoescape=True)
Where above, the given literal parameter will be converted to"foo^%bar^^bat"
before being passed to the database.
See also
Part of the inspection interface; returns self.
inherited from theget_children()
method ofClauseElement
Return immediate child elements of this ClauseElement
.
This is used for visit traversal.
**kwargs may contain flags that change the collection that isreturned, for example to return a subset of items in order tocut down on larger traversals, or to return child items from adifferent context (such as schema-level collections instead ofclause-level).
inherited from theilike()
method ofColumnOperators
Implement the ilike
operator, e.g. case insensitive LIKE.
In a column context, produces an expression either of the form:
- lower(a) LIKE lower(other)
Or on backends that support the ILIKE operator:
- a ILIKE other
E.g.:
- stmt = select([sometable]).\
- where(sometable.c.column.ilike("%foobar%"))
- Parameters
-
-
other – expression to be compared
-
optional escape character, renders the ESCAPE
keyword, e.g.:
- somecolumn.ilike("foo/%bar", escape="/")
See also
inherited from thein_()
method ofColumnOperators
Implement the in
operator.
In a column context, produces the clause column IN <other>
.
The given parameter other
may be:
-
A list of literal values, e.g.:
- stmt.where(column.in_([1, 2, 3]))
In this calling form, the list of items is converted to a set ofbound parameters the same length as the list given:
- WHERE COL IN (?, ?, ?)
-
A list of tuples may be provided if the comparison is against atuple_()
containing multiple expressions:
- from sqlalchemy import tuple_
- stmt.where(tuple_(col1, col2).in_([(1, 10), (2, 20), (3, 30)]))
-
An empty list, e.g.:
- stmt.where(column.in_([]))
In this calling form, the expression renders a “false” expression,e.g.:
- WHERE 1 != 1
This “false” expression has historically had different behaviorsin older SQLAlchemy versions, seecreate_engine.empty_in_strategy
for behavioral options.
Changed in version 1.2: simplified the behavior of “empty in”expressions
-
A bound parameter, e.g. bindparam()
, may be used if itincludes the bindparam.expanding
flag:
- stmt.where(column.in_(bindparam('value', expanding=True)))
In this calling form, the expression renders a special non-SQLplaceholder expression that looks like:
- WHERE COL IN ([EXPANDING_value])
This placeholder expression is intercepted at statement executiontime to be converted into the variable number of bound parameterform illustrated earlier. If the statement were executed as:
- connection.execute(stmt, {"value": [1, 2, 3]})
The database would be passed a bound parameter for each value:
- WHERE COL IN (?, ?, ?)
New in version 1.2: added “expanding” bound parameters
If an empty list is passed, a special “empty list” expression,which is specific to the database in use, is rendered. OnSQLite this would be:
- WHERE COL IN (SELECT 1 FROM (SELECT 1) WHERE 1!=1)
New in version 1.3: “expanding” bound parameters now supportempty lists
-
a select()
construct, which is usually a correlatedscalar select:
- stmt.where(
- column.in_(
- select([othertable.c.y]).
- where(table.c.x == othertable.c.x)
- )
- )
In this calling form, ColumnOperators.in_()
renders as given:
- WHERE COL IN (SELECT othertable.y
- FROM othertable WHERE othertable.x = table.x)
- Parameters
-
other – a list of literals, a select()
construct,or a bindparam()
construct that includes thebindparam.expanding
flag set to True.
inherited from theis_()
method ofColumnOperators
Implement the IS
operator.
Normally, IS
is generated automatically when comparing to avalue of None
, which resolves to NULL
. However, explicitusage of IS
may be desirable if comparing to boolean valueson certain platforms.
See also
inherited from theis_distinct_from()
method ofColumnOperators
Implement the IS DISTINCT FROM
operator.
Renders “a IS DISTINCT FROM b” on most platforms;on some such as SQLite may render “a IS NOT b”.
New in version 1.1.
inherited from theisnot()
method ofColumnOperators
Implement the IS NOT
operator.
Normally, IS NOT
is generated automatically when comparing to avalue of None
, which resolves to NULL
. However, explicitusage of IS NOT
may be desirable if comparing to boolean valueson certain platforms.
See also
inherited from theisnot_distinct_from()
method ofColumnOperators
Implement the IS NOT DISTINCT FROM
operator.
Renders “a IS NOT DISTINCT FROM b” on most platforms;on some such as SQLite may render “a IS b”.
New in version 1.1.
This typically refers to the “key” of the column as present in the.c
collection of a selectable, e.g. sometable.c[“somekey”] wouldreturn a Column with a .key of “somekey”.
This is a shortcut to the label()
function.
if ‘name’ is None, an anonymous label name will be generated.
inherited from thelike()
method ofColumnOperators
Implement the like
operator.
In a column context, produces the expression:
- a LIKE other
E.g.:
- stmt = select([sometable]).\
- where(sometable.c.column.like("%foobar%"))
- Parameters
-
-
other – expression to be compared
-
optional escape character, renders the ESCAPE
keyword, e.g.:
- somecolumn.like("foo/%bar", escape="/")
See also
inherited from thematch()
method ofColumnOperators
Implements a database-specific ‘match’ operator.
match()
attempts to resolve toa MATCH-like function or operator provided by the backend.Examples include:
-
PostgreSQL - renders x @@ to_tsquery(y)
-
MySQL - renders MATCH (x) AGAINST (y IN BOOLEAN MODE)
-
Oracle - renders CONTAINS(x, y)
-
other backends may provide special implementations.
-
Backends without any special implementation will emitthe operator as “MATCH”. This is compatible with SQLite, forexample.
inherited from thenotilike()
method ofColumnOperators
implement the NOT ILIKE
operator.
This is equivalent to using negation withColumnOperators.ilike()
, i.e. ~x.ilike(y)
.
See also
inherited from thenotin_()
method ofColumnOperators
implement the NOT IN
operator.
This is equivalent to using negation withColumnOperators.in_()
, i.e. ~x.in_(y)
.
In the case that other
is an empty sequence, the compilerproduces an “empty not in” expression. This defaults to theexpression “1 = 1” to produce true in all cases. Thecreate_engine.empty_in_strategy
may be used toalter this behavior.
Changed in version 1.2: The ColumnOperators.in_()
andColumnOperators.notin_()
operatorsnow produce a “static” expression for an empty IN sequenceby default.
See also
inherited from thenotlike()
method ofColumnOperators
implement the NOT LIKE
operator.
This is equivalent to using negation withColumnOperators.like()
, i.e. ~x.like(y)
.
See also
inherited from thenullsfirst()
method ofColumnOperators
Produce a nullsfirst()
clause against theparent object.
inherited from thenullslast()
method ofColumnOperators
Produce a nullslast()
clause against theparent object.
inherited from theop()
method ofOperators
produce a generic operator function.
e.g.:
- somecolumn.op("*")(5)
produces:
- somecolumn * 5
This function can also be used to make bitwise operators explicit. Forexample:
- somecolumn.op('&')(0xff)
is a bitwise AND of the value in somecolumn
.
- Parameters
-
-
operator – a string which will be output as the infix operatorbetween this element and the expression passed to thegenerated function.
-
precedence – precedence to apply to the operator, whenparenthesizing expressions. A lower number will cause the expressionto be parenthesized when applied against another operator withhigher precedence. The default value of 0
is lower than alloperators except for the comma (,
) and AS
operators.A value of 100 will be higher or equal to all operators, and -100will be lower than or equal to all operators.
-
if True, the operator will be considered as a“comparison” operator, that is which evaluates to a booleantrue/false value, like ==
, >
, etc. This flag should be setso that ORM relationships can establish that the operator is acomparison operator when used in a custom join condition.
New in version 0.9.2: - added theOperators.op.is_comparison
flag.
-
a TypeEngine
class or object that willforce the return type of an expression produced by this operatorto be of that type. By default, operators that specifyOperators.op.is_comparison
will resolve toBoolean
, and those that do not will be of the sametype as the left-hand operand.
New in version 1.2.0b3: - added theOperators.op.return_type
argument.
See also
Redefining and Creating New Operators
Using custom operators in join conditions
This is the lowest level of operation, raisesNotImplementedError
by default.
Overriding this on a subclass can allow commonbehavior to be applied to all operations.For example, overriding ColumnOperators
to apply func.lower()
to the left and rightside:
- class MyComparator(ColumnOperators):
- def operate(self, op, other):
- return op(func.lower(self), func.lower(other))
- Parameters
-
-
-
*other – the ‘other’ side of the operation. Willbe a single scalar for most operations.
-
**kwargs – modifiers. These may be passed by specialoperators such as ColumnOperators.contains()
.
inherited from theparams()
method ofClauseElement
Return a copy with bindparam()
elements replaced.
Returns a copy of this ClauseElement with bindparam()
elements replaced with values taken from the given dictionary:
- >>> clause = column('x') + bindparam('foo')
- >>> print clause.compile().params
- {'foo':None}
- >>> print clause.params({'foo':7}).compile().params
- {'foo':7}
Usage is the same as operate()
.
selfgroup
(_against=None)- Apply a ‘grouping’ to this
ClauseElement
.
This method is overridden by subclasses to return a“grouping” construct, i.e. parenthesis. In particularit’s used by “binary” expressions to provide a groupingaround themselves when placed into a larger expression,as well as by select()
constructs when placed intothe FROM clause of another select()
. (Note thatsubqueries should be normally created using theSelect.alias()
method, as many platforms requirenested SELECT statements to be named).
As expressions are composed together, the application ofself_group()
is automatic - end-user code should neverneed to use this method directly. Note that SQLAlchemy’sclause constructs take operator precedence into account -so parenthesis might not be needed, for example, inan expression like x OR (y AND z)
- AND takes precedenceover OR.
The base self_group()
method of ClauseElement
just returns self.
shareslineage
(_othercolumn)Return True if the given
ColumnElement
has a common ancestor to thisColumnElement
.
inherited from thestartswith()
method ofColumnOperators
Implement the startswith
operator.
Produces a LIKE expression that tests against a match for the startof a string value:
- column LIKE <other> || '%'
E.g.:
- stmt = select([sometable]).\
- where(sometable.c.column.startswith("foobar"))
Since the operator uses LIKE
, wildcard characters"%"
and "_"
that are present inside the ColumnOperators.startswith.autoescape
flagmay be set to True
to apply escaping to occurrences of thesecharacters within the string value so that they match as themselvesand not as wildcard characters. Alternatively, theColumnOperators.startswith.escape
parameter will establisha given character as an escape character which can be of use whenthe target expression is not a literal string.
- Parameters
-
-
other – expression to be compared. This is usually a plainstring value, but can also be an arbitrary SQL expression. LIKEwildcard characters %
and _
are not escaped by default unlessthe ColumnOperators.startswith.autoescape
flag isset to True.
-
boolean; when True, establishes an escape characterwithin the LIKE expression, then applies it to all occurrences of"%"
, "_"
and the escape character itself within thecomparison value, which is assumed to be a literal string and not aSQL expression.
An expression such as:
- somecolumn.startswith("foo%bar", autoescape=True)
Will render as:
- somecolumn LIKE :param || '%' ESCAPE '/'
With the value of :param as "foo/%bar"
.
New in version 1.2.
Changed in version 1.2.0: TheColumnOperators.startswith.autoescape
parameter is now a simple boolean rather than a character; the escape character itself is also escaped, and defaults to a forwards slash, which itself can be customized using the ColumnOperators.startswith.escape
parameter.
-
a character which when given will render with theESCAPE
keyword to establish that character as the escapecharacter. This character can then be placed preceding occurrencesof %
and _
to allow them to act as themselves and notwildcard characters.
An expression such as:
- somecolumn.startswith("foo/%bar", escape="^")
Will render as:
- somecolumn LIKE :param || '%' ESCAPE '^'
The parameter may also be combined withColumnOperators.startswith.autoescape
:
- somecolumn.startswith("foo%bar^bat", escape="^", autoescape=True)
Where above, the given literal parameter will be converted to"foo^%bar^^bat"
before being passed to the database.
See also
inherited from theunique_params()
method ofClauseElement
Return a copy with bindparam()
elements replaced.
Same functionality as params()
, except adds _unique=True_to affected bind parameters so that multiple statements can beused.
- class
sqlalchemy.sql.operators.
ColumnOperators
- Bases:
sqlalchemy.sql.operators.Operators
Defines boolean, comparison, and other operators forColumnElement
expressions.
By default, all methods call down tooperate()
or reverse_operate()
,passing in the appropriate operator function from thePython builtin operator
module ora SQLAlchemy-specific operator function fromsqlalchemy.expression.operators
. For examplethe eq
function:
- def __eq__(self, other):
- return self.operate(operators.eq, other)
Where operators.eq
is essentially:
- def eq(a, b):
- return a == b
The core column expression unit ColumnElement
overrides Operators.operate()
and othersto return further ColumnElement
constructs,so that the ==
operation above is replaced by a clauseconstruct.
See also
Redefining and Creating New Operators
In a column context, produces the clause a + b
if the parent object has non-string affinity.If the parent object has a string affinity,produces the concatenation operator, a || b
-see ColumnOperators.concat()
.
inherited from theand()
method ofOperators
Implement the &
operator.
When used with SQL expressions, results in anAND operation, equivalent toand_()
, that is:
- a & b
is equivalent to:
- from sqlalchemy import and_
- and_(a, b)
Care should be taken when using &
regardingoperator precedence; the &
operator has the highest precedence.The operands should be enclosed in parenthesis if they containfurther sub expressions:
- (a == 2) & (b == 4)
inherited from the delattr()
method of object
Implement delattr(self, name).
inherited from the dir()
method of object
Default dir() implementation.
In a column context, produces the clause a / b
.
In a column context, produces the clause a = b
.If the target is None
, produces a IS NULL
.
inherited from the format()
method of object
Default object formatter.
In a column context, produces the clause a >= b
.
inherited from the getattribute()
method of object
Return getattr(self, name).
This can be used by some database-specific typessuch as PostgreSQL ARRAY and HSTORE.
In a column context, produces the clause a > b
.
inherited from the init()
method of object
Initialize self. See help(type(self)) for accurate signature.
inherited from the init_subclass()
method of object
This method is called when a class is subclassed.
The default implementation does nothing. It may beoverridden to extend subclasses.
inherited from theinvert()
method ofOperators
Implement the ~
operator.
When used with SQL expressions, results in aNOT operation, equivalent tonot_()
, that is:
- ~a
is equivalent to:
- from sqlalchemy import not_
- not_(a)
In a column context, produces the clause a <= b
.
Not used by SQLAlchemy core, this is providedfor custom operator systems which want to use<< as an extension point.
In a column context, produces the clause a < b
.
In a column context, produces the clause a % b
.
In a column context, produces the clause a * b
.
In a column context, produces the clause a != b
.If the target is None
, produces a IS NOT NULL
.
In a column context, produces the clause -a
.
inherited from the new()
method of object
Create and return a new object. See help(type) for accurate signature.
inherited from theor()
method ofOperators
Implement the |
operator.
When used with SQL expressions, results in anOR operation, equivalent toor_()
, that is:
- a | b
is equivalent to:
- from sqlalchemy import or_
- or_(a, b)
Care should be taken when using |
regardingoperator precedence; the |
operator has the highest precedence.The operands should be enclosed in parenthesis if they containfurther sub expressions:
- (a == 2) | (b == 4)
inherited from the reduce()
method of object
Helper for pickle.
inherited from the reduce_ex()
method of object
Helper for pickle.
inherited from the repr()
method of object
Return repr(self).
Not used by SQLAlchemy core, this is providedfor custom operator systems which want to use>> as an extension point.
See ColumnOperators.truediv()
.
inherited from the setattr()
method of object
Implement setattr(self, name, value).
inherited from the sizeof()
method of object
Size of object in memory, in bytes.
inherited from the str()
method of object
Return str(self).
In a column context, produces the clause a - b
.
inherited from the subclasshook()
method of object
Abstract classes can override this to customize issubclass().
This is invoked early on by abc.ABCMeta.subclasscheck().It should return True, False or NotImplemented. If it returnsNotImplemented, the normal algorithm is used. Otherwise, itoverrides the normal algorithm (and the outcome is cached).
In a column context, produces the clause a / b
.
all
()[](https://docs.sqlalchemy.org/en/13/core/#sqlalchemy.sql.operators.ColumnOperators.all)- Produce a
all_()
clause against theparent object.
This operator is only appropriate against a scalar subqueryobject, or for some backends an column expression that isagainst the ARRAY type, e.g.:
- # postgresql '5 = ALL (somearray)'
- expr = 5 == mytable.c.somearray.all_()
- # mysql '5 = ALL (SELECT value FROM table)'
- expr = 5 == select([table.c.value]).as_scalar().all_()
See also
all_()
- standalone version
any_()
- ANY operator
New in version 1.1.
any
()[](https://docs.sqlalchemy.org/en/13/core/#sqlalchemy.sql.operators.ColumnOperators.any)- Produce a
any_()
clause against theparent object.
This operator is only appropriate against a scalar subqueryobject, or for some backends an column expression that isagainst the ARRAY type, e.g.:
- # postgresql '5 = ANY (somearray)'
- expr = 5 == mytable.c.somearray.any_()
- # mysql '5 = ANY (SELECT value FROM table)'
- expr = 5 == select([table.c.value]).as_scalar().any_()
See also
any_()
- standalone version
all_()
- ALL operator
New in version 1.1.
asc
()Produce a
asc()
clause against theparent object.Produce a
between()
clause againstthe parent object, given the lower and upper range.
inherited from thebool_op()
method ofOperators
Return a custom boolean operator.
This method is shorthand for callingOperators.op()
and passing theOperators.op.is_comparison
flag with True.
New in version 1.2.0b3.
See also
collate
(collation)- Produce a
collate()
clause againstthe parent object, given the collation string.
See also
In a column context, produces the clause a || b
,or uses the concat()
operator on MySQL.
Produces a LIKE expression that tests against a match for the middleof a string value:
- column LIKE '%' || <other> || '%'
E.g.:
- stmt = select([sometable]).\
- where(sometable.c.column.contains("foobar"))
Since the operator uses LIKE
, wildcard characters"%"
and "_"
that are present inside the ColumnOperators.contains.autoescape
flagmay be set to True
to apply escaping to occurrences of thesecharacters within the string value so that they match as themselvesand not as wildcard characters. Alternatively, theColumnOperators.contains.escape
parameter will establisha given character as an escape character which can be of use whenthe target expression is not a literal string.
- Parameters
-
-
other – expression to be compared. This is usually a plainstring value, but can also be an arbitrary SQL expression. LIKEwildcard characters %
and _
are not escaped by default unlessthe ColumnOperators.contains.autoescape
flag isset to True.
-
boolean; when True, establishes an escape characterwithin the LIKE expression, then applies it to all occurrences of"%"
, "_"
and the escape character itself within thecomparison value, which is assumed to be a literal string and not aSQL expression.
An expression such as:
- somecolumn.contains("foo%bar", autoescape=True)
Will render as:
- somecolumn LIKE '%' || :param || '%' ESCAPE '/'
With the value of :param as "foo/%bar"
.
New in version 1.2.
Changed in version 1.2.0: TheColumnOperators.contains.autoescape
parameter is now a simple boolean rather than a character; the escape character itself is also escaped, and defaults to a forwards slash, which itself can be customized using the ColumnOperators.contains.escape
parameter.
-
a character which when given will render with theESCAPE
keyword to establish that character as the escapecharacter. This character can then be placed preceding occurrencesof %
and _
to allow them to act as themselves and notwildcard characters.
An expression such as:
- somecolumn.contains("foo/%bar", escape="^")
Will render as:
- somecolumn LIKE '%' || :param || '%' ESCAPE '^'
The parameter may also be combined withColumnOperators.contains.autoescape
:
- somecolumn.contains("foo%bar^bat", escape="^", autoescape=True)
Where above, the given literal parameter will be converted to"foo^%bar^^bat"
before being passed to the database.
See also
desc
()Produce a
desc()
clause against theparent object.Produce a
distinct()
clause against theparent object.- Implement the ‘endswith’ operator.
Produces a LIKE expression that tests against a match for the endof a string value:
- column LIKE '%' || <other>
E.g.:
- stmt = select([sometable]).\
- where(sometable.c.column.endswith("foobar"))
Since the operator uses LIKE
, wildcard characters"%"
and "_"
that are present inside the ColumnOperators.endswith.autoescape
flagmay be set to True
to apply escaping to occurrences of thesecharacters within the string value so that they match as themselvesand not as wildcard characters. Alternatively, theColumnOperators.endswith.escape
parameter will establisha given character as an escape character which can be of use whenthe target expression is not a literal string.
- Parameters
-
-
other – expression to be compared. This is usually a plainstring value, but can also be an arbitrary SQL expression. LIKEwildcard characters %
and _
are not escaped by default unlessthe ColumnOperators.endswith.autoescape
flag isset to True.
-
boolean; when True, establishes an escape characterwithin the LIKE expression, then applies it to all occurrences of"%"
, "_"
and the escape character itself within thecomparison value, which is assumed to be a literal string and not aSQL expression.
An expression such as:
- somecolumn.endswith("foo%bar", autoescape=True)
Will render as:
- somecolumn LIKE '%' || :param ESCAPE '/'
With the value of :param as "foo/%bar"
.
New in version 1.2.
Changed in version 1.2.0: TheColumnOperators.endswith.autoescape
parameter is now a simple boolean rather than a character; the escape character itself is also escaped, and defaults to a forwards slash, which itself can be customized using the ColumnOperators.endswith.escape
parameter.
-
a character which when given will render with theESCAPE
keyword to establish that character as the escapecharacter. This character can then be placed preceding occurrencesof %
and _
to allow them to act as themselves and notwildcard characters.
An expression such as:
- somecolumn.endswith("foo/%bar", escape="^")
Will render as:
- somecolumn LIKE '%' || :param ESCAPE '^'
The parameter may also be combined withColumnOperators.endswith.autoescape
:
- somecolumn.endswith("foo%bar^bat", escape="^", autoescape=True)
Where above, the given literal parameter will be converted to"foo^%bar^^bat"
before being passed to the database.
See also
In a column context, produces an expression either of the form:
- lower(a) LIKE lower(other)
Or on backends that support the ILIKE operator:
- a ILIKE other
E.g.:
- stmt = select([sometable]).\
- where(sometable.c.column.ilike("%foobar%"))
- Parameters
-
-
other – expression to be compared
-
optional escape character, renders the ESCAPE
keyword, e.g.:
- somecolumn.ilike("foo/%bar", escape="/")
See also
In a column context, produces the clause column IN <other>
.
The given parameter other
may be:
-
A list of literal values, e.g.:
- stmt.where(column.in_([1, 2, 3]))
In this calling form, the list of items is converted to a set ofbound parameters the same length as the list given:
- WHERE COL IN (?, ?, ?)
-
A list of tuples may be provided if the comparison is against atuple_()
containing multiple expressions:
- from sqlalchemy import tuple_
- stmt.where(tuple_(col1, col2).in_([(1, 10), (2, 20), (3, 30)]))
-
An empty list, e.g.:
- stmt.where(column.in_([]))
In this calling form, the expression renders a “false” expression,e.g.:
- WHERE 1 != 1
This “false” expression has historically had different behaviorsin older SQLAlchemy versions, seecreate_engine.empty_in_strategy
for behavioral options.
Changed in version 1.2: simplified the behavior of “empty in”expressions
-
A bound parameter, e.g. bindparam()
, may be used if itincludes the bindparam.expanding
flag:
- stmt.where(column.in_(bindparam('value', expanding=True)))
In this calling form, the expression renders a special non-SQLplaceholder expression that looks like:
- WHERE COL IN ([EXPANDING_value])
This placeholder expression is intercepted at statement executiontime to be converted into the variable number of bound parameterform illustrated earlier. If the statement were executed as:
- connection.execute(stmt, {"value": [1, 2, 3]})
The database would be passed a bound parameter for each value:
- WHERE COL IN (?, ?, ?)
New in version 1.2: added “expanding” bound parameters
If an empty list is passed, a special “empty list” expression,which is specific to the database in use, is rendered. OnSQLite this would be:
- WHERE COL IN (SELECT 1 FROM (SELECT 1) WHERE 1!=1)
New in version 1.3: “expanding” bound parameters now supportempty lists
-
a select()
construct, which is usually a correlatedscalar select:
- stmt.where(
- column.in_(
- select([othertable.c.y]).
- where(table.c.x == othertable.c.x)
- )
- )
In this calling form, ColumnOperators.in_()
renders as given:
- WHERE COL IN (SELECT othertable.y
- FROM othertable WHERE othertable.x = table.x)
- Parameters
-
other – a list of literals, a select()
construct,or a bindparam()
construct that includes thebindparam.expanding
flag set to True.
Normally, IS
is generated automatically when comparing to avalue of None
, which resolves to NULL
. However, explicitusage of IS
may be desirable if comparing to boolean valueson certain platforms.
See also
Renders “a IS DISTINCT FROM b” on most platforms;on some such as SQLite may render “a IS NOT b”.
New in version 1.1.
Normally, IS NOT
is generated automatically when comparing to avalue of None
, which resolves to NULL
. However, explicitusage of IS NOT
may be desirable if comparing to boolean valueson certain platforms.
See also
Renders “a IS NOT DISTINCT FROM b” on most platforms;on some such as SQLite may render “a IS b”.
New in version 1.1.
In a column context, produces the expression:
- a LIKE other
E.g.:
- stmt = select([sometable]).\
- where(sometable.c.column.like("%foobar%"))
- Parameters
-
-
other – expression to be compared
-
optional escape character, renders the ESCAPE
keyword, e.g.:
- somecolumn.like("foo/%bar", escape="/")
See also
match()
attempts to resolve toa MATCH-like function or operator provided by the backend.Examples include:
-
PostgreSQL - renders x @@ to_tsquery(y)
-
MySQL - renders MATCH (x) AGAINST (y IN BOOLEAN MODE)
-
Oracle - renders CONTAINS(x, y)
-
other backends may provide special implementations.
-
Backends without any special implementation will emitthe operator as “MATCH”. This is compatible with SQLite, forexample.
This is equivalent to using negation withColumnOperators.ilike()
, i.e. ~x.ilike(y)
.
See also
This is equivalent to using negation withColumnOperators.in_()
, i.e. ~x.in_(y)
.
In the case that other
is an empty sequence, the compilerproduces an “empty not in” expression. This defaults to theexpression “1 = 1” to produce true in all cases. Thecreate_engine.empty_in_strategy
may be used toalter this behavior.
Changed in version 1.2: The ColumnOperators.in_()
andColumnOperators.notin_()
operatorsnow produce a “static” expression for an empty IN sequenceby default.
See also
This is equivalent to using negation withColumnOperators.like()
, i.e. ~x.like(y)
.
See also
nullsfirst
()Produce a
nullsfirst()
clause against theparent object.Produce a
nullslast()
clause against theparent object.op
(opstring, precedence=0, is_comparison=False, return_type=None)
inherited from theop()
method ofOperators
produce a generic operator function.
e.g.:
- somecolumn.op("*")(5)
produces:
- somecolumn * 5
This function can also be used to make bitwise operators explicit. Forexample:
- somecolumn.op('&')(0xff)
is a bitwise AND of the value in somecolumn
.
- Parameters
-
-
operator – a string which will be output as the infix operatorbetween this element and the expression passed to thegenerated function.
-
precedence – precedence to apply to the operator, whenparenthesizing expressions. A lower number will cause the expressionto be parenthesized when applied against another operator withhigher precedence. The default value of 0
is lower than alloperators except for the comma (,
) and AS
operators.A value of 100 will be higher or equal to all operators, and -100will be lower than or equal to all operators.
-
if True, the operator will be considered as a“comparison” operator, that is which evaluates to a booleantrue/false value, like ==
, >
, etc. This flag should be setso that ORM relationships can establish that the operator is acomparison operator when used in a custom join condition.
New in version 0.9.2: - added theOperators.op.is_comparison
flag.
-
a TypeEngine
class or object that willforce the return type of an expression produced by this operatorto be of that type. By default, operators that specifyOperators.op.is_comparison
will resolve toBoolean
, and those that do not will be of the sametype as the left-hand operand.
New in version 1.2.0b3: - added theOperators.op.return_type
argument.
See also
Redefining and Creating New Operators
Using custom operators in join conditions
inherited from theoperate()
method ofOperators
Operate on an argument.
This is the lowest level of operation, raisesNotImplementedError
by default.
Overriding this on a subclass can allow commonbehavior to be applied to all operations.For example, overriding ColumnOperators
to apply func.lower()
to the left and rightside:
- class MyComparator(ColumnOperators):
- def operate(self, op, other):
- return op(func.lower(self), func.lower(other))
- Parameters
-
-
-
*other – the ‘other’ side of the operation. Willbe a single scalar for most operations.
-
**kwargs – modifiers. These may be passed by specialoperators such as ColumnOperators.contains()
.
inherited from thereverse_operate()
method ofOperators
Reverse operate on an argument.
Usage is the same as operate()
.
Produces a LIKE expression that tests against a match for the startof a string value:
- column LIKE <other> || '%'
E.g.:
- stmt = select([sometable]).\
- where(sometable.c.column.startswith("foobar"))
Since the operator uses LIKE
, wildcard characters"%"
and "_"
that are present inside the ColumnOperators.startswith.autoescape
flagmay be set to True
to apply escaping to occurrences of thesecharacters within the string value so that they match as themselvesand not as wildcard characters. Alternatively, theColumnOperators.startswith.escape
parameter will establisha given character as an escape character which can be of use whenthe target expression is not a literal string.
- Parameters
-
-
other – expression to be compared. This is usually a plainstring value, but can also be an arbitrary SQL expression. LIKEwildcard characters %
and _
are not escaped by default unlessthe ColumnOperators.startswith.autoescape
flag isset to True.
-
boolean; when True, establishes an escape characterwithin the LIKE expression, then applies it to all occurrences of"%"
, "_"
and the escape character itself within thecomparison value, which is assumed to be a literal string and not aSQL expression.
An expression such as:
- somecolumn.startswith("foo%bar", autoescape=True)
Will render as:
- somecolumn LIKE :param || '%' ESCAPE '/'
With the value of :param as "foo/%bar"
.
New in version 1.2.
Changed in version 1.2.0: TheColumnOperators.startswith.autoescape
parameter is now a simple boolean rather than a character; the escape character itself is also escaped, and defaults to a forwards slash, which itself can be customized using the ColumnOperators.startswith.escape
parameter.
-
a character which when given will render with theESCAPE
keyword to establish that character as the escapecharacter. This character can then be placed preceding occurrencesof %
and _
to allow them to act as themselves and notwildcard characters.
An expression such as:
- somecolumn.startswith("foo/%bar", escape="^")
Will render as:
- somecolumn LIKE :param || '%' ESCAPE '^'
The parameter may also be combined withColumnOperators.startswith.autoescape
:
- somecolumn.startswith("foo%bar^bat", escape="^", autoescape=True)
Where above, the given literal parameter will be converted to"foo^%bar^^bat"
before being passed to the database.
See also
The DialectKWArgs
interacts with theDefaultDialect.construct_arguments
present on a dialect.
See also
DefaultDialect.construct_arguments
- classmethod
argumentfor
(_dialect_name, argument_name, default) - Add a new kind of dialect-specific keyword argument for this class.
E.g.:
- Index.argument_for("mydialect", "length", None)
- some_index = Index('a', 'b', mydialect_length=5)
The DialectKWArgs.argument_for()
method is a per-argumentway adding extra arguments to theDefaultDialect.construct_arguments
dictionary. Thisdictionary provides a list of argument names accepted by variousschema-level constructs on behalf of a dialect.
New dialects should typically specify this dictionary all at once as adata member of the dialect class. The use case for ad-hoc addition ofargument names is typically for end-user code that is also usinga custom compilation scheme which consumes the additional arguments.
- Parameters
-
-
dialect_name – name of a dialect. The dialect must belocatable, else a NoSuchModuleError
is raised. Thedialect must also include an existingDefaultDialect.construct_arguments
collection, indicatingthat it participates in the keyword-argument validation and defaultsystem, else ArgumentError
is raised. If the dialect doesnot include this collection, then any keyword argument can bespecified on behalf of this dialect already. All dialects packagedwithin SQLAlchemy include this collection, however for third partydialects, support may vary.
-
argument_name – name of the parameter.
-
default – default value of the parameter.
New in version 0.9.4.
dialect_kwargs
- A collection of keyword arguments specified as dialect-specificoptions to this construct.
The arguments are present here in their original <dialect>_<kwarg>
format. Only arguments that were actually passed are included;unlike the DialectKWArgs.dialect_options
collection, whichcontains all options known by this dialect including defaults.
The collection is also writable; keys are accepted of theform <dialect>_<kwarg>
where the value will be assembledinto the list of options.
New in version 0.9.2.
Changed in version 0.9.4: The DialectKWArgs.dialect_kwargs
collection is now writable.
See also
DialectKWArgs.dialect_options
- nested dictionary form
dialect_options
- A collection of keyword arguments specified as dialect-specificoptions to this construct.
This is a two-level nested registry, keyed to <dialect_name>
and <argument_name>
. For example, the postgresql_where
argument would be locatable as:
- arg = my_object.dialect_options['postgresql']['where']
New in version 0.9.2.
See also
DialectKWArgs.dialect_kwargs
- flat dictionary form
- property
kwargs
- A synonym for
DialectKWArgs.dialect_kwargs
.
- class
sqlalchemy.sql.expression.
Extract
(field, expr, **kwargs) - Bases:
sqlalchemy.sql.expression.ColumnElement
Represent a SQL EXTRACT clause, extract(field FROM expr)
.
init
(field, expr, **kwargs)- Construct a new
Extract
object.
This constructor is mirrored as a public API function; see extract()
for a full usage and argument description.
getchildren
(**kwargs_)- Return immediate child elements of this
ClauseElement
.
This is used for visit traversal.
**kwargs may contain flags that change the collection that isreturned, for example to return a subset of items in order tocut down on larger traversals, or to return child items from adifferent context (such as schema-level collections instead ofclause-level).
- class
sqlalchemy.sql.elements.
False
[](https://docs.sqlalchemy.org/en/13/core/#sqlalchemy.sql.elements.False) - Bases:
sqlalchemy.sql.expression.ColumnElement
Represent the false
keyword, or equivalent, in a SQL statement.
False_
is accessed as a constant via thefalse()
function.
Special arguments understood:
- Parameters
-
-
use_proxies – when True, consider two columns thatshare a common base column as equivalent (i.e. shares_lineage())
-
equivalents – a dictionary of columns as keys mapped to setsof columns. If the given “other” column is present in thisdictionary, if any of the columns in the corresponding set() passthe comparison test, the result is True. This is used to expand thecomparison to other columns that may be known to be equivalent tothis one via foreign key or other criterion.
- class
sqlalchemy.sql.expression.
FunctionFilter
(func, *criterion) - Bases:
sqlalchemy.sql.expression.ColumnElement
Represent a function FILTER clause.
This is a special operator against aggregate and window functions,which controls which rows are passed to it.It’s supported only by certain database backends.
Invocation of FunctionFilter
is viaFunctionElement.filter()
:
- func.count(1).filter(True)
New in version 1.0.0.
See also
init
(func, *criterion)- Construct a new
FunctionFilter
object.
This constructor is mirrored as a public API function; see funcfilter()
for a full usage and argument description.
This method adds additional criteria to the initial criteriaset up by FunctionElement.filter()
.
Multiple criteria are joined together at SQL render timevia AND
.
getchildren
(**kwargs_)- Return immediate child elements of this
ClauseElement
.
This is used for visit traversal.
**kwargs may contain flags that change the collection that isreturned, for example to return a subset of items in order tocut down on larger traversals, or to return child items from adifferent context (such as schema-level collections instead ofclause-level).
over
(partition_by=None, order_by=None, range=None, _rows=None)- Produce an OVER clause against this filtered function.
Used against aggregate or so-called “window” functions,for database backends that support window functions.
The expression:
- func.rank().filter(MyClass.y > 5).over(order_by='x')
is shorthand for:
- from sqlalchemy import over, funcfilter
- over(funcfilter(func.rank(), MyClass.y > 5), order_by='x')
See over()
for a full description.
selfgroup
(_against=None)- Apply a ‘grouping’ to this
ClauseElement
.
This method is overridden by subclasses to return a“grouping” construct, i.e. parenthesis. In particularit’s used by “binary” expressions to provide a groupingaround themselves when placed into a larger expression,as well as by select()
constructs when placed intothe FROM clause of another select()
. (Note thatsubqueries should be normally created using theSelect.alias()
method, as many platforms requirenested SELECT statements to be named).
As expressions are composed together, the application ofself_group()
is automatic - end-user code should neverneed to use this method directly. Note that SQLAlchemy’sclause constructs take operator precedence into account -so parenthesis might not be needed, for example, inan expression like x OR (y AND z)
- AND takes precedenceover OR.
The base self_group()
method of ClauseElement
just returns self.
- class
sqlalchemy.sql.expression.
Label
(name, element, type=None_) - Bases:
sqlalchemy.sql.expression.ColumnElement
Represents a column label (AS).
Represent a label, as typically applied to any column-levelelement using the AS
sql keyword.
init
(name, element, type=None)[](https://docs.sqlalchemy.org/en/13/core/#sqlalchemy.sql.expression.Label.__init_)- Construct a new
Label
object.
This constructor is mirrored as a public API function; see label()
for a full usage and argument description.
If no argument is given, the constructor creates a new empty list.The argument must be an iterable if specified.
getchildren
(**kwargs_)- Return immediate child elements of this
ClauseElement
.
This is used for visit traversal.
**kwargs may contain flags that change the collection that isreturned, for example to return a subset of items in order tocut down on larger traversals, or to return child items from adifferent context (such as schema-level collections instead ofclause-level).
Returns True when the argument x is true, False otherwise.The builtins True and False are the only two instances of the class bool.The class bool is a subclass of the class int, and cannot be subclassed.
selfgroup
(_against=None)- Apply a ‘grouping’ to this
ClauseElement
.
This method is overridden by subclasses to return a“grouping” construct, i.e. parenthesis. In particularit’s used by “binary” expressions to provide a groupingaround themselves when placed into a larger expression,as well as by select()
constructs when placed intothe FROM clause of another select()
. (Note thatsubqueries should be normally created using theSelect.alias()
method, as many platforms requirenested SELECT statements to be named).
As expressions are composed together, the application ofself_group()
is automatic - end-user code should neverneed to use this method directly. Note that SQLAlchemy’sclause constructs take operator precedence into account -so parenthesis might not be needed, for example, inan expression like x OR (y AND z)
- AND takes precedenceover OR.
The base self_group()
method of ClauseElement
just returns self.
- class
sqlalchemy.sql.elements.
Null
- Bases:
sqlalchemy.sql.expression.ColumnElement
Represent the NULL keyword in a SQL statement.
Null
is accessed as a constant via thenull()
function.
Special arguments understood:
- Parameters
-
-
use_proxies – when True, consider two columns thatshare a common base column as equivalent (i.e. shares_lineage())
-
equivalents – a dictionary of columns as keys mapped to setsof columns. If the given “other” column is present in thisdictionary, if any of the columns in the corresponding set() passthe comparison test, the result is True. This is used to expand thecomparison to other columns that may be known to be equivalent tothis one via foreign key or other criterion.
- class
sqlalchemy.sql.expression.
Over
(element, partition_by=None, order_by=None, range=None, _rows=None) - Bases:
sqlalchemy.sql.expression.ColumnElement
Represent an OVER clause.
This is a special operator against a so-called“window” function, as well as any aggregate function,which produces results relative to the result setitself. It’s supported only by certain databasebackends.
init
(element, partition_by=None, order_by=None, range=None, _rows=None)- Construct a new
Over
object.
This constructor is mirrored as a public API function; see over()
for a full usage and argument description.
element
= NoneThe underlying expression object to which this
Over
object refers towards.- the element referred to by this
Over
clause.
Deprecated since version 1.1: the Over.func
member of the Over
class is deprecated and will be removed in a future release. Please refer to the Over.element
attribute.
getchildren
(**kwargs_)- Return immediate child elements of this
ClauseElement
.
This is used for visit traversal.
**kwargs may contain flags that change the collection that isreturned, for example to return a subset of items in order tocut down on larger traversals, or to return child items from adifferent context (such as schema-level collections instead ofclause-level).
- class
sqlalchemy.sql.expression.
TextClause
(text, bind=None) - Bases:
sqlalchemy.sql.expression.Executable
,sqlalchemy.sql.expression.ClauseElement
Represent a literal SQL text fragment.
E.g.:
- from sqlalchemy import text
- t = text("SELECT * FROM users")
- result = connection.execute(t)
The Text
construct is produced using the text()
function; see that function for full documentation.
See also
bindparams
(*binds, **names_to_values)- Establish the values and/or types of bound parameters withinthis
TextClause
construct.
Given a text construct such as:
- from sqlalchemy import text
- stmt = text("SELECT id, name FROM user WHERE name=:name "
- "AND timestamp=:timestamp")
the TextClause.bindparams()
method can be used to establishthe initial value of :name
and :timestamp
,using simple keyword arguments:
- stmt = stmt.bindparams(name='jack',
- timestamp=datetime.datetime(2012, 10, 8, 15, 12, 5))
Where above, new BindParameter
objectswill be generated with the names name
and timestamp
, andvalues of jack
and datetime.datetime(2012, 10, 8, 15, 12, 5)
,respectively. The types will beinferred from the values given, in this case String
andDateTime
.
When specific typing behavior is needed, the positional *binds
argument can be used in which to specify bindparam()
constructsdirectly. These constructs must include at least the key
argument, then an optional value and type:
- from sqlalchemy import bindparam
- stmt = stmt.bindparams(
- bindparam('name', value='jack', type_=String),
- bindparam('timestamp', type_=DateTime)
- )
Above, we specified the type of DateTime
for thetimestamp
bind, and the type of String
for the name
bind. In the case of name
we also set the default value of"jack"
.
Additional bound parameters can be supplied at statement executiontime, e.g.:
- result = connection.execute(stmt,
- timestamp=datetime.datetime(2012, 10, 8, 15, 12, 5))
The TextClause.bindparams()
method can be called repeatedly,where it will re-use existing BindParameter
objects to addnew information. For example, we can callTextClause.bindparams()
first with typing information, and asecond time with value information, and it will be combined:
- stmt = text("SELECT id, name FROM user WHERE name=:name "
- "AND timestamp=:timestamp")
- stmt = stmt.bindparams(
- bindparam('name', type_=String),
- bindparam('timestamp', type_=DateTime)
- )
- stmt = stmt.bindparams(
- name='jack',
- timestamp=datetime.datetime(2012, 10, 8, 15, 12, 5)
- )
columns
(selectable, *cols, **types)- Turn this
TextClause
object into aTextAsFrom
object that can be embedded into another statement.
This function essentially bridges the gap between an entirelytextual SELECT statement and the SQL expression language conceptof a “selectable”:
- from sqlalchemy.sql import column, text
- stmt = text("SELECT id, name FROM some_table")
- stmt = stmt.columns(column('id'), column('name')).alias('st')
- stmt = select([mytable]). select_from(
- mytable.join(stmt, mytable.c.name == stmt.c.name)
- ).where(stmt.c.id > 5)
Above, we pass a series of column()
elements to theTextClause.columns()
method positionally. These column()
elements now become first class elements upon the TextAsFrom.c
column collection, just like any other selectable.
The column expressions we pass to TextClause.columns()
mayalso be typed; when we do so, these TypeEngine
objects becomethe effective return type of the column, so that SQLAlchemy’sresult-set-processing systems may be used on the return values.This is often needed for types such as date or boolean types, as wellas for unicode processing on some dialect configurations:
- stmt = text("SELECT id, name, timestamp FROM some_table")
- stmt = stmt.columns(
- column('id', Integer),
- column('name', Unicode),
- column('timestamp', DateTime)
- )
- for id, name, timestamp in connection.execute(stmt):
- print(id, name, timestamp)
As a shortcut to the above syntax, keyword arguments referring totypes alone may be used, if only type conversion is needed:
- stmt = text("SELECT id, name, timestamp FROM some_table")
- stmt = stmt.columns(
- id=Integer,
- name=Unicode,
- timestamp=DateTime
- )
- for id, name, timestamp in connection.execute(stmt):
- print(id, name, timestamp)
The positional form of TextClause.columns()
also provides theunique feature of positional column targeting, which isparticularly useful when using the ORM with complex textual queries. Ifwe specify the columns from our model to TextClause.columns()
,the result set will match to those columns positionally, meaning thename or origin of the column in the textual SQL doesn’t matter:
- stmt = text("SELECT users.id, addresses.id, users.id, "
- "users.name, addresses.email_address AS email "
- "FROM users JOIN addresses ON users.id=addresses.user_id "
- "WHERE users.id = 1").columns(
- User.id,
- Address.id,
- Address.user_id,
- User.name,
- Address.email_address
- )
- query = session.query(User).from_statement(stmt).options(
- contains_eager(User.addresses))
New in version 1.1: the TextClause.columns()
method nowoffers positional column targeting in the result set whenthe column expressions are passed purely positionally.
The TextClause.columns()
method provides a directroute to calling FromClause.alias()
as well asSelectBase.cte()
against a textual SELECT statement:
- stmt = stmt.columns(id=Integer, name=String).cte('st')
- stmt = select([sometable]).where(sometable.c.id == stmt.c.id)
New in version 0.9.0: text()
can now be converted into afully featured “selectable” construct using theTextClause.columns()
method.
Subclasses should override the default behavior, which is astraight identity comparison.
**kw are arguments consumed by subclass compare() methods andmay be used to modify the criteria for comparison.(see ColumnElement
)
getchildren
(**kwargs_)- Return immediate child elements of this
ClauseElement
.
This is used for visit traversal.
**kwargs may contain flags that change the collection that isreturned, for example to return a subset of items in order tocut down on larger traversals, or to return child items from adifferent context (such as schema-level collections instead ofclause-level).
selfgroup
(_against=None)- Apply a ‘grouping’ to this
ClauseElement
.
This method is overridden by subclasses to return a“grouping” construct, i.e. parenthesis. In particularit’s used by “binary” expressions to provide a groupingaround themselves when placed into a larger expression,as well as by select()
constructs when placed intothe FROM clause of another select()
. (Note thatsubqueries should be normally created using theSelect.alias()
method, as many platforms requirenested SELECT statements to be named).
As expressions are composed together, the application ofself_group()
is automatic - end-user code should neverneed to use this method directly. Note that SQLAlchemy’sclause constructs take operator precedence into account -so parenthesis might not be needed, for example, inan expression like x OR (y AND z)
- AND takes precedenceover OR.
The base self_group()
method of ClauseElement
just returns self.
- class
sqlalchemy.sql.expression.
Tuple
(*clauses, **kw) - Bases:
sqlalchemy.sql.expression.ClauseList
,sqlalchemy.sql.expression.ColumnElement
Represent a SQL tuple.
init
(*clauses, **kw)- Construct a new
Tuple
object.
This constructor is mirrored as a public API function; see tuple_()
for a full usage and argument description.
- class
sqlalchemy.sql.expression.
WithinGroup
(element, *order_by) - Bases:
sqlalchemy.sql.expression.ColumnElement
Represent a WITHIN GROUP (ORDER BY) clause.
This is a special operator against so-called“ordered set aggregate” and “hypotheticalset aggregate” functions, including percentile_cont()
,rank()
, dense_rank()
, etc.
It’s supported only by certain database backends, such as PostgreSQL,Oracle and MS SQL Server.
The WithinGroup
construct extracts its type from themethod FunctionElement.within_group_type()
. If this returnsNone
, the function’s .type
is used.
init
(element, *order_by)- Construct a new
WithinGroup
object.
This constructor is mirrored as a public API function; see within_group()
for a full usage and argument description.
getchildren
(**kwargs_)- Return immediate child elements of this
ClauseElement
.
This is used for visit traversal.
**kwargs may contain flags that change the collection that isreturned, for example to return a subset of items in order tocut down on larger traversals, or to return child items from adifferent context (such as schema-level collections instead ofclause-level).
over
(partition_by=None, order_by=None, range=None, _rows=None)- Produce an OVER clause against this
WithinGroup
construct.
This function has the same signature as that ofFunctionElement.over()
.
- class
sqlalchemy.sql.elements.
True
[](https://docs.sqlalchemy.org/en/13/core/#sqlalchemy.sql.elements.True) - Bases:
sqlalchemy.sql.expression.ColumnElement
Represent the true
keyword, or equivalent, in a SQL statement.
True_
is accessed as a constant via thetrue()
function.
Special arguments understood:
- Parameters
-
-
use_proxies – when True, consider two columns thatshare a common base column as equivalent (i.e. shares_lineage())
-
equivalents – a dictionary of columns as keys mapped to setsof columns. If the given “other” column is present in thisdictionary, if any of the columns in the corresponding set() passthe comparison test, the result is True. This is used to expand thecomparison to other columns that may be known to be equivalent tothis one via foreign key or other criterion.
- class
sqlalchemy.sql.expression.
TypeCoerce
(expression, type_) - Bases:
sqlalchemy.sql.expression.ColumnElement
Represent a Python-side type-coercion wrapper.
TypeCoerce
supplies the expression.type_coerce()
function; see that function for usage details.
Changed in version 1.1: The type_coerce()
function now producesa persistent TypeCoerce
wrapper object rather thantranslating the given object in place.
See also
init
(expression, type)[](https://docs.sqlalchemy.org/en/13/core/#sqlalchemy.sql.expression.TypeCoerce.init_)- Construct a new
TypeCoerce
object.
This constructor is mirrored as a public API function; see type_coerce()
for a full usage and argument description.
getchildren
(**kwargs_)- Return immediate child elements of this
ClauseElement
.
This is used for visit traversal.
**kwargs may contain flags that change the collection that isreturned, for example to return a subset of items in order tocut down on larger traversals, or to return child items from adifferent context (such as schema-level collections instead ofclause-level).
- class
sqlalchemy.sql.operators.
customop
(_opstring, precedence=0, is_comparison=False, return_type=None, natural_self_precedent=False, eager_grouping=False) - Represent a ‘custom’ operator.
custom_op
is normally instantiated when theOperators.op()
or Operators.bool_op()
methodsare used to create a custom operator callable. The class can also beused directly when programmatically constructing expressions. E.g.to represent the “factorial” operation:
- from sqlalchemy.sql import UnaryExpression
- from sqlalchemy.sql import operators
- from sqlalchemy import Numeric
- unary = UnaryExpression(table.c.somecolumn,
- modifier=operators.custom_op("!"),
- type_=Numeric)
See also
Implements base methodsoperate()
andreverse_operate()
, as well asand()
,or()
,invert()
.
Usually is used via its most common subclassColumnOperators
.
When used with SQL expressions, results in anAND operation, equivalent toand_()
, that is:
- a & b
is equivalent to:
- from sqlalchemy import and_
- and_(a, b)
Care should be taken when using &
regardingoperator precedence; the &
operator has the highest precedence.The operands should be enclosed in parenthesis if they containfurther sub expressions:
- (a == 2) & (b == 4)
When used with SQL expressions, results in aNOT operation, equivalent tonot_()
, that is:
- ~a
is equivalent to:
- from sqlalchemy import not_
- not_(a)
When used with SQL expressions, results in anOR operation, equivalent toor_()
, that is:
- a | b
is equivalent to:
- from sqlalchemy import or_
- or_(a, b)
Care should be taken when using |
regardingoperator precedence; the |
operator has the highest precedence.The operands should be enclosed in parenthesis if they containfurther sub expressions:
- (a == 2) | (b == 4)
This method is shorthand for callingOperators.op()
and passing theOperators.op.is_comparison
flag with True.
New in version 1.2.0b3.
See also
op
(opstring, precedence=0, is_comparison=False, return_type=None)- produce a generic operator function.
e.g.:
- somecolumn.op("*")(5)
produces:
- somecolumn * 5
This function can also be used to make bitwise operators explicit. Forexample:
- somecolumn.op('&')(0xff)
is a bitwise AND of the value in somecolumn
.
- Parameters
-
-
operator – a string which will be output as the infix operatorbetween this element and the expression passed to thegenerated function.
-
precedence – precedence to apply to the operator, whenparenthesizing expressions. A lower number will cause the expressionto be parenthesized when applied against another operator withhigher precedence. The default value of 0
is lower than alloperators except for the comma (,
) and AS
operators.A value of 100 will be higher or equal to all operators, and -100will be lower than or equal to all operators.
-
if True, the operator will be considered as a“comparison” operator, that is which evaluates to a booleantrue/false value, like ==
, >
, etc. This flag should be setso that ORM relationships can establish that the operator is acomparison operator when used in a custom join condition.
New in version 0.9.2: - added theOperators.op.is_comparison
flag.
-
a TypeEngine
class or object that willforce the return type of an expression produced by this operatorto be of that type. By default, operators that specifyOperators.op.is_comparison
will resolve toBoolean
, and those that do not will be of the sametype as the left-hand operand.
New in version 1.2.0b3: - added theOperators.op.return_type
argument.
See also
Redefining and Creating New Operators
Using custom operators in join conditions
This is the lowest level of operation, raisesNotImplementedError
by default.
Overriding this on a subclass can allow commonbehavior to be applied to all operations.For example, overriding ColumnOperators
to apply func.lower()
to the left and rightside:
- class MyComparator(ColumnOperators):
- def operate(self, op, other):
- return op(func.lower(self), func.lower(other))
- Parameters
-
-
-
*other – the ‘other’ side of the operation. Willbe a single scalar for most operations.
-
**kwargs – modifiers. These may be passed by specialoperators such as ColumnOperators.contains()
.
Usage is the same as operate()
.
- class
sqlalchemy.sql.elements.
quoted_name
- Bases:
sqlalchemy.util.langhelpers.MemoizedSlots
,builtins.str
Represent a SQL identifier combined with quoting preferences.
quoted_name
is a Python unicode/str subclass whichrepresents a particular identifier name along with aquote
flag. This quote
flag, when set toTrue
or False
, overrides automatic quoting behaviorfor this identifier in order to either unconditionally quoteor to not quote the name. If left at its default of None
,quoting behavior is applied to the identifier on a per-backend basisbased on an examination of the token itself.
A quoted_name
object with quote=True
is alsoprevented from being modified in the case of a so-called“name normalize” option. Certain database backends, such asOracle, Firebird, and DB2 “normalize” case-insensitive namesas uppercase. The SQLAlchemy dialects for these backendsconvert from SQLAlchemy’s lower-case-means-insensitive conventionto the upper-case-means-insensitive conventions of those backends.The quote=True
flag here will prevent this conversion from occurringto support an identifier that’s quoted as all lower case againstsuch a backend.
The quoted_name
object is normally created automaticallywhen specifying the name for key schema constructs such asTable
, Column
, and others. The class can also bepassed explicitly as the name to any function that receives a name whichcan be quoted. Such as to use the Engine.has_table()
method withan unconditionally quoted name:
- from sqlalchemy import create_engine
- from sqlalchemy.sql import quoted_name
- engine = create_engine("oracle+cx_oracle://some_dsn")
- engine.has_table(quoted_name("some_table", True))
The above logic will run the “has table” logic against the Oracle backend,passing the name exactly as "some_table"
without converting toupper case.
New in version 0.9.0.
Changed in version 1.2: The quoted_name
construct is nowimportable from sqlalchemy.sql
, in addition to the previouslocation of sqlalchemy.sql.elements
.
- class
sqlalchemy.sql.expression.
UnaryExpression
(element, operator=None, modifier=None, type=None, _negate=None, wraps_column_expression=False) - Bases:
sqlalchemy.sql.expression.ColumnElement
Define a ‘unary’ expression.
A unary expression has a single column expressionand an operator. The operator can be placed on the left(where it is called the ‘operator’) or right (where it is called the‘modifier’) of the column expression.
UnaryExpression
is the basis for several unary operatorsincluding those used by desc()
, asc()
, distinct()
,nullsfirst()
and nullslast()
.
compare
(other, **kw)Compare this
UnaryExpression
against the givenClauseElement
.- Return immediate child elements of this
ClauseElement
.
This is used for visit traversal.
**kwargs may contain flags that change the collection that isreturned, for example to return a subset of items in order tocut down on larger traversals, or to return child items from adifferent context (such as schema-level collections instead ofclause-level).
selfgroup
(_against=None)- Apply a ‘grouping’ to this
ClauseElement
.
This method is overridden by subclasses to return a“grouping” construct, i.e. parenthesis. In particularit’s used by “binary” expressions to provide a groupingaround themselves when placed into a larger expression,as well as by select()
constructs when placed intothe FROM clause of another select()
. (Note thatsubqueries should be normally created using theSelect.alias()
method, as many platforms requirenested SELECT statements to be named).
As expressions are composed together, the application ofself_group()
is automatic - end-user code should neverneed to use this method directly. Note that SQLAlchemy’sclause constructs take operator precedence into account -so parenthesis might not be needed, for example, inan expression like x OR (y AND z)
- AND takes precedenceover OR.
The base self_group()
method of ClauseElement
just returns self.