SQLAlchemy 2.0.47__cp313-cp313t-win_amd64.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (274) hide show
  1. sqlalchemy/__init__.py +283 -0
  2. sqlalchemy/connectors/__init__.py +18 -0
  3. sqlalchemy/connectors/aioodbc.py +184 -0
  4. sqlalchemy/connectors/asyncio.py +429 -0
  5. sqlalchemy/connectors/pyodbc.py +250 -0
  6. sqlalchemy/cyextension/__init__.py +6 -0
  7. sqlalchemy/cyextension/collections.cp313t-win_amd64.pyd +0 -0
  8. sqlalchemy/cyextension/collections.pyx +409 -0
  9. sqlalchemy/cyextension/immutabledict.cp313t-win_amd64.pyd +0 -0
  10. sqlalchemy/cyextension/immutabledict.pxd +8 -0
  11. sqlalchemy/cyextension/immutabledict.pyx +133 -0
  12. sqlalchemy/cyextension/processors.cp313t-win_amd64.pyd +0 -0
  13. sqlalchemy/cyextension/processors.pyx +68 -0
  14. sqlalchemy/cyextension/resultproxy.cp313t-win_amd64.pyd +0 -0
  15. sqlalchemy/cyextension/resultproxy.pyx +102 -0
  16. sqlalchemy/cyextension/util.cp313t-win_amd64.pyd +0 -0
  17. sqlalchemy/cyextension/util.pyx +90 -0
  18. sqlalchemy/dialects/__init__.py +62 -0
  19. sqlalchemy/dialects/_typing.py +30 -0
  20. sqlalchemy/dialects/mssql/__init__.py +88 -0
  21. sqlalchemy/dialects/mssql/aioodbc.py +63 -0
  22. sqlalchemy/dialects/mssql/base.py +4093 -0
  23. sqlalchemy/dialects/mssql/information_schema.py +285 -0
  24. sqlalchemy/dialects/mssql/json.py +129 -0
  25. sqlalchemy/dialects/mssql/provision.py +185 -0
  26. sqlalchemy/dialects/mssql/pymssql.py +126 -0
  27. sqlalchemy/dialects/mssql/pyodbc.py +760 -0
  28. sqlalchemy/dialects/mysql/__init__.py +104 -0
  29. sqlalchemy/dialects/mysql/aiomysql.py +250 -0
  30. sqlalchemy/dialects/mysql/asyncmy.py +231 -0
  31. sqlalchemy/dialects/mysql/base.py +3949 -0
  32. sqlalchemy/dialects/mysql/cymysql.py +106 -0
  33. sqlalchemy/dialects/mysql/dml.py +225 -0
  34. sqlalchemy/dialects/mysql/enumerated.py +282 -0
  35. sqlalchemy/dialects/mysql/expression.py +146 -0
  36. sqlalchemy/dialects/mysql/json.py +91 -0
  37. sqlalchemy/dialects/mysql/mariadb.py +72 -0
  38. sqlalchemy/dialects/mysql/mariadbconnector.py +322 -0
  39. sqlalchemy/dialects/mysql/mysqlconnector.py +302 -0
  40. sqlalchemy/dialects/mysql/mysqldb.py +314 -0
  41. sqlalchemy/dialects/mysql/provision.py +153 -0
  42. sqlalchemy/dialects/mysql/pymysql.py +158 -0
  43. sqlalchemy/dialects/mysql/pyodbc.py +157 -0
  44. sqlalchemy/dialects/mysql/reflection.py +727 -0
  45. sqlalchemy/dialects/mysql/reserved_words.py +570 -0
  46. sqlalchemy/dialects/mysql/types.py +835 -0
  47. sqlalchemy/dialects/oracle/__init__.py +81 -0
  48. sqlalchemy/dialects/oracle/base.py +3802 -0
  49. sqlalchemy/dialects/oracle/cx_oracle.py +1555 -0
  50. sqlalchemy/dialects/oracle/dictionary.py +507 -0
  51. sqlalchemy/dialects/oracle/oracledb.py +941 -0
  52. sqlalchemy/dialects/oracle/provision.py +297 -0
  53. sqlalchemy/dialects/oracle/types.py +316 -0
  54. sqlalchemy/dialects/oracle/vector.py +365 -0
  55. sqlalchemy/dialects/postgresql/__init__.py +167 -0
  56. sqlalchemy/dialects/postgresql/_psycopg_common.py +189 -0
  57. sqlalchemy/dialects/postgresql/array.py +519 -0
  58. sqlalchemy/dialects/postgresql/asyncpg.py +1284 -0
  59. sqlalchemy/dialects/postgresql/base.py +5378 -0
  60. sqlalchemy/dialects/postgresql/dml.py +339 -0
  61. sqlalchemy/dialects/postgresql/ext.py +540 -0
  62. sqlalchemy/dialects/postgresql/hstore.py +406 -0
  63. sqlalchemy/dialects/postgresql/json.py +404 -0
  64. sqlalchemy/dialects/postgresql/named_types.py +524 -0
  65. sqlalchemy/dialects/postgresql/operators.py +129 -0
  66. sqlalchemy/dialects/postgresql/pg8000.py +669 -0
  67. sqlalchemy/dialects/postgresql/pg_catalog.py +326 -0
  68. sqlalchemy/dialects/postgresql/provision.py +183 -0
  69. sqlalchemy/dialects/postgresql/psycopg.py +862 -0
  70. sqlalchemy/dialects/postgresql/psycopg2.py +892 -0
  71. sqlalchemy/dialects/postgresql/psycopg2cffi.py +61 -0
  72. sqlalchemy/dialects/postgresql/ranges.py +1031 -0
  73. sqlalchemy/dialects/postgresql/types.py +313 -0
  74. sqlalchemy/dialects/sqlite/__init__.py +57 -0
  75. sqlalchemy/dialects/sqlite/aiosqlite.py +482 -0
  76. sqlalchemy/dialects/sqlite/base.py +3056 -0
  77. sqlalchemy/dialects/sqlite/dml.py +263 -0
  78. sqlalchemy/dialects/sqlite/json.py +92 -0
  79. sqlalchemy/dialects/sqlite/provision.py +229 -0
  80. sqlalchemy/dialects/sqlite/pysqlcipher.py +157 -0
  81. sqlalchemy/dialects/sqlite/pysqlite.py +756 -0
  82. sqlalchemy/dialects/type_migration_guidelines.txt +145 -0
  83. sqlalchemy/engine/__init__.py +62 -0
  84. sqlalchemy/engine/_py_processors.py +136 -0
  85. sqlalchemy/engine/_py_row.py +128 -0
  86. sqlalchemy/engine/_py_util.py +74 -0
  87. sqlalchemy/engine/base.py +3390 -0
  88. sqlalchemy/engine/characteristics.py +155 -0
  89. sqlalchemy/engine/create.py +893 -0
  90. sqlalchemy/engine/cursor.py +2298 -0
  91. sqlalchemy/engine/default.py +2394 -0
  92. sqlalchemy/engine/events.py +965 -0
  93. sqlalchemy/engine/interfaces.py +3471 -0
  94. sqlalchemy/engine/mock.py +134 -0
  95. sqlalchemy/engine/processors.py +61 -0
  96. sqlalchemy/engine/reflection.py +2102 -0
  97. sqlalchemy/engine/result.py +2399 -0
  98. sqlalchemy/engine/row.py +400 -0
  99. sqlalchemy/engine/strategies.py +16 -0
  100. sqlalchemy/engine/url.py +924 -0
  101. sqlalchemy/engine/util.py +167 -0
  102. sqlalchemy/event/__init__.py +26 -0
  103. sqlalchemy/event/api.py +220 -0
  104. sqlalchemy/event/attr.py +676 -0
  105. sqlalchemy/event/base.py +472 -0
  106. sqlalchemy/event/legacy.py +258 -0
  107. sqlalchemy/event/registry.py +390 -0
  108. sqlalchemy/events.py +17 -0
  109. sqlalchemy/exc.py +832 -0
  110. sqlalchemy/ext/__init__.py +11 -0
  111. sqlalchemy/ext/associationproxy.py +2027 -0
  112. sqlalchemy/ext/asyncio/__init__.py +25 -0
  113. sqlalchemy/ext/asyncio/base.py +281 -0
  114. sqlalchemy/ext/asyncio/engine.py +1471 -0
  115. sqlalchemy/ext/asyncio/exc.py +21 -0
  116. sqlalchemy/ext/asyncio/result.py +965 -0
  117. sqlalchemy/ext/asyncio/scoping.py +1599 -0
  118. sqlalchemy/ext/asyncio/session.py +1947 -0
  119. sqlalchemy/ext/automap.py +1701 -0
  120. sqlalchemy/ext/baked.py +570 -0
  121. sqlalchemy/ext/compiler.py +600 -0
  122. sqlalchemy/ext/declarative/__init__.py +65 -0
  123. sqlalchemy/ext/declarative/extensions.py +564 -0
  124. sqlalchemy/ext/horizontal_shard.py +478 -0
  125. sqlalchemy/ext/hybrid.py +1535 -0
  126. sqlalchemy/ext/indexable.py +364 -0
  127. sqlalchemy/ext/instrumentation.py +450 -0
  128. sqlalchemy/ext/mutable.py +1085 -0
  129. sqlalchemy/ext/mypy/__init__.py +6 -0
  130. sqlalchemy/ext/mypy/apply.py +324 -0
  131. sqlalchemy/ext/mypy/decl_class.py +515 -0
  132. sqlalchemy/ext/mypy/infer.py +590 -0
  133. sqlalchemy/ext/mypy/names.py +335 -0
  134. sqlalchemy/ext/mypy/plugin.py +303 -0
  135. sqlalchemy/ext/mypy/util.py +357 -0
  136. sqlalchemy/ext/orderinglist.py +439 -0
  137. sqlalchemy/ext/serializer.py +185 -0
  138. sqlalchemy/future/__init__.py +16 -0
  139. sqlalchemy/future/engine.py +15 -0
  140. sqlalchemy/inspection.py +174 -0
  141. sqlalchemy/log.py +288 -0
  142. sqlalchemy/orm/__init__.py +171 -0
  143. sqlalchemy/orm/_orm_constructors.py +2661 -0
  144. sqlalchemy/orm/_typing.py +179 -0
  145. sqlalchemy/orm/attributes.py +2845 -0
  146. sqlalchemy/orm/base.py +971 -0
  147. sqlalchemy/orm/bulk_persistence.py +2135 -0
  148. sqlalchemy/orm/clsregistry.py +571 -0
  149. sqlalchemy/orm/collections.py +1627 -0
  150. sqlalchemy/orm/context.py +3334 -0
  151. sqlalchemy/orm/decl_api.py +2004 -0
  152. sqlalchemy/orm/decl_base.py +2192 -0
  153. sqlalchemy/orm/dependency.py +1302 -0
  154. sqlalchemy/orm/descriptor_props.py +1092 -0
  155. sqlalchemy/orm/dynamic.py +300 -0
  156. sqlalchemy/orm/evaluator.py +379 -0
  157. sqlalchemy/orm/events.py +3252 -0
  158. sqlalchemy/orm/exc.py +237 -0
  159. sqlalchemy/orm/identity.py +302 -0
  160. sqlalchemy/orm/instrumentation.py +754 -0
  161. sqlalchemy/orm/interfaces.py +1496 -0
  162. sqlalchemy/orm/loading.py +1686 -0
  163. sqlalchemy/orm/mapped_collection.py +557 -0
  164. sqlalchemy/orm/mapper.py +4444 -0
  165. sqlalchemy/orm/path_registry.py +809 -0
  166. sqlalchemy/orm/persistence.py +1788 -0
  167. sqlalchemy/orm/properties.py +935 -0
  168. sqlalchemy/orm/query.py +3459 -0
  169. sqlalchemy/orm/relationships.py +3508 -0
  170. sqlalchemy/orm/scoping.py +2148 -0
  171. sqlalchemy/orm/session.py +5280 -0
  172. sqlalchemy/orm/state.py +1168 -0
  173. sqlalchemy/orm/state_changes.py +196 -0
  174. sqlalchemy/orm/strategies.py +3470 -0
  175. sqlalchemy/orm/strategy_options.py +2568 -0
  176. sqlalchemy/orm/sync.py +164 -0
  177. sqlalchemy/orm/unitofwork.py +796 -0
  178. sqlalchemy/orm/util.py +2403 -0
  179. sqlalchemy/orm/writeonly.py +674 -0
  180. sqlalchemy/pool/__init__.py +44 -0
  181. sqlalchemy/pool/base.py +1524 -0
  182. sqlalchemy/pool/events.py +375 -0
  183. sqlalchemy/pool/impl.py +588 -0
  184. sqlalchemy/py.typed +0 -0
  185. sqlalchemy/schema.py +69 -0
  186. sqlalchemy/sql/__init__.py +145 -0
  187. sqlalchemy/sql/_dml_constructors.py +132 -0
  188. sqlalchemy/sql/_elements_constructors.py +1872 -0
  189. sqlalchemy/sql/_orm_types.py +20 -0
  190. sqlalchemy/sql/_py_util.py +75 -0
  191. sqlalchemy/sql/_selectable_constructors.py +763 -0
  192. sqlalchemy/sql/_typing.py +482 -0
  193. sqlalchemy/sql/annotation.py +587 -0
  194. sqlalchemy/sql/base.py +2293 -0
  195. sqlalchemy/sql/cache_key.py +1057 -0
  196. sqlalchemy/sql/coercions.py +1404 -0
  197. sqlalchemy/sql/compiler.py +8081 -0
  198. sqlalchemy/sql/crud.py +1752 -0
  199. sqlalchemy/sql/ddl.py +1444 -0
  200. sqlalchemy/sql/default_comparator.py +551 -0
  201. sqlalchemy/sql/dml.py +1850 -0
  202. sqlalchemy/sql/elements.py +5589 -0
  203. sqlalchemy/sql/events.py +458 -0
  204. sqlalchemy/sql/expression.py +159 -0
  205. sqlalchemy/sql/functions.py +2158 -0
  206. sqlalchemy/sql/lambdas.py +1442 -0
  207. sqlalchemy/sql/naming.py +209 -0
  208. sqlalchemy/sql/operators.py +2623 -0
  209. sqlalchemy/sql/roles.py +323 -0
  210. sqlalchemy/sql/schema.py +6222 -0
  211. sqlalchemy/sql/selectable.py +7265 -0
  212. sqlalchemy/sql/sqltypes.py +3930 -0
  213. sqlalchemy/sql/traversals.py +1024 -0
  214. sqlalchemy/sql/type_api.py +2368 -0
  215. sqlalchemy/sql/util.py +1485 -0
  216. sqlalchemy/sql/visitors.py +1164 -0
  217. sqlalchemy/testing/__init__.py +96 -0
  218. sqlalchemy/testing/assertions.py +994 -0
  219. sqlalchemy/testing/assertsql.py +520 -0
  220. sqlalchemy/testing/asyncio.py +135 -0
  221. sqlalchemy/testing/config.py +434 -0
  222. sqlalchemy/testing/engines.py +483 -0
  223. sqlalchemy/testing/entities.py +117 -0
  224. sqlalchemy/testing/exclusions.py +476 -0
  225. sqlalchemy/testing/fixtures/__init__.py +28 -0
  226. sqlalchemy/testing/fixtures/base.py +384 -0
  227. sqlalchemy/testing/fixtures/mypy.py +332 -0
  228. sqlalchemy/testing/fixtures/orm.py +227 -0
  229. sqlalchemy/testing/fixtures/sql.py +482 -0
  230. sqlalchemy/testing/pickleable.py +155 -0
  231. sqlalchemy/testing/plugin/__init__.py +6 -0
  232. sqlalchemy/testing/plugin/bootstrap.py +51 -0
  233. sqlalchemy/testing/plugin/plugin_base.py +828 -0
  234. sqlalchemy/testing/plugin/pytestplugin.py +892 -0
  235. sqlalchemy/testing/profiling.py +329 -0
  236. sqlalchemy/testing/provision.py +603 -0
  237. sqlalchemy/testing/requirements.py +1945 -0
  238. sqlalchemy/testing/schema.py +198 -0
  239. sqlalchemy/testing/suite/__init__.py +19 -0
  240. sqlalchemy/testing/suite/test_cte.py +237 -0
  241. sqlalchemy/testing/suite/test_ddl.py +389 -0
  242. sqlalchemy/testing/suite/test_deprecations.py +153 -0
  243. sqlalchemy/testing/suite/test_dialect.py +776 -0
  244. sqlalchemy/testing/suite/test_insert.py +630 -0
  245. sqlalchemy/testing/suite/test_reflection.py +3557 -0
  246. sqlalchemy/testing/suite/test_results.py +504 -0
  247. sqlalchemy/testing/suite/test_rowcount.py +258 -0
  248. sqlalchemy/testing/suite/test_select.py +2010 -0
  249. sqlalchemy/testing/suite/test_sequence.py +317 -0
  250. sqlalchemy/testing/suite/test_types.py +2147 -0
  251. sqlalchemy/testing/suite/test_unicode_ddl.py +189 -0
  252. sqlalchemy/testing/suite/test_update_delete.py +139 -0
  253. sqlalchemy/testing/util.py +535 -0
  254. sqlalchemy/testing/warnings.py +52 -0
  255. sqlalchemy/types.py +74 -0
  256. sqlalchemy/util/__init__.py +162 -0
  257. sqlalchemy/util/_collections.py +712 -0
  258. sqlalchemy/util/_concurrency_py3k.py +288 -0
  259. sqlalchemy/util/_has_cy.py +40 -0
  260. sqlalchemy/util/_py_collections.py +541 -0
  261. sqlalchemy/util/compat.py +421 -0
  262. sqlalchemy/util/concurrency.py +110 -0
  263. sqlalchemy/util/deprecations.py +401 -0
  264. sqlalchemy/util/langhelpers.py +2203 -0
  265. sqlalchemy/util/preloaded.py +150 -0
  266. sqlalchemy/util/queue.py +322 -0
  267. sqlalchemy/util/tool_support.py +201 -0
  268. sqlalchemy/util/topological.py +120 -0
  269. sqlalchemy/util/typing.py +734 -0
  270. sqlalchemy-2.0.47.dist-info/METADATA +243 -0
  271. sqlalchemy-2.0.47.dist-info/RECORD +274 -0
  272. sqlalchemy-2.0.47.dist-info/WHEEL +5 -0
  273. sqlalchemy-2.0.47.dist-info/licenses/LICENSE +19 -0
  274. sqlalchemy-2.0.47.dist-info/top_level.txt +1 -0
