SqlAlchemy 2.0 中文文档(三十五)(1)https://developer.aliyun.com/article/1562891
参数:
count
- 一个整数 COUNT 参数,或者提供整数结果的 SQL 表达式。当percent=True
时,这将表示要返回的行数的百分比,而不是绝对值。传递None
来重置它。with_ties
- 当为True
时,使用 WITH TIES 选项来返回结果集中与ORDER BY
子句中最后一位并列的任何其他行。在这种情况下,ORDER BY
可能是强制性的。默认为False
。percent
- 当为True
时,count
表示要返回的所选行总数的百分比。默认为False
。
另请参阅
GenerativeSelect.limit()
GenerativeSelect.offset()
method get_execution_options() → _ExecuteOptions
继承自 Executable.get_execution_options()
方法的 Executable
获取在执行期间生效的非 SQL 选项。
自版本 1.3 起新增。
另请参阅
Executable.execution_options()
method get_label_style() → SelectLabelStyle
继承自 GenerativeSelect.get_label_style()
方法的 GenerativeSelect
检索当前的标签样式。
自版本 1.4 起新增。
method group_by(_GenerativeSelect__first: Literal[None, _NoArg.NO_ARG] | _ColumnExpressionOrStrLabelArgument[Any] = _NoArg.NO_ARG, *clauses: _ColumnExpressionOrStrLabelArgument[Any]) → Self
继承自 GenerativeSelect.group_by()
方法的 GenerativeSelect
返回一个应用了给定的 GROUP BY 标准列表的新可选择对象。
通过传递None
可以抑制所有现有的 GROUP BY 设置。
例如:
stmt = select(table.c.name, func.max(table.c.stat)).\ group_by(table.c.name)
参数:
*子句 – 一系列将用于生成 GROUP BY 子句的 ColumnElement
构造。
另请参阅
带有 GROUP BY / HAVING 的聚合函数 - 在 SQLAlchemy 统一教程 中
按标签排序或分组 - 在 SQLAlchemy 统一教程 中
method is_derived_from(fromclause: FromClause | None) → bool
如果此 ReturnsRows
是从给定的 FromClause
‘派生’的,则返回 True
。
一个示例是一个表的别名是从该表派生的。
method label(name: str | None) → Label[Any]
继承自 SelectBase.label()
方法的 SelectBase
返回此可选择对象的‘标量’表示,嵌入为带有标签的子查询。
另请参阅
SelectBase.scalar_subquery()
。
method lateral(name: str | None = None) → LateralFromClause
继承自 SelectBase.lateral()
方法的 SelectBase
返回此 Selectable
的 LATERAL 别名。
返回值是顶层 lateral()
函数提供的 Lateral
构造。
另请参阅
LATERAL 关联 - 用法概述。
method limit(limit: _LimitOffsetType) → Self
继承自 GenerativeSelect.limit()
方法的 GenerativeSelect
返回应用了给定 LIMIT 条件的新可选择对象。
这是一个通常呈现为 LIMIT
表达式的数值值,在生成的选择中。不支持 LIMIT
的后端将尝试提供类似的功能。
注意
GenerativeSelect.limit()
方法将替换应用的任何子句,使用 GenerativeSelect.fetch()
。
参数:
limit – 整数 LIMIT 参数,或提供整数结果的 SQL 表达式。传递None
来重置它。
另请参见
GenerativeSelect.fetch()
GenerativeSelect.offset()
method offset(offset: _LimitOffsetType) → Self
继承自 GenerativeSelect.offset()
的 GenerativeSelect
方法
返回一个应用了给定 OFFSET 条件的新可选择项。
这是一个通常渲染为结果选择中的OFFSET
表达式的数值。不支持OFFSET
的后端将尝试提供类似的功能。
参数:
offset – 整数 OFFSET 参数,或提供整数结果的 SQL 表达式。传递None
来重置它。
另请参见
GenerativeSelect.limit()
GenerativeSelect.fetch()
method options(*options: ExecutableOption) → Self
继承自 Executable.options()
的 Executable
方法
对该语句应用选项。
从一般意义上讲,选项是任何可以由语句的 SQL 编译器解释的 Python 对象。这些选项可以被特定方言或特定类型的编译器消耗。
最常见的选项类型是应用“急加载”和其他加载行为到 ORM 查询的 ORM 级别选项。然而,选项理论上可以用于许多其他目的。
关于特定类型语句的特定类型选项的背景,请参阅这些选项对象的文档。
自版本 1.4 起更改:- 将Executable.options()
添加到核心语句对象,以实现统一的核心/ORM 查询功能目标。
另请参见
列加载选项 - 指的是用于 ORM 查询的使用特定选项的选项
带有加载器选项的关系加载 - 指的是用于 ORM 查询的使用特定选项的选项
method order_by(_GenerativeSelect__first: Literal[None, _NoArg.NO_ARG] | _ColumnExpressionOrStrLabelArgument[Any] = _NoArg.NO_ARG, *clauses: _ColumnExpressionOrStrLabelArgument[Any]) → Self
继承自 GenerativeSelect.order_by()
的 GenerativeSelect
方法
返回一个应用了给定 ORDER BY 条件列表的新可选择性。
例如:
stmt = select(table).order_by(table.c.id, table.c.name)
多次调用此方法相当于一次性将所有子句连接起来调用一次。 通过单独传递None
可以取消所有现有的 ORDER BY 条件。 然后可以通过再次调用Query.order_by()
来添加新的 ORDER BY 条件,例如:
# will erase all ORDER BY and ORDER BY new_col alone stmt = stmt.order_by(None).order_by(new_col)
参数:
*子句 – 一系列将用于生成 ORDER BY 子句的ColumnElement
构造。
另请参阅
ORDER BY - 在 SQLAlchemy 统一教程中
按标签排序或分组 - 在 SQLAlchemy 统一教程中
method replace_selectable(old: FromClause, alias: Alias) → Self
继承自 Selectable.replace_selectable()
方法的 Selectable
用给定的Alias
对象替换所有FromClause
‘old’的所有出现,返回此FromClause
的副本。
自版本 1.4 起弃用:Selectable.replace_selectable()
方法已弃用,并将在将来的版本中删除。 通过 sqlalchemy.sql.visitors 模块可以获得类似的功能。
method scalar_subquery() → ScalarSelect[Any]
继承自 SelectBase.scalar_subquery()
方���的 SelectBase
返回此可选择性的‘标量’表示,可用作列表达式。
返回的对象是ScalarSelect
的一个实例。
通常,在其 columns 子句中只有一个列的 select 语句有资格用作标量表达式。 然后可以在封闭 SELECT 的 WHERE 子句或 columns 子句中使用标量子查询。
请注意,标量子查询与使用SelectBase.subquery()
方法生成的 FROM 级子查询不同。
另请参阅
标量和相关子查询 - 在 2.0 教程中
method select(*arg: Any, **kw: Any) → Select
继承自 SelectBase
方法的 SelectBase.select()
自版本 1.4 起弃用:SelectBase.select()
方法已弃用,并将在将来的版本中删除;此方法隐式创建一个应明确的子查询。请先调用SelectBase.subquery()
以创建子查询,然后可以选择它。
attribute selected_columns
一个ColumnCollection
代表此 SELECT 语句或类似结构在其结果集中返回的列,不包括TextClause
构造。
对于CompoundSelect
,CompoundSelect.selected_columns
属性返回一系列语句中第一个 SELECT 语句的选定列。
另请参阅
Select.selected_columns
版本 1.4 中新增。
method self_group(against: OperatorType | None = None) → GroupedElement
对这个ClauseElement
应用一个“分组”。
此方法被子类重写以返回一个“分组”构造,即括号。特别是它被“二进制”表达式使用时,当它们被放置到更大的表达式中时,提供了一个围绕自身的分组,以及当select()
构造被放置到另一个select()
的 FROM 子句中时。(请注意,子查询通常应使用Select.alias()
方法创建,因为许多平台要求嵌套的 SELECT 语句需要命名)。
随着表达式的组合,self_group()
的应用是自动的 - 最终用户代码不应直接使用此方法。请注意,SQLAlchemy 的子句构造考虑了操作符优先级 - 因此在表达式中可能不需要括号,例如x OR (y AND z)
- AND 优先于 OR。
ClauseElement
的基本self_group()
方法只返回 self。
method set_label_style(style: SelectLabelStyle) → CompoundSelect
返回具有指定标签样式的新可选择项。
有三种“标签样式”可用,SelectLabelStyle.LABEL_STYLE_DISAMBIGUATE_ONLY
、SelectLabelStyle.LABEL_STYLE_TABLENAME_PLUS_COL
和SelectLabelStyle.LABEL_STYLE_NONE
。默认样式是SelectLabelStyle.LABEL_STYLE_TABLENAME_PLUS_COL
。
在现代 SQLAlchemy 中,通常不需要更改标签样式,因为通过使用ColumnElement.label()
方法更有效地使用逐表达式标签。在过去的版本中,LABEL_STYLE_TABLENAME_PLUS_COL
用于消除来自不同表、别名或子查询的同名列的歧义;较新的LABEL_STYLE_DISAMBIGUATE_ONLY
现在仅对与现有名称冲突的名称应用标签,因此此标签的影响最小。
消除歧义的理由主要是为了在创建子查询时从给定的FromClause.c
集合中使所有列表达式可用。
从版本 1.4 开始:- GenerativeSelect.set_label_style()
方法替换了以前的.apply_labels()
、.with_labels()
和use_labels=True
方法和/或参数的组合。
另请参阅
LABEL_STYLE_DISAMBIGUATE_ONLY
LABEL_STYLE_TABLENAME_PLUS_COL
LABEL_STYLE_NONE
LABEL_STYLE_DEFAULT
method slice(start: int, stop: int) → Self
继承自 GenerativeSelect.slice()
方法的 GenerativeSelect
根据切片对此语句应用 LIMIT / OFFSET。
开始和停止索引的行为类似于 Python 内置range()
函数的参数。此方法提供了一种替代方法,用于使用LIMIT
/OFFSET
获取查询的切片。
例如,
stmt = select(User).order_by(User).id.slice(1, 3)
渲染为
SELECT users.id AS users_id, users.name AS users_name FROM users ORDER BY users.id LIMIT ? OFFSET ? (2, 1)
注意
GenerativeSelect.slice()
方法将替换应用的任何子句,该子句应用了 GenerativeSelect.fetch()
。
版本 1.4 中的新功能:增加了从 ORM 泛化的 GenerativeSelect.slice()
方法。
另请参阅
GenerativeSelect.limit()
GenerativeSelect.offset()
GenerativeSelect.fetch()
method subquery(name: str | None = None) → Subquery
从 SelectBase
的 SelectBase.subquery()
方法继承
返回此 SelectBase
的子查询。
从 SQL 角度看,子查询是一种括号括起来的、命名的构造,可以放置在另一个 SELECT 语句的 FROM 子句中。
假设有一个如下所示的 SELECT 语句:
stmt = select(table.c.id, table.c.name)
上述语句可能如下所示:
SELECT table.id, table.name FROM table
单独呈现子查询形式时,呈现方式相同,但是当嵌入到另一个 SELECT 语句的 FROM 子句中时,它变成了一个命名子元素:
subq = stmt.subquery() new_stmt = select(subq)
上述内容呈现为:
SELECT anon_1.id, anon_1.name FROM (SELECT table.id, table.name FROM table) AS anon_1
从历史上看,SelectBase.subquery()
等同于在 FROM 对象上调用 FromClause.alias()
方法;但是,由于 SelectBase
对象不是直接的 FROM 对象,因此 SelectBase.subquery()
方法提供了更清晰的语义。
版本 1.4 中的新功能。
method with_for_update(*, nowait: bool = False, read: bool = False, of: _ForUpdateOfArgument | None = None, skip_locked: bool = False, key_share: bool = False) → Self
从 GenerativeSelect
的 GenerativeSelect.with_for_update()
方法继承
为此 GenerativeSelect
指定一个 FOR UPDATE
子句。
例如:
stmt = select(table).with_for_update(nowait=True)
在像 PostgreSQL 或 Oracle 这样的数据库上,上述语句将呈现为如下语句:
SELECT table.a, table.b FROM table FOR UPDATE NOWAIT
在其他后端,nowait
选项将被忽略,而会产生以下输出:
SELECT table.a, table.b FROM table FOR UPDATE
当不带参数调用时,语句将带有后缀FOR UPDATE
。然后可以提供额外的参数,允许使用常见的特定于数据库的变体。
参数:
nowait
– 布尔值;在 Oracle 和 PostgreSQL 方言上会渲染FOR UPDATE NOWAIT
。read
– 布尔值;在 MySQL 上会渲染LOCK IN SHARE MODE
,在 PostgreSQL 上会渲染FOR SHARE
。在 PostgreSQL 上,与nowait
组合时,会渲染FOR SHARE NOWAIT
。of
– SQL 表达式或 SQL 表达式元素列表,(通常是Column
对象或兼容表达式,对于某些后端也可以是表达式)将渲染为FOR UPDATE OF
子句;受 PostgreSQL、Oracle、某些 MySQL 版本和可能其他后端支持。根据后端的不同,可能会渲染为表或列。skip_locked
– 布尔值,在 Oracle 和 PostgreSQL 方言上会渲染FOR UPDATE SKIP LOCKED
,如果还指定了read=True
,则会渲染FOR SHARE SKIP LOCKED
。key_share
– 布尔值,会渲染FOR NO KEY UPDATE
,或者如果与read=True
组合,会在 PostgreSQL 方言上渲染FOR KEY SHARE
。
class sqlalchemy.sql.expression.CTE
表示一个公共表达式。
CTE
对象是通过任何 SELECT 语句的SelectBase.cte()
方法获得的。较少见的语法还允许在 DML 构造上使用HasCTE.cte()
方法,例如Insert
、Update
和Delete
。查看HasCTE.cte()
方法以获取有关 CTE 的用法详细信息。
参见
子查询和 CTE - 在 2.0 教程中
HasCTE.cte()
- 调用样式示例
成员
alias(), union(), union_all()
类签名
类sqlalchemy.sql.expression.CTE
(sqlalchemy.sql.roles.DMLTableRole
, sqlalchemy.sql.roles.IsCTERole
, sqlalchemy.sql.expression.Generative
, sqlalchemy.sql.expression.HasPrefixes
, sqlalchemy.sql.expression.HasSuffixes
, sqlalchemy.sql.expression.AliasedReturnsRows
)
method alias(name: str | None = None, flat: bool = False) → CTE
返回此CTE
的Alias
。
此方法是FromClause.alias()
方法的 CTE 特定专业化。
另请参阅
使用别名
alias()
method union(*other: _SelectStatementForCompoundArgument) → CTE
返回一个新的CTE
,其中包含原始 CTE 与提供的可选参数作为位置参数的 SQL UNION
。
参数:
*其他 –
一个或多个用于创建 UNION 的元素。
从版本 1.4.28 更改:现在接受多个元素。
另请参阅
HasCTE.cte()
- 调用样式示例
method union_all(*other: _SelectStatementForCompoundArgument) → CTE
返回一个新的CTE
,其中包含原始 CTE 与提供的可选参数作为位置参数的 SQL UNION ALL
。
参数:
*其他 –
一个或多个用于创建 UNION 的元素。
从版本 1.4.28 更改:现在接受多个元素。
另请参阅
HasCTE.cte()
- 调用样式示例
class sqlalchemy.sql.expression.Executable
将一个ClauseElement
标记为支持执行。
Executable
是所有“语句”类型对象的超类,包括select()
、delete()
、update()
、insert()
、text()
。
成员
execution_options(), get_execution_options(), options()
类签名
类sqlalchemy.sql.expression.Executable
(sqlalchemy.sql.roles.StatementRole
)
method execution_options(**kw: Any) → Self
为语句设置在执行期间生效的非 SQL 选项。
可以在多个范围设置执行选项,包括每个语句、每个连接或每次执行,使用诸如Connection.execution_options()
和接受选项字典的参数的方法,如Connection.execute.execution_options
和Session.execute.execution_options
。
执行选项的主要特征与其他类型的选项(如 ORM 加载器选项)不同,执行选项永远不会影响查询的编译 SQL,只会影响 SQL 语句本身的调用方式或结果的获取方式。也就是说,执行选项不是 SQL 编译所考虑的内容,也不被视为语句的缓存状态的一部分。
Executable.execution_options()
方法是生成的,就像应用于Engine
和Query
对象的方法一样,这意味着当调用该方法时,会返回对象的副本,将给定的参数应用于该新副本,但原始对象保持不变:
statement = select(table.c.x, table.c.y) new_statement = statement.execution_options(my_option=True)
一个例外是Connection
对象,其中Connection.execution_options()
方法明确地不是生成的。
可以传递给Executable.execution_options()
和其他相关方法和参数字典的选项类型包括被 SQLAlchemy Core 或 ORM 明确消耗的参数,以及 SQLAlchemy 未定义的任意关键字参数,这意味着这些方法和/或参数字典可用于与自定义代码交互的用户定义参数,可以使用诸如Executable.get_execution_options()
和Connection.get_execution_options()
等方法访问参数,或者在选定的事件钩子中使用专用的execution_options
事件参数,例如ConnectionEvents.before_execute.execution_options
或ORMExecuteState.execution_options
,例如:
from sqlalchemy import event @event.listens_for(some_engine, "before_execute") def _process_opt(conn, statement, multiparams, params, execution_options): "run a SQL function before invoking a statement" if execution_options.get("do_special_thing", False): conn.exec_driver_sql("run_special_function()")
在 SQLAlchemy 明确识别的选项范围内,大多数适用于特定类别的对象而不是其他对象。最常见的执行选项包括:
Connection.execution_options.isolation_level
- 通过Engine
为连接或一类连接设置隔离级别。此选项仅被Connection
或Engine
接受。Connection.execution_options.stream_results
- 表示应使用服务器端游标获取结果;此选项被Connection
,Connection.execute()
上的Connection.execute.execution_options
参数以及 SQL 语句对象上的Executable.execution_options()
以及 ORM 构造如Session.execute()
所接受。Connection.execution_options.compiled_cache
- 表示将作为Connection
或Engine
的 SQL 编译缓存的字典,以及Session.execute()
等 ORM 方法的缓存。 可以传递为None
以禁用语句的缓存。 此选项不被Executable.execution_options()
接受,因为在语句对象中携带编译缓存是不明智的。Connection.execution_options.schema_translate_map
- 用于模式转换映射功能的模式名称映射,被Connection
,Engine
,Executable
接受,以及 ORM 构造如Session.execute()
。
参见
Connection.execution_options()
Connection.execute.execution_options
Session.execute.execution_options
ORM 执行选项 - 所有 ORM 特定执行选项的文档
method get_execution_options() → _ExecuteOptions
获取在执行期间生效的非 SQL 选项。
版本 1.3 中的新功能。
另请参阅
Executable.execution_options()
method options(*options: ExecutableOption) → Self
将选项应用于此语句。
一般来说,选项是任何可以被 SQL 编译器解释为语句的 Python 对象。这些选项可以被特定的方言或特定类型的编译器消耗。
最常见的选项类型是应用“急加载”和其他加载行为到 ORM 查询的 ORM 级选项。然而,选项理论上可以用于许多其他目的。
有关特定类型语句的特定类型选项的背景,请参阅这些选项对象的文档。
版本 1.4 中的更改:- 向核心语句对象添加了 Executable.options()
,以实现统一的核心 / ORM 查询功能。
另请参阅
列加载选项 - 指特定于 ORM 查询使用的选项
使用加载器选项加载关系 - 指特定于 ORM 查询使用的选项
class sqlalchemy.sql.expression.Exists
表示一个 EXISTS
子句。
请参阅 exists()
以获取用法描述。
通过调用 SelectBase.exists()
可以从 select()
实例构建 EXISTS
子句。
成员
correlate(), correlate_except(), inherit_cache, select(), select_from(), where()
类签名
类 sqlalchemy.sql.expression.Exists
(sqlalchemy.sql.expression.UnaryExpression
)
method correlate(*fromclauses: Literal[None, False] | _FromClauseArgument) → Self
将相关性应用于由此 Exists
指示的子查询。
另请参阅
ScalarSelect.correlate()
method correlate_except(*fromclauses: Literal[None, False] | _FromClauseArgument) → Self
将关联应用于由此 Exists
指示的子查询。
参见
ScalarSelect.correlate_except()
attribute inherit_cache: bool | None = True
指示此 HasCacheKey
实例是否应该使用其直接超类使用的缓存键生成方案。
该属性默认为 None
,表示结构尚未考虑是否适合参与缓存;这在功能上等同于将值设置为 False
,只是还会发出警告。
如果与对象对应的 SQL 不会基于仅属于此类而不属于其超类的属性更改,则可以将此标志设置为 True
。
参见
为自定义结构启用缓存支持 - 为第三方或用户定义的 SQL 结构设置 HasCacheKey.inherit_cache
属性的通用指南。
method select() → Select
返回此 Exists
的 SELECT。
例如:
stmt = exists(some_table.c.id).where(some_table.c.id == 5).select()
这将生成一个类似于的语句:
SELECT EXISTS (SELECT id FROM some_table WHERE some_table = :param) AS anon_1
参见
select()
- 允许任意列列表的通用方法。
method select_from(*froms: _FromClauseArgument) → Self
返回一个新的 Exists
构造,将给定表达式应用于包含的 select 语句的 Select.select_from()
方法。
注意
通常最好首先构建一个 Select
语句,包括所需的 WHERE 子句,然后一次使用 SelectBase.exists()
方法生成一个 Exists
对象。
method where(*clause: _ColumnExpressionArgument[bool]) → Self
返回一个新的带有给定表达式添加到其 WHERE 子句中的 exists()
构造,如果有的话,通过 AND 连接到现有子句。
注意
通常最好先构建一个包含所需 WHERE 子句的 Select
语句,然后立即使用 SelectBase.exists()
方法生成一个 Exists
对象。
class sqlalchemy.sql.expression.FromClause
表示可以在 SELECT
语句的 FROM
子句中使用的元素。
最常见的 FromClause
形式是 Table
和 select()
构造。所有 FromClause
对象的共同特征包括:
- 一个
c
集合,提供对一组ColumnElement
对象的按名称访问。 - 一个
primary_key
属性,其中包含所有指示primary_key
标志的ColumnElement
对象的集合。 - 生成各种“from”子句的方法,包括
FromClause.alias()
、FromClause.join()
、FromClause.select()
。
成员
alias(), c, columns, description, entity_namespace, exported_columns, foreign_keys, is_derived_from(), join(), outerjoin(), primary_key, schema, select(), tablesample()
类签名
类sqlalchemy.sql.expression.FromClause
(sqlalchemy.sql.roles.AnonymizedFromClauseRole
, sqlalchemy.sql.expression.Selectable
)
method alias(name: str | None = None, flat: bool = False) → NamedFromClause
返回此FromClause
的别名。
例如:
a2 = some_table.alias('a2')
上述代码创建了一个Alias
对象,可以在任何 SELECT 语句中作为 FROM 子句使用。
另请参阅
使用别名
alias()
attribute c
FromClause.columns
的同义词
返回:
一个ColumnCollection
。
attribute columns
此FromClause
维护的ColumnElement
对象的基于名称的集合。
columns
或c
集合是使用与表绑定或其他可选择绑定的列构造 SQL 表达式的入口:
select(mytable).where(mytable.c.somecolumn == 5)
返回:
一个ColumnCollection
对象。
attribute description
此FromClause
的简要描述。
主要用于错误消息格式化。
attribute entity_namespace
返回一个用于在 SQL 表达式中基于名称访问的命名空间。
这是用于解析“filter_by()”类型表达式的命名空间,例如:
stmt.filter_by(address='some address')
默认为.c
集合,但在内部可以使用“entity_namespace”注释进行覆盖以提供替代结果。
attribute exported_columns
一个ColumnCollection
,表示此Selectable
的“导出”列。
FromClause
对象的“导出”列与FromClause.columns
集合是同义词。
新版本中新增。
另请参阅
Selectable.exported_columns
SelectBase.exported_columns
attribute foreign_keys
返回此 FromClause
引用的 ForeignKey
标记对象的集合。
每个 ForeignKey
都是一个属于 Table
-范围的 ForeignKeyConstraint
的成员。
另请参见
Table.foreign_key_constraints
method is_derived_from(fromclause: FromClause | None) → bool
如果此 FromClause
是从给定的 FromClause
衍生出来的,则返回 True
。
一个示例是一个表的别名是从该表派生的。
method join(right: _FromClauseArgument, onclause: _ColumnExpressionArgument[bool] | None = None, isouter: bool = False, full: bool = False) → Join
从此 FromClause
返回一个 Join
到另一个 FromClause
。
例如:
from sqlalchemy import join j = user_table.join(address_table, user_table.c.id == address_table.c.user_id) stmt = select(user_table).select_from(j)
将会发出类似以下的 SQL:
SELECT user.id, user.name FROM user JOIN address ON user.id = address.user_id
参数:
right
– 连接的右侧;这是任何FromClause
对象,如Table
对象,也可以是一个可选择兼容对象,如 ORM 映射的类。onclause
– 表示连接的 ON 子句的 SQL 表达式。如果保留为None
,则FromClause.join()
将尝试根据外键关系连接两个表。isouter
– 如果为 True,则渲染一个左外连接,而不是连接。full
– 如果为 True,则渲染一个完整的外连接,而不是左外连接。意味着FromClause.join.isouter
。
另请参见
join()
- 独立函数
Join
- 生成的对象类型
method outerjoin(right: _FromClauseArgument, onclause: _ColumnExpressionArgument[bool] | None = None, full: bool = False) → Join
从此 FromClause
返回一个带有 “isouter” 标志设置为 True 的 Join
到另一个 FromClause
。
例如:
from sqlalchemy import outerjoin j = user_table.outerjoin(address_table, user_table.c.id == address_table.c.user_id)
以上等同于:
j = user_table.join( address_table, user_table.c.id == address_table.c.user_id, isouter=True)
参数:
right
– 连接的右侧;这是任何FromClause
对象,例如Table
对象,也可以是 ORM 映射的类等可选兼容对象。onclause
– 代表连接的 ON 子句的 SQL 表达式。如果留空,FromClause.join()
将尝试根据外键关系连接两个表。full
– 如果为 True,则渲染 FULL OUTER JOIN,而不是 LEFT OUTER JOIN。
另见
FromClause.join()
Join
attribute primary_key
返回这个 _selectable.FromClause
的主键所组成的可迭代列 Column
对象集合。
对于 Table
对象,这个集合由 PrimaryKeyConstraint
表示,它本身是一个可迭代的 Column
对象集合。
attribute schema: str | None = None
为这个 FromClause
定义 ‘schema’ 属性。
对于大多数对象而言,这通常为 None
,除了 Table
的情况,其中它被视为 Table.schema
参数的值。
method select() → Select
返回这个 FromClause
的 SELECT。
例如:
stmt = some_table.select().where(some_table.c.id == 5)
另见
select()
- 允许任意列列表的通用方法。
method tablesample(sampling: float | Function[Any], name: str | None = None, seed: roles.ExpressionElementRole[Any] | None = None) → TableSample
返回这个 FromClause
的 TABLESAMPLE 别名。
返回值也是顶层 tablesample()
函数提供的 TableSample
构造。
另见
tablesample()
- 使用指南和参数
class sqlalchemy.sql.expression.GenerativeSelect
可以添加额外元素的 SELECT 语句的基类。
这用作Select
和CompoundSelect
的基础,其中可以添加诸如 ORDER BY、GROUP BY 之类的元素,并且可以控制列的呈现。与TextualSelect
相比,虽然它是SelectBase
的子类,并且也是一个 SELECT 构造,但它代表的是一个固定的文本字符串,无法在这个级别上更改,只能包装为子查询。
成员
fetch(), get_label_style(), group_by(), limit(), offset(), order_by(), set_label_style(), slice(), with_for_update()
类签名
class sqlalchemy.sql.expression.GenerativeSelect
(sqlalchemy.sql.expression.SelectBase
, sqlalchemy.sql.expression.Generative
)
method fetch(count: _LimitOffsetType, with_ties: bool = False, percent: bool = False) → Self
使用给定的 FETCH FIRST 标准返回一个新的可选择的。
这是一个数值,通常在结果选择中呈现为FETCH {FIRST | NEXT} [ count ] {ROW | ROWS} {ONLY | WITH TIES}
表达式。此功能目前已为 Oracle、PostgreSQL、MSSQL 实现。
使用GenerativeSelect.offset()
来指定偏移量。
注意
GenerativeSelect.fetch()
方法将替换任何应用于GenerativeSelect.limit()
的子句。
1.4 版中的新功能。
参数:
count
– 一个整数 COUNT 参数,或者提供整数结果的 SQL 表达式。当percent=True
时,这将表示要返回的行的百分比,而不是绝对值。传递None
来重置它。with_ties
– 当为True
时,使用 WITH TIES 选项来返回任何根据ORDER BY
子句在结果集中处于最后位置的附加行。在这种情况下,ORDER BY
可能是强制性的。默认为False
percent
– 当True
时,count
表示要返回的所选行总数的百分比。默认为False
。
另请参阅
GenerativeSelect.limit()
GenerativeSelect.offset()
method get_label_style() → SelectLabelStyle
检索当前的标签样式。
1.4 版本中的新内容。
method group_by(_GenerativeSelect__first: Literal[None, _NoArg.NO_ARG] | _ColumnExpressionOrStrLabelArgument[Any] = _NoArg.NO_ARG, *clauses: _ColumnExpressionOrStrLabelArgument[Any]) → Self
返回具有给定的 GROUP BY 条件列表的新可选择对象。
通过传递None
可以抑制所有现有的 GROUP BY 设置。
例如:
stmt = select(table.c.name, func.max(table.c.stat)).\ group_by(table.c.name)
参数:
*clauses – 一系列将用于生成 GROUP BY 子句的ColumnElement
构造。
另请参阅
带有 GROUP BY / HAVING 的聚合函数 - 在 SQLAlchemy 统一教程中
按标签排序或分组 - 在 SQLAlchemy 统一教程中
method limit(limit: _LimitOffsetType) → Self
返回具有给定 LIMIT 条件的新可选择对象。
这是一个数值,通常在结果选择中呈现为LIMIT
表达式。不支持LIMIT
的后端将尝试提供类似的功能。
注意
GenerativeSelect.limit()
方法将替换应用的任何子句与GenerativeSelect.fetch()
。
参数:
limit – 一个整数 LIMIT 参数,或者提供整数结果的 SQL 表达式。传递None
来重置它。
另请参阅
GenerativeSelect.fetch()
GenerativeSelect.offset()
method offset(offset: _LimitOffsetType) → Self
返回具有给定 OFFSET 条件的新可选择对象。
这是一个数值,通常在结果选择中呈现为OFFSET
表达式。不支持OFFSET
的后端将尝试提供类似的功能。
参数:
offset – 一个整数 OFFSET 参数,或者提供整数结果的 SQL 表达式。传递None
来重置它。
另请参阅
GenerativeSelect.limit()
GenerativeSelect.fetch()
method order_by(_GenerativeSelect__first: Literal[None, _NoArg.NO_ARG] | _ColumnExpressionOrStrLabelArgument[Any] = _NoArg.NO_ARG, *clauses: _ColumnExpressionOrStrLabelArgument[Any]) → Self
返回具有给定的 ORDER BY 条件列表的新可选择对象。
例如:
stmt = select(table).order_by(table.c.id, table.c.name)
多次调用此方法等效于将所有子句连接一次。所有现有的 ORDER BY 条件都可以通过单独传递 None
来取消。然后,可以通过再次调用 Query.order_by()
来添加新的 ORDER BY 条件,例如:
# will erase all ORDER BY and ORDER BY new_col alone stmt = stmt.order_by(None).order_by(new_col)
参数:
*clauses – 一系列用于生成 ORDER BY 子句的 ColumnElement
构造。
请参见
ORDER BY - 在 SQLAlchemy 统一教程中
按标签排序或分组 - 在 SQLAlchemy 统一教程中
method set_label_style(style: SelectLabelStyle) → Self
返回具有指定标签样式的新可选择项。
有三种“标签样式”可用,SelectLabelStyle.LABEL_STYLE_DISAMBIGUATE_ONLY
、SelectLabelStyle.LABEL_STYLE_TABLENAME_PLUS_COL
和 SelectLabelStyle.LABEL_STYLE_NONE
。默认样式是 SelectLabelStyle.LABEL_STYLE_TABLENAME_PLUS_COL
。
在现代 SQLAlchemy 中,通常不需要更改标签样式,因为通过使用 ColumnElement.label()
方法更有效地使用每个表达式的标签。在以前的版本中,LABEL_STYLE_TABLENAME_PLUS_COL
用于消除来自不同表、别名或子查询的相同命名列的歧义; 新的 LABEL_STYLE_DISAMBIGUATE_ONLY
现在仅将标签应用于与现有名称冲突的名称,以使此标签的影响最小化。
消除歧义的原因主要是在创建子查询时,所有列表达式都可以从给定的 FromClause.c
集合中使用。
从版本 1.4 开始: - GenerativeSelect.set_label_style()
方法取代了先前的 .apply_labels()
、.with_labels()
和 use_labels=True
方法和/或参数的组合。
请参见
LABEL_STYLE_DISAMBIGUATE_ONLY
LABEL_STYLE_TABLENAME_PLUS_COL
LABEL_STYLE_NONE
LABEL_STYLE_DEFAULT
method slice(start: int, stop: int) → Self
根据一个切片对该语句应用 LIMIT / OFFSET。
起始和停止索引的行为类似于 Python 内置的 range()
函数的参数。此方法提供了一个替代方案,用于使用 LIMIT
/OFFSET
获取查询的一个切片。
例如,
stmt = select(User).order_by(User).id.slice(1, 3)
渲染为
SELECT users.id AS users_id, users.name AS users_name FROM users ORDER BY users.id LIMIT ? OFFSET ? (2, 1)
注意
GenerativeSelect.slice()
方法将替换任何使用 GenerativeSelect.fetch()
应用的子句。
自 1.4 版本新增:从 ORM 推广出的 GenerativeSelect.slice()
方法。
另请参见
GenerativeSelect.limit()
GenerativeSelect.offset()
GenerativeSelect.fetch()
method with_for_update(*, nowait: bool = False, read: bool = False, of: _ForUpdateOfArgument | None = None, skip_locked: bool = False, key_share: bool = False) → Self
为此 GenerativeSelect
指定一个 FOR UPDATE
子句。
例如:
stmt = select(table).with_for_update(nowait=True)
在像 PostgreSQL 或 Oracle 这样的数据库上,上述内容将渲染为类似于以下语句:
SELECT table.a, table.b FROM table FOR UPDATE NOWAIT
在其他后端,nowait
选项将被忽略,并且会产生:
SELECT table.a, table.b FROM table FOR UPDATE
在不带参数调用时,该语句将以后缀 FOR UPDATE
渲染。然后可以提供其他参数,以允许常见的数据库特定变体。
参数:
nowait
– 布尔值;将在 Oracle 和 PostgreSQL 方言上渲染为FOR UPDATE NOWAIT
。read
– 布尔值;将在 MySQL 上渲染为LOCK IN SHARE MODE
,在 PostgreSQL 上渲染为FOR SHARE
。在 PostgreSQL 上,当与nowait
结合使用时,将渲染为FOR SHARE NOWAIT
。of
– SQL 表达式或 SQL 表达式元素列表(通常是Column
对象或兼容的表达式,对于某些后端,也可以是表达式);它将被渲染为一个FOR UPDATE OF
子句;受 PostgreSQL、Oracle、一些 MySQL 版本和可能其他一些后端的支持。根据后端的不同,可能会渲染为表或列。skip_locked
– 布尔值,将在 Oracle 和 PostgreSQL 方言上渲染为FOR UPDATE SKIP LOCKED
,如果还指定了read=True
,则会渲染为FOR SHARE SKIP LOCKED
。key_share
– 布尔值,将在 PostgreSQL 方言上渲染为FOR NO KEY UPDATE
,或者如果与read=True
结合使用,则会渲染为FOR KEY SHARE
。
class sqlalchemy.sql.expression.HasCTE
声明一个包含 CTE 支持的类的 Mixin。
成员
add_cte(), cte()
类签名
类sqlalchemy.sql.expression.HasCTE
(sqlalchemy.sql.roles.HasCTERole
,sqlalchemy.sql.expression.SelectsRows
)
method add_cte(*ctes: CTE, nest_here: bool = False) → Self
向该语句添加一个或多个CTE
构造。
此方法将使给定的CTE
构造与父语句相关联,以便它们将分别无条件地在最终语句的 WITH 子句中渲染,即使在语句或任何子选择中未在其他地方引用。
当可选参数HasCTE.add_cte.nest_here
设置为 True 时,每个给定的CTE
将直接在此语句中渲染为 WITH 子句,而不会像将该语句渲染为更大语句中的子查询时被移动到最终渲染语句的顶部。
此方法有两个一般用途。一个是嵌入一些没有明确引用的 CTE 语句,例如将 DML 语句(例如 INSERT 或 UPDATE)作为 CTE 内联到可能间接从其结果中提取的主语句中的用例。另一个是提供对应该保持直接渲染为特定语句的特定 CTE 构造的精确放置的控制,该语句可能嵌套在较大的语句中。
例如:
from sqlalchemy import table, column, select t = table('t', column('c1'), column('c2')) ins = t.insert().values({"c1": "x", "c2": "y"}).cte() stmt = select(t).add_cte(ins)
将渲染为:
WITH anon_1 AS (INSERT INTO t (c1, c2) VALUES (:param_1, :param_2)) SELECT t.c1, t.c2 FROM t
上述“anon_1”CTE 在 SELECT 语句中没有被引用,但仍然完成了运行 INSERT 语句的任务。
在与 DML 相关的上下文中,使用 PostgreSQL Insert
构造生成“upsert”:
from sqlalchemy import table, column from sqlalchemy.dialects.postgresql import insert t = table("t", column("c1"), column("c2")) delete_statement_cte = ( t.delete().where(t.c.c1 < 1).cte("deletions") ) insert_stmt = insert(t).values({"c1": 1, "c2": 2}) update_statement = insert_stmt.on_conflict_do_update( index_elements=[t.c.c1], set_={ "c1": insert_stmt.excluded.c1, "c2": insert_stmt.excluded.c2, }, ).add_cte(delete_statement_cte) print(update_statement)
上述语句渲染为:
WITH deletions AS (DELETE FROM t WHERE t.c1 < %(c1_1)s) INSERT INTO t (c1, c2) VALUES (%(c1)s, %(c2)s) ON CONFLICT (c1) DO UPDATE SET c1 = excluded.c1, c2 = excluded.c2
从版本 1.4.21 开始新增。
参数:
*ctes
–
零个或多个CTE
构造。
从版本 2.0 开始更改:接受多个 CTE 实例nest_here
–
如果为 True,则给定的 CTE 或 CTE 将被渲染为如果它们在添加到此HasCTE
时指定了HasCTE.cte.nesting
标志为 True。假设给定的 CTE 也没有在外部包含语句中被引用,则给定的 CTE 在给定此标志时应在此语句级别渲染。
从版本 2.0 开始新增。
另请参阅HasCTE.cte.nesting
method cte(name: str | None = None, recursive: bool = False, nesting: bool = False) → CTE
返回一个新的CTE
,或者通用表达式实例。
公共表达式是 SQL 标准的一部分,其中 SELECT 语句可以在主语句之后指定的辅助语句中进行绘制,使用名为“WITH”的子句。还可以使用关于 UNION 的特殊语义来允许“递归”查询,其中 SELECT 语句可以绘制出先前已选择的行集。
在一些数据库中,CTE 也可以应用于 DML 构造 UPDATE、INSERT 和 DELETE,既可以作为 CTE 行的来源(与 RETURNING 结合使用),也可以作为 CTE 行的消费者。
SQLAlchemy 检测到CTE
对象,这些对象与Alias
对象类似,被视为要传递到语句的 FROM 子句以及语句顶部的 WITH 子句中的特殊元素。
对于诸如 PostgreSQL“MATERIALIZED”和“NOT MATERIALIZED”之类的特殊前缀,可以使用CTE.prefix_with()
方法来建立这些前缀。
版本 1.3.13 中的更改:增加了对前缀的支持。特别是- MATERIALIZED 和 NOT MATERIALIZED。
参数:
name
– 给公共表达式的名称。与FromClause.alias()
类似,名称可以保持为None
,在这种情况下,将在查询编译时使用匿名符号。recursive
– 如果为True
,则呈现WITH RECURSIVE
。递归公共表达式旨在与 UNION ALL 一起使用,以从已经选择的行中派生行。nesting
–
如果为True
,则将 CTE 本地呈现到引用它的语句中。对于更复杂的情况,还可以使用HasCTE.add_cte()
方法,使用HasCTE.add_cte.nest_here
参数来更精细地控制特定 CTE 的确切放置位置。
1.4.24 版本中的新增内容。
另请参阅HasCTE.add_cte()
以下示例包括两个来自 PostgreSQL 文档的示例,网址为www.postgresql.org/docs/current/static/queries-with.html
,以及额外的示例。
示例 1,非递归:
from sqlalchemy import (Table, Column, String, Integer, MetaData, select, func) metadata = MetaData() orders = Table('orders', metadata, Column('region', String), Column('amount', Integer), Column('product', String), Column('quantity', Integer) ) regional_sales = select( orders.c.region, func.sum(orders.c.amount).label('total_sales') ).group_by(orders.c.region).cte("regional_sales") top_regions = select(regional_sales.c.region).\ where( regional_sales.c.total_sales > select( func.sum(regional_sales.c.total_sales) / 10 ) ).cte("top_regions") statement = select( orders.c.region, orders.c.product, func.sum(orders.c.quantity).label("product_units"), func.sum(orders.c.amount).label("product_sales") ).where(orders.c.region.in_( select(top_regions.c.region) )).group_by(orders.c.region, orders.c.product) result = conn.execute(statement).fetchall()
示例 2,WITH RECURSIVE:
from sqlalchemy import (Table, Column, String, Integer, MetaData, select, func) metadata = MetaData() parts = Table('parts', metadata, Column('part', String), Column('sub_part', String), Column('quantity', Integer), ) included_parts = select(\ parts.c.sub_part, parts.c.part, parts.c.quantity\ ).\ where(parts.c.part=='our part').\ cte(recursive=True) incl_alias = included_parts.alias() parts_alias = parts.alias() included_parts = included_parts.union_all( select( parts_alias.c.sub_part, parts_alias.c.part, parts_alias.c.quantity ).\ where(parts_alias.c.part==incl_alias.c.sub_part) ) statement = select( included_parts.c.sub_part, func.sum(included_parts.c.quantity). label('total_quantity') ).\ group_by(included_parts.c.sub_part) result = conn.execute(statement).fetchall()
示例 3,使用 CTE 的 UPDATE 和 INSERT 的 upsert:
from datetime import date from sqlalchemy import (MetaData, Table, Column, Integer, Date, select, literal, and_, exists) metadata = MetaData() visitors = Table('visitors', metadata, Column('product_id', Integer, primary_key=True), Column('date', Date, primary_key=True), Column('count', Integer), ) # add 5 visitors for the product_id == 1 product_id = 1 day = date.today() count = 5 update_cte = ( visitors.update() .where(and_(visitors.c.product_id == product_id, visitors.c.date == day)) .values(count=visitors.c.count + count) .returning(literal(1)) .cte('update_cte') ) upsert = visitors.insert().from_select( [visitors.c.product_id, visitors.c.date, visitors.c.count], select(literal(product_id), literal(day), literal(count)) .where(~exists(update_cte.select())) ) connection.execute(upsert)
示例 4,嵌套 CTE(SQLAlchemy 1.4.24 及以上版本):
value_a = select( literal("root").label("n") ).cte("value_a") # A nested CTE with the same name as the root one value_a_nested = select( literal("nesting").label("n") ).cte("value_a", nesting=True) # Nesting CTEs takes ascendency locally # over the CTEs at a higher level value_b = select(value_a_nested.c.n).cte("value_b") value_ab = select(value_a.c.n.label("a"), value_b.c.n.label("b"))
上述查询将第二个 CTE 嵌套在第一个内部,并显示为以下内联参数:
WITH value_a AS (SELECT 'root' AS n), value_b AS (WITH value_a AS (SELECT 'nesting' AS n) SELECT value_a.n AS n FROM value_a) SELECT value_a.n AS a, value_b.n AS b FROM value_a, value_b
可以使用HasCTE.add_cte()
方法设置相同的 CTE,如下所示(SQLAlchemy 2.0 及以上版本):
value_a = select( literal("root").label("n") ).cte("value_a") # A nested CTE with the same name as the root one value_a_nested = select( literal("nesting").label("n") ).cte("value_a") # Nesting CTEs takes ascendency locally # over the CTEs at a higher level value_b = ( select(value_a_nested.c.n). add_cte(value_a_nested, nest_here=True). cte("value_b") ) value_ab = select(value_a.c.n.label("a"), value_b.c.n.label("b"))
示例 5,非线性 CTE(SQLAlchemy 1.4.28 及以上版本):
edge = Table( "edge", metadata, Column("id", Integer, primary_key=True), Column("left", Integer), Column("right", Integer), ) root_node = select(literal(1).label("node")).cte( "nodes", recursive=True ) left_edge = select(edge.c.left).join( root_node, edge.c.right == root_node.c.node ) right_edge = select(edge.c.right).join( root_node, edge.c.left == root_node.c.node ) subgraph_cte = root_node.union(left_edge, right_edge) subgraph = select(subgraph_cte)
上述查询将在递归 CTE 内呈现 2 个 UNION:
WITH RECURSIVE nodes(node) AS ( SELECT 1 AS node UNION SELECT edge."left" AS "left" FROM edge JOIN nodes ON edge."right" = nodes.node UNION SELECT edge."right" AS "right" FROM edge JOIN nodes ON edge."left" = nodes.node ) SELECT nodes.node FROM nodes
另见
Query.cte()
- HasCTE.cte()
的 ORM 版本。
class sqlalchemy.sql.expression.HasPrefixes
成员
prefix_with()
method prefix_with(*prefixes: _TextCoercedExpressionArgument[Any], dialect: str = '*') → Self
在语句关键字后添加一个或多个表达式,即 SELECT、INSERT、UPDATE 或 DELETE。生成式。
用于支持像 MySQL 提供的特定于后端的前缀关键字。
例如:
stmt = table.insert().prefix_with("LOW_PRIORITY", dialect="mysql") # MySQL 5.7 optimizer hints stmt = select(table).prefix_with( "/*+ BKA(t1) */", dialect="mysql")
可以通过多次调用 HasPrefixes.prefix_with()
来指定多个前缀。
参数:
*prefixes
– 将在 INSERT、UPDATE 或 DELETE 关键字之后呈现的文本或ClauseElement
构造。dialect
– 可选的字符串方言名称,将此前缀的呈现限制为仅限于该方言。
class sqlalchemy.sql.expression.HasSuffixes
成员
suffix_with()
method suffix_with(*suffixes: _TextCoercedExpressionArgument[Any], dialect: str = '*') → Self
作为整体的语句后添加一个或多个表达式。
用于支持某些构造的特定于后端的后缀关键字。
例如:
stmt = select(col1, col2).cte().suffix_with( "cycle empno set y_cycle to 1 default 0", dialect="oracle")
可以通过多次调用 HasSuffixes.suffix_with()
来指定多个后缀。
参数:
*suffixes
– 将在目标子句之后呈现的文本或ClauseElement
构造。dialect
– 可选的字符串方言名称,将此后缀的呈现限制为仅限于该方言。
class sqlalchemy.sql.expression.Join
表示两个 FromClause
元素之间的 JOIN
构造。
Join
的公共构造函数是模块级别的 join()
函数,以及任何 FromClause
的 FromClause.join()
方法(例如 Table
)。
另见
join()
FromClause.join()
成员
init(), description, is_derived_from(), select(), self_group()
类签名
sqlalchemy.sql.expression.Join
类(sqlalchemy.sql.roles.DMLTableRole
, sqlalchemy.sql.expression.FromClause
)
method __init__(left: _FromClauseArgument, right: _FromClauseArgument, onclause: _OnClauseArgument | None = None, isouter: bool = False, full: bool = False)
构造一个新的 Join
。
常见的入口点是 join()
函数或任何 FromClause
对象的 FromClause.join()
方法。
attribute description
method is_derived_from(fromclause: FromClause | None) → bool
如果此 FromClause
是从给定的 FromClause
‘派生’,则返回 True
。
一个示例是表的别名是从该表派生的。
method select() → Select
从此 Join
创建一个 Select
。
例如:
stmt = table_a.join(table_b, table_a.c.id == table_b.c.a_id) stmt = stmt.select()
以上将产生类似于以下的 SQL 字符串:
SELECT table_a.id, table_a.col, table_b.id, table_b.a_id FROM table_a JOIN table_b ON table_a.id = table_b.a_id
method self_group(against: OperatorType | None = None) → FromGrouping
对此 ClauseElement
应用‘分组’。
子类会重写此方法以返回一个“分组”构造,即括号。特别是它被“二元”表达式使用,当它们被放置到更大的表达式中时,会提供一个围绕自己的分组,以及当被放置到另一个 select()
的 FROM 子句中时,由 select()
构造使用。(注意,子查询通常应使用 Select.alias()
方法创建,因为许多平台要求嵌套的 SELECT 语句必须具有名称)。
当表达式组合在一起时,会自动应用 self_group()
- 最终用户代码不应直接使用此方法。请注意,SQLAlchemy 的子句构造会考虑运算符优先级 - 因此在像 x OR (y AND z)
这样的表达式中可能不需要括号 - AND 优先于 OR。
self_group()
方法属于 ClauseElement
的基类,仅返回自身。
class sqlalchemy.sql.expression.Lateral
表示一个 LATERAL 子查询。
该对象可以通过 lateral()
模块级函数以及所有 FromClause
子类的 FromClause.lateral()
方法构建。
虽然 LATERAL 是 SQL 标准的一部分,但目前只有较新版本的 PostgreSQL 支持该关键字。
另请参阅
LATERAL 相关性 - 用法概述。
成员
inherit_cache
类签名
类 sqlalchemy.sql.expression.Lateral
(sqlalchemy.sql.expression.FromClauseAlias
, sqlalchemy.sql.expression.LateralFromClause
)
attribute inherit_cache: bool | None = True
指示此 HasCacheKey
实例是否应使用其直接超类使用的缓存键生成方案。
此属性默认为 None
,表示构造尚未考虑其是否适合参与缓存;这在功能上相当于将值设置为 False
,但也会发出警告。
如果与对象相对应的 SQL 不会因为该类局部属性而改变,而是改变其超类,则可以在特定类上将此标志设置为 True
。
另请参阅
为自定义构造启用缓存支持 - 为第三方或用户定义的 SQL 构造设置 HasCacheKey.inherit_cache
属性的一般指南。
class sqlalchemy.sql.expression.ReturnsRows
最基本的核心构造类,具有可表示行的列概念。
虽然 SELECT 语句和 TABLE 是我们在此类别中首先考虑的主要内容,但是像 INSERT、UPDATE 和 DELETE 这样的 DML 也可以指定 RETURNING,这意味着它们可以在 CTEs 和其他形式中使用,而且 PostgreSQL 也有返回行的函数。
自 1.4 版本新增。
成员
exported_columns, is_derived_from()
类签名
类 sqlalchemy.sql.expression.ReturnsRows
(sqlalchemy.sql.roles.ReturnsRowsRole
, sqlalchemy.sql.expression.DQLDMLClauseElement
)
attribute exported_columns
一个 ColumnCollection
,代表这个 ReturnsRows
的“导出”列。
“导出”列代表此 SQL 构造呈现的 ColumnElement
表达式集合。主要有几种类型,包括 FROM 子句的“FROM 子句列”,例如表、连接或子查询,以及“SELECTed 列”,即 SELECT 语句的“列子句”中的列,以及 DML 语句中的 RETURNING 列。
自版本 1.4 新增。
另请参阅
FromClause.exported_columns
SelectBase.exported_columns
method is_derived_from(fromclause: FromClause | None) → bool
如果此 ReturnsRows
是从给定的 FromClause
“派生”出来的,则返回 True
。
例如,表的别名是从该表派生出来的。
class sqlalchemy.sql.expression.ScalarSelect
表示一个标量子查询。
通过调用 SelectBase.scalar_subquery()
方法创建 ScalarSelect
。然后,该对象作为 ColumnElement
层次结构中的 SQL 列表达式参与其他 SQL 表达式。
另请参阅
SelectBase.scalar_subquery()
标量和相关子查询 - 在 2.0 教程中
成员
correlate(), correlate_except(), inherit_cache, self_group(), where()
类签名
类 sqlalchemy.sql.expression.ScalarSelect
(sqlalchemy.sql.roles.InElementRole
, sqlalchemy.sql.expression.Generative
, sqlalchemy.sql.expression.GroupedElement
, sqlalchemy.sql.expression.ColumnElement
)
method correlate(*fromclauses: Literal[None, False] | _FromClauseArgument) → Self
返回一个新的ScalarSelect
,它将相关联给定的 FROM 子句到封闭Select
的 FROM 子句。
该方法是从底层Select
的Select.correlate()
方法中镜像出来的。该方法应用了:meth:_sql.Select.correlate方法,然后返回一个新的
ScalarSelect`针对该语句。
版本 1.4 中的新内容:以前,ScalarSelect.correlate()
方法仅从Select
中可用。
参数:
*fromclauses - 一个或多个FromClause
构造的列表,或其他兼容的构造(即 ORM 映射的类),以成为相关集合的一部分。
还请参阅
ScalarSelect.correlate_except()
标量和相关子查询 - 在 2.0 教程
method correlate_except(*fromclauses: Literal[None, False] | _FromClauseArgument) → Self
返回一个新的ScalarSelect
,它将从自动相关过程中省略给定的 FROM 子句。
该方法是从底层Select
的Select.correlate_except()
方法中镜像出来的。该方法应用了:meth:_sql.Select.correlate_except方法,然后返回一个新的
ScalarSelect`针对该语句。
版本 1.4 中的新内容:以前,ScalarSelect.correlate_except()
方法仅从Select
中可用。
参数:
*fromclauses - 一个或多个FromClause
构造的列表,或其他兼容的构造(即 ORM 映射的类),以成为相关例外集合的一部分。
另请参见
ScalarSelect.correlate()
标量和相关子查询 - 在 2.0 教程中
attribute inherit_cache: bool | None = True
指示此 HasCacheKey
实例是否应使用其直接超类使用的缓存键生成方案。
该属性默认为 None
,表示构造尚未考虑是否适合参与缓存;这在功能上等同于将值设置为 False
,只是还会发出警告。
如果与对象对应的 SQL 不基于仅属于此类而不是其超类的属性更改,则可以在特定类上将此标志设置为 True
。
另请参阅
为自定义构造启用缓存支持 - 设置第三方或用户定义的 SQL 构造的 HasCacheKey.inherit_cache
属性的一般指南。
method self_group(against: OperatorType | None = None) → ColumnElement[Any]
对这个 ClauseElement
应用一个“分组”。
此方法被子类重写以返回一个“分组”构造,即括号。特别是当“二元”表达式被放置到更大的表达式中时,它们会提供一个围绕自身的分组,以及当 select()
构造被放置到另一个 select()
的 FROM 子句中时。 (请注意,子查询通常应使用 Select.alias()
方法创建,因为许多平台要求嵌套的 SELECT 语句必须被命名)。
当表达式组合在一起时,self_group()
的应用是自动的 - 最终用户代码不应直接使用此方法。请注意,SQLAlchemy 的子句构造会考虑运算符优先级 - 因此在诸如 x OR (y AND z)
这样的表达式中可能不需要括号 - AND 优先于 OR。
ClauseElement
的基本 self_group()
方法只返回自身。
method where(crit: _ColumnExpressionArgument[bool]) → Self
对此 ScalarSelect
引用的 SELECT 语句应用 WHERE 子句。
class sqlalchemy.sql.expression.Select
表示一个 SELECT
语句。
Select
对象通常使用 select()
函数构造。详情请参阅该函数。
另请参阅
select()
使用 SELECT 语句 - 在 2.0 教程中
成员
init(), add_columns(), add_cte(), alias(), as_scalar(), c, column(), column_descriptions, columns_clause_froms, correlate(), correlate_except(), corresponding_column(), cte(), distinct(), except_(), except_all(), execution_options(), exists(), exported_columns, fetch(), filter(), filter_by(), from_statement(), froms, get_children(), get_execution_options(), get_final_froms(), get_label_style(), group_by(), having(), inherit_cache, inner_columns, intersect(), intersect_all(), is_derived_from(), join(), join_from(), label(), lateral(), limit(), offset(), options(), order_by(), outerjoin(), outerjoin_from(), prefix_with(), reduce_columns(), replace_selectable(), scalar_subquery(), select(), select_from(), selected_columns, self_group(), set_label_style(), slice(), subquery(), suffix_with(), union(), union_all(), where(), whereclause, with_for_update(), with_hint(), with_only_columns(), with_statement_hint()
类签名
类sqlalchemy.sql.expression.Select
(sqlalchemy.sql.expression.HasPrefixes
,sqlalchemy.sql.expression.HasSuffixes
,sqlalchemy.sql.expression.HasHints
,sqlalchemy.sql.expression.HasCompileState
,sqlalchemy.sql.expression._SelectFromElements
,sqlalchemy.sql.expression.GenerativeSelect
,sqlalchemy.sql.expression.TypedReturnsRows
)
method __init__(*entities: _ColumnsClauseArgument[Any])
构造一个新的Select
。
Select
的公共构造函数是select()
函数。
method add_columns(*entities: _ColumnsClauseArgument[Any]) → Select[Any]
返回一个新的select()
构造,其中包含给定实体附加到其列子句中。
例如:
my_select = my_select.add_columns(table.c.new_column)
列子句中的原始表达式保持不变。要用新表达式替换原始表达式,请参见方法Select.with_only_columns()
。
参数:
*entities – 要添加到列子句中的列、表或其他实体表达式
另请参见
Select.with_only_columns()
- 替换现有表达式而不是追加。
同时选择多个 ORM 实体 - 以 ORM 为中心的示例
method add_cte(*ctes: CTE, nest_here: bool = False) → Self
继承自 HasCTE.add_cte()
方法的 HasCTE
向此语句添加一个或多个CTE
构造。
此方法将将给定的CTE
构造与父语句关联,以便它们将分别无条件地呈现在最终语句的 WITH 子句中,即使在语句或任何子选择中未引用它们。
当可选的HasCTE.add_cte.nest_here
参数设置为 True 时,每个给定的CTE
将直接与此语句一起渲染为 WITH 子句,而不是被移动到最终渲染的语句顶部,即使此语句作为较大语句中的子查询进行渲染也是如此。
此方法有两个一般用途。一个是嵌入服务于某种目的而不被显式引用的 CTE 语句,比如将 DML 语句(如 INSERT 或 UPDATE)嵌入为一个 CTE 与可能间接引用其结果的主要语句内联的用例。另一个是提供对应于应保持直接渲染为可能嵌套在较大语句中的特定语句的 CTE 结构系列的确切放置位置的控制。
例如:
from sqlalchemy import table, column, select t = table('t', column('c1'), column('c2')) ins = t.insert().values({"c1": "x", "c2": "y"}).cte() stmt = select(t).add_cte(ins)
渲染后:
WITH anon_1 AS (INSERT INTO t (c1, c2) VALUES (:param_1, :param_2)) SELECT t.c1, t.c2 FROM t
在上面的示例中,“anon_1” CTE 虽然在 SELECT 语句中没有被引用,但仍完成了运行 INSERT 语句的任务。
类似地,在与 DML 相关的上下文中,使用 PostgreSQL Insert
构造来生成“upsert”:
from sqlalchemy import table, column from sqlalchemy.dialects.postgresql import insert t = table("t", column("c1"), column("c2")) delete_statement_cte = ( t.delete().where(t.c.c1 < 1).cte("deletions") ) insert_stmt = insert(t).values({"c1": 1, "c2": 2}) update_statement = insert_stmt.on_conflict_do_update( index_elements=[t.c.c1], set_={ "c1": insert_stmt.excluded.c1, "c2": insert_stmt.excluded.c2, }, ).add_cte(delete_statement_cte) print(update_statement)
上述语句渲染为:
WITH deletions AS (DELETE FROM t WHERE t.c1 < %(c1_1)s) INSERT INTO t (c1, c2) VALUES (%(c1)s, %(c2)s) ON CONFLICT (c1) DO UPDATE SET c1 = excluded.c1, c2 = excluded.c2
新版本 1.4.21 中新增。
参数:
*ctes
–
零个或多个CTE
构造。
从版本 2.0 开始更改:接受多个 CTE 实例nest_here
–
如果为 True,则给定的 CTE 或 CTEs 将被渲染,就好像在将它们添加到此HasCTE
时指定了HasCTE.cte.nesting
标志为 True。假设给定的 CTEs 在外部包含语句中也没有被引用,则在给出此标志时,当这些 CTEs 被渲染时,应在此语句级别上渲染。
新版本 2.0 中新增。
另请参阅HasCTE.cte.nesting
method alias(name: str | None = None, flat: bool = False) → Subquery
从 SelectBase
的 SelectBase.alias()
方法继承
返回针对此SelectBase
的命名子查询。
对于一个 SelectBase
(而不是一个 FromClause
),这将返回一个行为大部分与与 FromClause
一起使用的 Alias
对象相同的 Subquery
对象。
从版本 1.4 开始更改:SelectBase.alias()
方法现在是 SelectBase.subquery()
方法的同义词。
method as_scalar() → ScalarSelect[Any]
继承自 SelectBase.as_scalar()
方法的 SelectBase
从版本 1.4 开始弃用:SelectBase.as_scalar()
方法已被弃用,并将在将来的版本中删除。请参考 SelectBase.scalar_subquery()
。
attribute c
继承自 SelectBase.c
属性的 SelectBase
从版本 1.4 开始弃用:SelectBase.c
和 SelectBase.columns
属性已被弃用,并将在将来的版本中删除;这些属性隐式地创建一个应该是明确的子查询。请首先调用 SelectBase.subquery()
来创建一个子查询,然后该子查询包含此属性。要访问此 SELECT 对象从中选择的列,请使用 SelectBase.selected_columns
属性。
method column(column: _ColumnsClauseArgument[Any]) → Select[Any]
返回一个新的带有给定列表达式添加到其列子句的 select()
构造。
从版本 1.4 开始弃用:Select.column()
方法已被弃用,并将在将来的版本中删除。请使用 Select.add_columns()
例如:
my_select = my_select.column(table.c.new_column)
请参阅 Select.with_only_columns()
的文档,了解如何添加 / 替换 Select
对象的列的指南。
attribute column_descriptions
返回一个 启用插件 的‘列描述’结构,引用此语句所选的列。
这个属性通常在使用 ORM 时很有用,因为会返回一个包含有关映射实体信息的扩展结构。部分 检查来自启用了 ORM 的 SELECT 和 DML 语句的实体和列 包含更多背景信息。
对于仅核心语句,此访问器返回的结构派生自由 Select.selected_columns
访问器返回的相同对象,格式化为包含键 name
、type
和 expr
的字典列表,这些键指示要选择的列表达式:
>>> stmt = select(user_table) >>> stmt.column_descriptions [ { 'name': 'id', 'type': Integer(), 'expr': Column('id', Integer(), ...)}, { 'name': 'name', 'type': String(length=30), 'expr': Column('name', String(length=30), ...)} ]
1.4.33 版中的更改:Select.column_descriptions
属性返回一个仅针对核心实体的结构,而不仅仅是 ORM 实体。
另请参阅
UpdateBase.entity_description
- insert()
、update()
或 delete()
的实体信息
从启用了 ORM 的 SELECT 和 DML 语句中检查实体和列 - ORM 背景
attribute columns_clause_froms
返回由此 SELECT 语句的列子句暗示的 FromClause
对象集。
版本 1.4.23 中的新内容。
另请参阅
Select.froms
- 考虑了完整语句的“最终” FROM 列表
Select.with_only_columns()
- 使用此集合设置新的 FROM 列表
method correlate(*fromclauses: Literal[None, False] | _FromClauseArgument) → Self
返回一个新的 Select
,将给定的 FROM 子句与封闭 Select
的 FROM 子句相关联。
调用此方法将关闭 Select
对象的默认行为“自动关联”。通常情况下,通过其 WHERE 子句、ORDER BY、HAVING 或 columns 子句 封闭此对象的 Select
中出现的 FROM 元素将从此 Select
对象的 FROM 子句 中省略。使用 Select.correlate()
方法设置显式关联集合提供了一个固定的 FROM 对象列表,这些对象可能参与此过程。
当使用 Select.correlate()
应用特定的 FROM 子句进行关联时,无论此 Select
对象相对于封闭的引用相对于相同的 FROM 对象的外层 Select
嵌套多深,FROM 元素都会成为关联的候选对象。这与“自动关联”的行为形成对比,后者仅与一个直接封闭的 Select
相关联。多级关联确保封闭和封闭的 Select
之间的链接始终通过至少一个 WHERE/ORDER BY/HAVING/columns 子句,以便进行关联。
如果传入 None
,Select
对象将不会关联其任何 FROM 条目,所有条目都将无条件地在本地 FROM 子句中渲染。
参数:
*fromclauses – 一个或多个 FromClause
或其他与 FROM 兼容的构造,如 ORM 映射实体,以成为关联集合的一部分;或者传递单个值 None
来删除所有现有的关联。
另请参阅
Select.correlate_except()
标量和关联子查询
method correlate_except(*fromclauses: Literal[None, False] | _FromClauseArgument) → Self
返回一个新的 Select
,它将从自动关联过程中省略给定的 FROM 子句。
调用 Select.correlate_except()
会关闭给定 FROM 元素的Select
对象的默认“自动关联”行为。在此指定的元素将无条件出现在 FROM 列表中,而所有其他 FROM 元素仍然受到正常的自动关联行为的影响。
如果传递了None
,或者没有传递参数,则Select
对象将关联其所有 FROM 条目。
参数:
*fromclauses – 一个或多个FromClause
构造的列表,或其他兼容的构造(即 ORM 映射的类),成为关联例外集合的一部分。
另请参见
Select.correlate()
标量和相关子查询
method corresponding_column(column: KeyedColumnElement[Any], require_embedded: bool = False) → KeyedColumnElement[Any] | None
继承自 Selectable.corresponding_column()
方法的 Selectable
给定一个ColumnElement
,返回此Selectable
的Selectable.exported_columns
集合中对应于该原始ColumnElement
的导出ColumnElement
对象,通过共同祖先列进行对应。
参数:
column
– 要匹配的目标ColumnElement
。require_embedded
– 仅当给定的ColumnElement
实际存在于此Selectable
的子元素中时,才返回相应列,通常情况下,如果该列仅与此Selectable
的导出列之一共享共同祖先,则列会匹配。
另请参见
Selectable.exported_columns
- 用于操作的ColumnCollection
。
ColumnCollection.corresponding_column()
- 实现方法。
method cte(name: str | None = None, recursive: bool = False, nesting: bool = False) → CTE
从 HasCTE.cte()
方法继承而来 HasCTE
返回一个新的CTE
或公共表达式实例。
公共表达式是一种 SQL 标准,其中 SELECT 语句可以在主语句的基础上绘制出与主语句一起指定的辅助语句,使用一个叫做“WITH”的子句。还可以使用特殊的语义关于 UNION 来允许“递归”查询,其中一个 SELECT 语句可以绘制出先前已选择的行集。
CTE 也可以应用于某些数据库上的 DML 构造 UPDATE、INSERT 和 DELETE,既作为与 RETURNING 结合使用时 CTE 行的来源,也作为 CTE 行的消费者。
SQLAlchemy 检测到CTE
对象,这些对象与Alias
对象类似,作为要传递到语句的 FROM 子句以及语句顶部的 WITH 子句的特殊元素。
对于诸如 PostgreSQL 的“MATERIALIZED”和“NOT MATERIALIZED”等特殊前缀,可以使用CTE.prefix_with()
方法来建立这些。
在版本 1.3.13 中更改:添加了对前缀的支持。特别是- MATERIALIZED 和 NOT MATERIALIZED。
参数:
name
– 给公共表达式的名称。与FromClause.alias()
类似,如果将名称留空,则在查询编译时将使用匿名符号。recursive
– 如果设置为True
,将渲染WITH RECURSIVE
。递归公共表达式旨在与 UNION ALL 结合使用,以便从已选择的行中派生行。nesting
–
如果设置为True
,将在引用它的语句中本地渲染 CTE。对于更复杂的场景,也可以使用HasCTE.add_cte()
方法,使用HasCTE.add_cte.nest_here
参数更精细地控制特定 CTE 的确切放置位置。
新功能在版本 1.4.24 中添加。
另请参阅HasCTE.add_cte()
以下示例包括两个来自 PostgreSQL 文档的示例www.postgresql.org/docs/current/static/queries-with.html
,以及其他示例。
示例 1,非递归:
from sqlalchemy import (Table, Column, String, Integer, MetaData, select, func) metadata = MetaData() orders = Table('orders', metadata, Column('region', String), Column('amount', Integer), Column('product', String), Column('quantity', Integer) ) regional_sales = select( orders.c.region, func.sum(orders.c.amount).label('total_sales') ).group_by(orders.c.region).cte("regional_sales") top_regions = select(regional_sales.c.region).\ where( regional_sales.c.total_sales > select( func.sum(regional_sales.c.total_sales) / 10 ) ).cte("top_regions") statement = select( orders.c.region, orders.c.product, func.sum(orders.c.quantity).label("product_units"), func.sum(orders.c.amount).label("product_sales") ).where(orders.c.region.in_( select(top_regions.c.region) )).group_by(orders.c.region, orders.c.product) result = conn.execute(statement).fetchall()
示例 2,WITH RECURSIVE:
from sqlalchemy import (Table, Column, String, Integer, MetaData, select, func) metadata = MetaData() parts = Table('parts', metadata, Column('part', String), Column('sub_part', String), Column('quantity', Integer), ) included_parts = select(\ parts.c.sub_part, parts.c.part, parts.c.quantity\ ).\ where(parts.c.part=='our part').\ cte(recursive=True) incl_alias = included_parts.alias() parts_alias = parts.alias() included_parts = included_parts.union_all( select( parts_alias.c.sub_part, parts_alias.c.part, parts_alias.c.quantity ).\ where(parts_alias.c.part==incl_alias.c.sub_part) ) statement = select( included_parts.c.sub_part, func.sum(included_parts.c.quantity). label('total_quantity') ).\ group_by(included_parts.c.sub_part) result = conn.execute(statement).fetchall()
示例 3,使用 UPDATE 和 INSERT 进行 upsert 与 CTE:
from datetime import date from sqlalchemy import (MetaData, Table, Column, Integer, Date, select, literal, and_, exists) metadata = MetaData() visitors = Table('visitors', metadata, Column('product_id', Integer, primary_key=True), Column('date', Date, primary_key=True), Column('count', Integer), ) # add 5 visitors for the product_id == 1 product_id = 1 day = date.today() count = 5 update_cte = ( visitors.update() .where(and_(visitors.c.product_id == product_id, visitors.c.date == day)) .values(count=visitors.c.count + count) .returning(literal(1)) .cte('update_cte') ) upsert = visitors.insert().from_select( [visitors.c.product_id, visitors.c.date, visitors.c.count], select(literal(product_id), literal(day), literal(count)) .where(~exists(update_cte.select())) ) connection.execute(upsert)
SqlAlchemy 2.0 中文文档(三十五)(3)https://developer.aliyun.com/article/1562892