@@ -0,0 +1,326 @@
1
+ # dialects/postgresql/pg_catalog.py
2
+ # Copyright (C) 2005-2026 the SQLAlchemy authors and contributors
3
+ # <see AUTHORS file>
4
+ #
5
+ # This module is part of SQLAlchemy and is released under
6
+ # the MIT License: https://www.opensource.org/licenses/mit-license.php
7
+
8
+ from __future__ import annotations
9
+
10
+ from typing import Any
11
+ from typing import Optional
12
+ from typing import Sequence
13
+ from typing import TYPE_CHECKING
14
+
15
+ from .array import ARRAY
16
+ from .types import OID
17
+ from .types import REGCLASS
18
+ from ... import Column
19
+ from ... import func
20
+ from ... import MetaData
21
+ from ... import Table
22
+ from ...types import BigInteger
23
+ from ...types import Boolean
24
+ from ...types import CHAR
25
+ from ...types import Float
26
+ from ...types import Integer
27
+ from ...types import SmallInteger
28
+ from ...types import String
29
+ from ...types import Text
30
+ from ...types import TypeDecorator
31
+
32
+ if TYPE_CHECKING:
33
+ from ...engine.interfaces import Dialect
34
+ from ...sql.type_api import _ResultProcessorType
35
+
36
+
37
+ # types
38
+ class NAME(TypeDecorator[str]):
39
+ impl = String(64, collation="C")
40
+ cache_ok = True
41
+
42
+
43
+ class PG_NODE_TREE(TypeDecorator[str]):
44
+ impl = Text(collation="C")
45
+ cache_ok = True
46
+
47
+
48
+ class INT2VECTOR(TypeDecorator[Sequence[int]]):
49
+ impl = ARRAY(SmallInteger)
50
+ cache_ok = True
51
+
52
+
53
+ class OIDVECTOR(TypeDecorator[Sequence[int]]):
54
+ impl = ARRAY(OID)
55
+ cache_ok = True
56
+
57
+
58
+ class _SpaceVector:
59
+ def result_processor(
60
+ self, dialect: Dialect, coltype: object
61
+ ) -> _ResultProcessorType[list[int]]:
62
+ def process(value: Any) -> Optional[list[int]]:
63
+ if value is None:
64
+ return value
65
+ return [int(p) for p in value.split(" ")]
66
+
67
+ return process
68
+
69
+
70
+ REGPROC = REGCLASS # seems an alias
71
+
72
+ # functions
73
+ _pg_cat = func.pg_catalog
74
+ quote_ident = _pg_cat.quote_ident
75
+ pg_table_is_visible = _pg_cat.pg_table_is_visible
76
+ pg_type_is_visible = _pg_cat.pg_type_is_visible
77
+ pg_get_viewdef = _pg_cat.pg_get_viewdef
78
+ pg_get_serial_sequence = _pg_cat.pg_get_serial_sequence
79
+ format_type = _pg_cat.format_type
80
+ pg_get_expr = _pg_cat.pg_get_expr
81
+ pg_get_constraintdef = _pg_cat.pg_get_constraintdef
82
+ pg_get_indexdef = _pg_cat.pg_get_indexdef
83
+
84
+ # constants
85
+ RELKINDS_TABLE_NO_FOREIGN = ("r", "p")
86
+ RELKINDS_TABLE = RELKINDS_TABLE_NO_FOREIGN + ("f",)
87
+ RELKINDS_VIEW = ("v",)
88
+ RELKINDS_MAT_VIEW = ("m",)
89
+ RELKINDS_ALL_TABLE_LIKE = RELKINDS_TABLE + RELKINDS_VIEW + RELKINDS_MAT_VIEW
90
+
91
+ # tables
92
+ pg_catalog_meta = MetaData(schema="pg_catalog")
93
+
94
+ pg_namespace = Table(
95
+ "pg_namespace",
96
+ pg_catalog_meta,
97
+ Column("oid", OID),
98
+ Column("nspname", NAME),
99
+ Column("nspowner", OID),
100
+ )
101
+
102
+ pg_class = Table(
103
+ "pg_class",
104
+ pg_catalog_meta,
105
+ Column("oid", OID, info={"server_version": (9, 3)}),
106
+ Column("relname", NAME),
107
+ Column("relnamespace", OID),
108
+ Column("reltype", OID),
109
+ Column("reloftype", OID),
110
+ Column("relowner", OID),
111
+ Column("relam", OID),
112
+ Column("relfilenode", OID),
113
+ Column("reltablespace", OID),
114
+ Column("relpages", Integer),
115
+ Column("reltuples", Float),
116
+ Column("relallvisible", Integer, info={"server_version": (9, 2)}),
117
+ Column("reltoastrelid", OID),
118
+ Column("relhasindex", Boolean),
119
+ Column("relisshared", Boolean),
120
+ Column("relpersistence", CHAR, info={"server_version": (9, 1)}),
121
+ Column("relkind", CHAR),
122
+ Column("relnatts", SmallInteger),
123
+ Column("relchecks", SmallInteger),
124
+ Column("relhasrules", Boolean),
125
+ Column("relhastriggers", Boolean),
126
+ Column("relhassubclass", Boolean),
127
+ Column("relrowsecurity", Boolean),
128
+ Column("relforcerowsecurity", Boolean, info={"server_version": (9, 5)}),
129
+ Column("relispopulated", Boolean, info={"server_version": (9, 3)}),
130
+ Column("relreplident", CHAR, info={"server_version": (9, 4)}),
131
+ Column("relispartition", Boolean, info={"server_version": (10,)}),
132
+ Column("relrewrite", OID, info={"server_version": (11,)}),
133
+ Column("reloptions", ARRAY(Text)),
134
+ )
135
+
136
+ pg_type = Table(
137
+ "pg_type",
138
+ pg_catalog_meta,
139
+ Column("oid", OID, info={"server_version": (9, 3)}),
140
+ Column("typname", NAME),
141
+ Column("typnamespace", OID),
142
+ Column("typowner", OID),
143
+ Column("typlen", SmallInteger),
144
+ Column("typbyval", Boolean),
145
+ Column("typtype", CHAR),
146
+ Column("typcategory", CHAR),
147
+ Column("typispreferred", Boolean),
148
+ Column("typisdefined", Boolean),
149
+ Column("typdelim", CHAR),
150
+ Column("typrelid", OID),
151
+ Column("typelem", OID),
152
+ Column("typarray", OID),
153
+ Column("typinput", REGPROC),
154
+ Column("typoutput", REGPROC),
155
+ Column("typreceive", REGPROC),
156
+ Column("typsend", REGPROC),
157
+ Column("typmodin", REGPROC),
158
+ Column("typmodout", REGPROC),
159
+ Column("typanalyze", REGPROC),
160
+ Column("typalign", CHAR),
161
+ Column("typstorage", CHAR),
162
+ Column("typnotnull", Boolean),
163
+ Column("typbasetype", OID),
164
+ Column("typtypmod", Integer),
165
+ Column("typndims", Integer),
166
+ Column("typcollation", OID, info={"server_version": (9, 1)}),
167
+ Column("typdefault", Text),
168
+ )
169
+
170
+ pg_index = Table(
171
+ "pg_index",
172
+ pg_catalog_meta,
173
+ Column("indexrelid", OID),
174
+ Column("indrelid", OID),
175
+ Column("indnatts", SmallInteger),
176
+ Column("indnkeyatts", SmallInteger, info={"server_version": (11,)}),
177
+ Column("indisunique", Boolean),
178
+ Column("indnullsnotdistinct", Boolean, info={"server_version": (15,)}),
179
+ Column("indisprimary", Boolean),
180
+ Column("indisexclusion", Boolean, info={"server_version": (9, 1)}),
181
+ Column("indimmediate", Boolean),
182
+ Column("indisclustered", Boolean),
183
+ Column("indisvalid", Boolean),
184
+ Column("indcheckxmin", Boolean),
185
+ Column("indisready", Boolean),
186
+ Column("indislive", Boolean, info={"server_version": (9, 3)}), # 9.3
187
+ Column("indisreplident", Boolean),
188
+ Column("indkey", INT2VECTOR),
189
+ Column("indcollation", OIDVECTOR, info={"server_version": (9, 1)}), # 9.1
190
+ Column("indclass", OIDVECTOR),
191
+ Column("indoption", INT2VECTOR),
192
+ Column("indexprs", PG_NODE_TREE),
193
+ Column("indpred", PG_NODE_TREE),
194
+ )
195
+
196
+ pg_attribute = Table(
197
+ "pg_attribute",
198
+ pg_catalog_meta,
199
+ Column("attrelid", OID),
200
+ Column("attname", NAME),
201
+ Column("atttypid", OID),
202
+ Column("attstattarget", Integer),
203
+ Column("attlen", SmallInteger),
204
+ Column("attnum", SmallInteger),
205
+ Column("attndims", Integer),
206
+ Column("attcacheoff", Integer),
207
+ Column("atttypmod", Integer),
208
+ Column("attbyval", Boolean),
209
+ Column("attstorage", CHAR),
210
+ Column("attalign", CHAR),
211
+ Column("attnotnull", Boolean),
212
+ Column("atthasdef", Boolean),
213
+ Column("atthasmissing", Boolean, info={"server_version": (11,)}),
214
+ Column("attidentity", CHAR, info={"server_version": (10,)}),
215
+ Column("attgenerated", CHAR, info={"server_version": (12,)}),
216
+ Column("attisdropped", Boolean),
217
+ Column("attislocal", Boolean),
218
+ Column("attinhcount", Integer),
219
+ Column("attcollation", OID, info={"server_version": (9, 1)}),
220
+ )
221
+
222
+ pg_constraint = Table(
223
+ "pg_constraint",
224
+ pg_catalog_meta,
225
+ Column("oid", OID), # 9.3
226
+ Column("conname", NAME),
227
+ Column("connamespace", OID),
228
+ Column("contype", CHAR),
229
+ Column("condeferrable", Boolean),
230
+ Column("condeferred", Boolean),
231
+ Column("convalidated", Boolean, info={"server_version": (9, 1)}),
232
+ Column("conrelid", OID),
233
+ Column("contypid", OID),
234
+ Column("conindid", OID),
235
+ Column("conparentid", OID, info={"server_version": (11,)}),
236
+ Column("confrelid", OID),
237
+ Column("confupdtype", CHAR),
238
+ Column("confdeltype", CHAR),
239
+ Column("confmatchtype", CHAR),
240
+ Column("conislocal", Boolean),
241
+ Column("coninhcount", Integer),
242
+ Column("connoinherit", Boolean, info={"server_version": (9, 2)}),
243
+ Column("conkey", ARRAY(SmallInteger)),
244
+ Column("confkey", ARRAY(SmallInteger)),
245
+ )
246
+
247
+ pg_sequence = Table(
248
+ "pg_sequence",
249
+ pg_catalog_meta,
250
+ Column("seqrelid", OID),
251
+ Column("seqtypid", OID),
252
+ Column("seqstart", BigInteger),
253
+ Column("seqincrement", BigInteger),
254
+ Column("seqmax", BigInteger),
255
+ Column("seqmin", BigInteger),
256
+ Column("seqcache", BigInteger),
257
+ Column("seqcycle", Boolean),
258
+ info={"server_version": (10,)},
259
+ )
260
+
261
+ pg_attrdef = Table(
262
+ "pg_attrdef",
263
+ pg_catalog_meta,
264
+ Column("oid", OID, info={"server_version": (9, 3)}),
265
+ Column("adrelid", OID),
266
+ Column("adnum", SmallInteger),
267
+ Column("adbin", PG_NODE_TREE),
268
+ )
269
+
270
+ pg_description = Table(
271
+ "pg_description",
272
+ pg_catalog_meta,
273
+ Column("objoid", OID),
274
+ Column("classoid", OID),
275
+ Column("objsubid", Integer),
276
+ Column("description", Text(collation="C")),
277
+ )
278
+
279
+ pg_enum = Table(
280
+ "pg_enum",
281
+ pg_catalog_meta,
282
+ Column("oid", OID, info={"server_version": (9, 3)}),
283
+ Column("enumtypid", OID),
284
+ Column("enumsortorder", Float(), info={"server_version": (9, 1)}),
285
+ Column("enumlabel", NAME),
286
+ )
287
+
288
+ pg_am = Table(
289
+ "pg_am",
290
+ pg_catalog_meta,
291
+ Column("oid", OID, info={"server_version": (9, 3)}),
292
+ Column("amname", NAME),
293
+ Column("amhandler", REGPROC, info={"server_version": (9, 6)}),
294
+ Column("amtype", CHAR, info={"server_version": (9, 6)}),
295
+ )
296
+
297
+ pg_collation = Table(
298
+ "pg_collation",
299
+ pg_catalog_meta,
300
+ Column("oid", OID, info={"server_version": (9, 3)}),
301
+ Column("collname", NAME),
302
+ Column("collnamespace", OID),
303
+ Column("collowner", OID),
304
+ Column("collprovider", CHAR, info={"server_version": (10,)}),
305
+ Column("collisdeterministic", Boolean, info={"server_version": (12,)}),
306
+ Column("collencoding", Integer),
307
+ Column("collcollate", Text),
308
+ Column("collctype", Text),
309
+ Column("colliculocale", Text),
310
+ Column("collicurules", Text, info={"server_version": (16,)}),
311
+ Column("collversion", Text, info={"server_version": (10,)}),
312
+ )
313
+
314
+ pg_opclass = Table(
315
+ "pg_opclass",
316
+ pg_catalog_meta,
317
+ Column("oid", OID, info={"server_version": (9, 3)}),
318
+ Column("opcmethod", NAME),
319
+ Column("opcname", NAME),
320
+ Column("opsnamespace", OID),
321
+ Column("opsowner", OID),
322
+ Column("opcfamily", OID),
323
+ Column("opcintype", OID),
324
+ Column("opcdefault", Boolean),
325
+ Column("opckeytype", OID),
326
+ )
@@ -0,0 +1,183 @@
1
+ # dialects/postgresql/provision.py
2
+ # Copyright (C) 2005-2026 the SQLAlchemy authors and contributors
3
+ # <see AUTHORS file>
4
+ #
5
+ # This module is part of SQLAlchemy and is released under
6
+ # the MIT License: https://www.opensource.org/licenses/mit-license.php
7
+ # mypy: ignore-errors
8
+
9
+ import time
10
+
11
+ from ... import exc
12
+ from ... import inspect
13
+ from ... import text
14
+ from ...testing import warn_test_suite
15
+ from ...testing.provision import create_db
16
+ from ...testing.provision import drop_all_schema_objects_post_tables
17
+ from ...testing.provision import drop_all_schema_objects_pre_tables
18
+ from ...testing.provision import drop_db
19
+ from ...testing.provision import log
20
+ from ...testing.provision import post_configure_engine
21
+ from ...testing.provision import prepare_for_drop_tables
22
+ from ...testing.provision import set_default_schema_on_connection
23
+ from ...testing.provision import temp_table_keyword_args
24
+ from ...testing.provision import upsert
25
+
26
+
27
+ @create_db.for_db("postgresql")
28
+ def _pg_create_db(cfg, eng, ident):
29
+ template_db = cfg.options.postgresql_templatedb
30
+
31
+ with eng.execution_options(isolation_level="AUTOCOMMIT").begin() as conn:
32
+ if not template_db:
33
+ template_db = conn.exec_driver_sql(
34
+ "select current_database()"
35
+ ).scalar()
36
+
37
+ attempt = 0
38
+ while True:
39
+ try:
40
+ conn.exec_driver_sql(
41
+ "CREATE DATABASE %s TEMPLATE %s" % (ident, template_db)
42
+ )
43
+ except exc.OperationalError as err:
44
+ attempt += 1
45
+ if attempt >= 3:
46
+ raise
47
+ if "accessed by other users" in str(err):
48
+ log.info(
49
+ "Waiting to create %s, URI %r, "
50
+ "template DB %s is in use sleeping for .5",
51
+ ident,
52
+ eng.url,
53
+ template_db,
54
+ )
55
+ time.sleep(0.5)
56
+ except:
57
+ raise
58
+ else:
59
+ break
60
+
61
+
62
+ @drop_db.for_db("postgresql")
63
+ def _pg_drop_db(cfg, eng, ident):
64
+ with eng.connect().execution_options(isolation_level="AUTOCOMMIT") as conn:
65
+ with conn.begin():
66
+ conn.execute(
67
+ text(
68
+ "select pg_terminate_backend(pid) from pg_stat_activity "
69
+ "where usename=current_user and pid != pg_backend_pid() "
70
+ "and datname=:dname"
71
+ ),
72
+ dict(dname=ident),
73
+ )
74
+ conn.exec_driver_sql("DROP DATABASE %s" % ident)
75
+
76
+
77
+ @temp_table_keyword_args.for_db("postgresql")
78
+ def _postgresql_temp_table_keyword_args(cfg, eng):
79
+ return {"prefixes": ["TEMPORARY"]}
80
+
81
+
82
+ @set_default_schema_on_connection.for_db("postgresql")
83
+ def _postgresql_set_default_schema_on_connection(
84
+ cfg, dbapi_connection, schema_name
85
+ ):
86
+ existing_autocommit = dbapi_connection.autocommit
87
+ dbapi_connection.autocommit = True
88
+ cursor = dbapi_connection.cursor()
89
+ cursor.execute("SET SESSION search_path='%s'" % schema_name)
90
+ cursor.close()
91
+ dbapi_connection.autocommit = existing_autocommit
92
+
93
+
94
+ @drop_all_schema_objects_pre_tables.for_db("postgresql")
95
+ def drop_all_schema_objects_pre_tables(cfg, eng):
96
+ with eng.connect().execution_options(isolation_level="AUTOCOMMIT") as conn:
97
+ for xid in conn.exec_driver_sql(
98
+ "select gid from pg_prepared_xacts"
99
+ ).scalars():
100
+ conn.exec_driver_sql("ROLLBACK PREPARED '%s'" % xid)
101
+
102
+
103
+ @drop_all_schema_objects_post_tables.for_db("postgresql")
104
+ def drop_all_schema_objects_post_tables(cfg, eng):
105
+ from sqlalchemy.dialects import postgresql
106
+
107
+ inspector = inspect(eng)
108
+ with eng.begin() as conn:
109
+ for enum in inspector.get_enums("*"):
110
+ conn.execute(
111
+ postgresql.DropEnumType(
112
+ postgresql.ENUM(name=enum["name"], schema=enum["schema"])
113
+ )
114
+ )
115
+
116
+
117
+ @prepare_for_drop_tables.for_db("postgresql")
118
+ def prepare_for_drop_tables(config, connection):
119
+ """Ensure there are no locks on the current username/database."""
120
+
121
+ result = connection.exec_driver_sql(
122
+ "select pid, state, wait_event_type, query "
123
+ # "select pg_terminate_backend(pid), state, wait_event_type "
124
+ "from pg_stat_activity where "
125
+ "usename=current_user "
126
+ "and datname=current_database() and state='idle in transaction' "
127
+ "and pid != pg_backend_pid()"
128
+ )
129
+ rows = result.all() # noqa
130
+ if rows:
131
+ warn_test_suite(
132
+ "PostgreSQL may not be able to DROP tables due to "
133
+ "idle in transaction: %s"
134
+ % ("; ".join(row._mapping["query"] for row in rows))
135
+ )
136
+
137
+
138
+ @upsert.for_db("postgresql")
139
+ def _upsert(
140
+ cfg,
141
+ table,
142
+ returning,
143
+ *,
144
+ set_lambda=None,
145
+ sort_by_parameter_order=False,
146
+ index_elements=None,
147
+ ):
148
+ from sqlalchemy.dialects.postgresql import insert
149
+
150
+ stmt = insert(table)
151
+
152
+ table_pk = inspect(table).selectable
153
+
154
+ if set_lambda:
155
+ if index_elements is None:
156
+ index_elements = table_pk.primary_key
157
+ stmt = stmt.on_conflict_do_update(
158
+ index_elements=index_elements, set_=set_lambda(stmt.excluded)
159
+ )
160
+ else:
161
+ stmt = stmt.on_conflict_do_nothing()
162
+
163
+ stmt = stmt.returning(
164
+ *returning, sort_by_parameter_order=sort_by_parameter_order
165
+ )
166
+ return stmt
167
+
168
+
169
+ _extensions = [
170
+ ("citext", (13,)),
171
+ ("hstore", (13,)),
172
+ ]
173
+
174
+
175
+ @post_configure_engine.for_db("postgresql")
176
+ def _create_citext_extension(url, engine, follower_ident):
177
+ with engine.connect() as conn:
178
+ for extension, min_version in _extensions:
179
+ if conn.dialect.server_version_info >= min_version:
180
+ conn.execute(
181
+ text(f"CREATE EXTENSION IF NOT EXISTS {extension}")
182
+ )
183
+ conn.commit()