]> git.ipfire.org Git - thirdparty/sqlalchemy/sqlalchemy.git/log
thirdparty/sqlalchemy/sqlalchemy.git
4 years agoMerge "Correct cache key for proxy_owner, with_context_options"
mike bayer [Mon, 10 May 2021 20:04:20 +0000 (20:04 +0000)] 
Merge "Correct cache key for proxy_owner, with_context_options"

4 years agoMerge "calculate warnings stacklevels dynamically"
mike bayer [Mon, 10 May 2021 20:01:01 +0000 (20:01 +0000)] 
Merge "calculate warnings stacklevels dynamically"

4 years agocalculate warnings stacklevels dynamically
Mike Bayer [Fri, 7 May 2021 17:01:40 +0000 (13:01 -0400)] 
calculate warnings stacklevels dynamically

A new approach has been applied to the warnings system in SQLAlchemy to
accurately predict the appropriate stack level for each warning
dynamically. This allows evaluating the source of SQLAlchemy-generated
warnings and deprecation warnings to be more straightforward as the warning
will indicate the source line within end-user code, rather than from an
arbitrary level within SQLAlchemy's own source code.

Fixes: #6241
Change-Id: I9ecf3b3ea77424d15e8d4c0aa47350602c0568d7

4 years agoCorrect cache key for proxy_owner, with_context_options
Mike Bayer [Mon, 10 May 2021 17:19:14 +0000 (13:19 -0400)] 
Correct cache key for proxy_owner, with_context_options

Fixed issue in subquery loader strategy which prevented caching from
working correctly. This would have been seen in the logs as a "generated"
message instead of "cached" for all subqueryload SQL emitted, which by
saturating the cache with new keys would degrade overall performance; it
also would produce "LRU size alert" warnings.

In this issue we also observe that the local LRU cache for lazyloader
and selectinloader will get used for all subsequent loads as well,
which makes it more likely to hit the limit of 30.   However rather than
trying to work this out, it would be better if we removed the
loader-local LRU caches altogether once we are confident these
are working well.

Fixes: #6459
Change-Id: Id953e8f75536bb87f7e3315929cebcd8f84a5a50

4 years agoreset session on new #6449 test for pypy
Mike Bayer [Sun, 9 May 2021 16:42:19 +0000 (12:42 -0400)] 
reset session on new #6449 test for pypy

Change-Id: If1c8c755a7e9c0191c1666a13b9e920effbeb5bc

4 years agoformatting
Mike Bayer [Sun, 9 May 2021 16:14:42 +0000 (12:14 -0400)] 
formatting

Change-Id: I69092dc6c2121bb780aed1b145ccd3eaabb0ff5d

4 years agoMerge "Update SQLAlchemy README.unittests.rst"
mike bayer [Sun, 9 May 2021 16:08:34 +0000 (16:08 +0000)] 
Merge "Update SQLAlchemy README.unittests.rst"

4 years agoremove extra verbiage
Mike Bayer [Sun, 9 May 2021 15:54:15 +0000 (11:54 -0400)] 
remove extra verbiage

having all this verbiage in the template itself means
all the issues will have all this verbiage in them, so
pull it back again.  there is unfortunately no way to
cleanly direct reporters through the guidelines with github.

Change-Id: I9835e412fac244b639d1fe6970e4dab43ab95117

4 years agofix quote.
Mike Bayer [Sun, 9 May 2021 15:52:04 +0000 (11:52 -0400)] 
fix quote.

I really wish there were a way to get the guidelines to be
HTML formatted.

Change-Id: I22de6d40be9940e152c829a7c9a1cfc0eaf2211c

4 years agotrying a different issue template
Mike Bayer [Sun, 9 May 2021 15:19:38 +0000 (11:19 -0400)] 
trying a different issue template

Change-Id: Ibb4fda98f4fdef569ce0bb9435849f0009ff1a82

4 years agoUpdate SQLAlchemy README.unittests.rst
Gord Thompson [Sun, 9 May 2021 13:41:32 +0000 (07:41 -0600)] 
Update SQLAlchemy README.unittests.rst

Change-Id: Ic7af61e68a0828401fb6774f9f301d83fad95367

4 years agoMerge "Ensure propagate_to_loaders honored at the sub-loader level"
mike bayer [Sun, 9 May 2021 02:59:21 +0000 (02:59 +0000)] 
Merge "Ensure propagate_to_loaders honored at the sub-loader level"

4 years agoEnsure propagate_to_loaders honored at the sub-loader level
Mike Bayer [Sun, 9 May 2021 01:21:35 +0000 (21:21 -0400)] 
Ensure propagate_to_loaders honored at the sub-loader level

Fixed additional regression caused by "eager loaders run on unexpire"
feature :ticket:`1763` where the feature would run for a
``contains_eager()`` eagerload option in the case that the
``contains_eager()`` were chained to an additional eager loader option,
which would then produce an incorrect query as the original query-bound
join criteria were no longer present.

The contains_eager() option correctly included
propagate_to_loaders=False however this would not be considered
if the contains_eager() were chained and therefore bundled inside
of an enclosing loader.  We don't want to turn off propagation
completely in that case because we still want the other
loaders inside to be handled individually, so add a check
as each option is moved into the query context.

Fixes: #6449
Change-Id: Icd1d6611095c20ae44ff5d2df734c24770fc8812

4 years agoadd ssl_check_hostname option in mysqldb
Jerry Zhao [Fri, 23 Apr 2021 15:54:04 +0000 (11:54 -0400)] 
add ssl_check_hostname option in mysqldb

Added support for the ``ssl_check_hostname=`` parameter in mysql connection
URIs and updated the mysql dialect documentation regarding secure
connections. Original pull request courtesy of Jerry Zhao.

Fixes: #5397
Closes: #5759
Pull-request: https://github.com/sqlalchemy/sqlalchemy/pull/5759
Pull-request-sha: 75f4bdc68d4b5745c518472e8bc2b02cec0f81e6

Change-Id: I964bfa7a4c15e215a3ad6e2b907cb78f5b3e5036

4 years agoVersion 1.4.15 placeholder
Mike Bayer [Thu, 6 May 2021 21:24:52 +0000 (17:24 -0400)] 
Version 1.4.15 placeholder

4 years ago- 1.4.14 rel_1_4_14
Mike Bayer [Thu, 6 May 2021 21:15:56 +0000 (17:15 -0400)] 
- 1.4.14

4 years agofix absolute import
Mike Bayer [Thu, 6 May 2021 21:13:53 +0000 (17:13 -0400)] 
fix absolute import

Change-Id: I57e7bb8ac8f53c601b2ec5462d7502f8e53f1b0f

4 years agoMerge "don't cache TypeDecorator by default"
mike bayer [Thu, 6 May 2021 21:12:48 +0000 (21:12 +0000)] 
Merge "don't cache TypeDecorator by default"

4 years agoMerge "mypy: fix working directory for mypy_extra_test_paths."
mike bayer [Thu, 6 May 2021 19:56:10 +0000 (19:56 +0000)] 
Merge "mypy: fix working directory for mypy_extra_test_paths."

4 years agodon't cache TypeDecorator by default
Mike Bayer [Thu, 6 May 2021 16:24:00 +0000 (12:24 -0400)] 
don't cache TypeDecorator by default

The :class:`.TypeDecorator` class will now emit a warning when used in SQL
compilation with caching unless the ``.cache_ok`` flag is set to ``True``
or ``False``. ``.cache_ok`` indicates that all the parameters passed to the
object are safe to be used as a cache key, ``False`` means they are not.

Fixes: #6436
Change-Id: Ib1bb7dc4b124e38521d615c2e2e691e4915594fb

4 years agoMerge "unify transactional context managers"
mike bayer [Thu, 6 May 2021 14:11:04 +0000 (14:11 +0000)] 
Merge "unify transactional context managers"

4 years agounify transactional context managers
Mike Bayer [Sun, 2 May 2021 22:31:03 +0000 (18:31 -0400)] 
unify transactional context managers

Applied consistent behavior to the use case of
calling ``.commit()`` or ``.rollback()`` inside of an existing
``.begin()`` context manager, with the addition of potentially
emitting SQL within the block subsequent to the commit or rollback.
This change continues upon the change first added in
:ticket:`6155` where the use case of calling "rollback" inside of
a ``.begin()`` contextmanager block was proposed:

* calling ``.commit()`` or ``.rollback()`` will now be allowed
without error or warning within all scopes, including
that of legacy and future :class:`_engine.Engine`, ORM
:class:`_orm.Session`, asyncio :class:`.AsyncEngine`.  Previously,
the :class:`_orm.Session` disallowed this.

* The remaining scope of the context manager is then closed;
when the block ends, a check is emitted to see if the transaction
was already ended, and if so the block returns without action.

* It will now raise **an error** if subsequent SQL of any kind
is emitted within the block, **after** ``.commit()`` or
``.rollback()`` is called.   The block should be closed as
the state of the executable object would otherwise be undefined
in this state.

Fixes: #6288
Change-Id: I8b21766ae430f0fa1ac5ef689f4c0fb19fc84336

4 years agoAdd a comment in the compiler on why the NOT IN operator
Federico Caselli [Wed, 5 May 2021 20:06:19 +0000 (22:06 +0200)] 
Add a comment in the compiler on why the NOT IN operator
is rendered using brackets.

Change-Id: I39c2e6a03e8aad7ff27bc6000da5bc9f1de14dc2

4 years agomypy: fix working directory for mypy_extra_test_paths.
Maico Timmerman [Wed, 5 May 2021 18:20:18 +0000 (20:20 +0200)] 
mypy: fix working directory for mypy_extra_test_paths.

Change-Id: I55f6b414dd6893590231cc929648db90d3ee4161

4 years agoMerge "Parenthesize for empty not in"
mike bayer [Wed, 5 May 2021 16:36:08 +0000 (16:36 +0000)] 
Merge "Parenthesize for empty not in"

4 years agoUpdate README.dialects.rst
Gord Thompson [Wed, 5 May 2021 00:07:43 +0000 (18:07 -0600)] 
Update README.dialects.rst

Update link to sqlalchemy-access, plus a few minor tweaks

Change-Id: Ief2876760edf4f7cec311748012cb0944df3babd

4 years agoMerge "Establish deprecation path for CursorResult.keys()"
mike bayer [Wed, 5 May 2021 14:05:11 +0000 (14:05 +0000)] 
Merge "Establish deprecation path for CursorResult.keys()"

4 years agoMerge "mypy: load extra test files from environment variable"
mike bayer [Wed, 5 May 2021 14:04:08 +0000 (14:04 +0000)] 
Merge "mypy: load extra test files from environment variable"

4 years agoParenthesize for empty not in
Mike Bayer [Wed, 5 May 2021 12:38:54 +0000 (08:38 -0400)] 
Parenthesize for empty not in

Fixed regression caused by the "empty in" change just made in
:ticket:`6397` 1.4.12 where the expression needs to be parenthesized for
the "not in" use case, otherwise the condition will interfere with the
other filtering criteria.

also amends StrSQLCompiler to use the newer "empty IN" style for
its compilation process.

Fixes: #6428
Change-Id: I182a552fc0d3065a9e38c0f4ece2deb143735c36

4 years agomypy: load extra test files from environment variable
Maico Timmerman [Fri, 30 Apr 2021 14:36:23 +0000 (16:36 +0200)] 
mypy: load extra test files from environment variable

Add --mypy-extra-test-path parameter to pytest execution to list extra
directories to load test files from.
This enables the stubs repo to load this plugin and specify it's
own test directory to run mypy tests. Supports both single file tests
and incremental tests based on patch files.

Change-Id: Id6424ff15b2f527183b9713384df3d625a8e6eb8

4 years agoUse sqlalchemyorg action forks for the releases.
Federico Caselli [Tue, 4 May 2021 20:14:35 +0000 (22:14 +0200)] 
Use sqlalchemyorg action forks for the releases.

Change-Id: Ib7ccde2fbcaefe80859941e5e46bebf4fe4ea689

4 years agoEstablish deprecation path for CursorResult.keys()
Mike Bayer [Tue, 4 May 2021 17:31:51 +0000 (13:31 -0400)] 
Establish deprecation path for CursorResult.keys()

Established a deprecation path for calling upon the
:meth:`_cursor.CursorResult.keys` method for a statement that returns no
rows to provide support for legacy patterns used by the "records" package
as well as any other non-migrated applications. Previously, this would
raise :class:`.ResourceClosedException` unconditionally in the same way as
it does when attempting to fetch rows. While this is the correct behavior
going forward, the :class:`_cursor.LegacyCursorResult` object will now in
this case return an empty list for ``.keys()`` as it did in 1.3, while also
emitting a 2.0 deprecation warning. The :class:`_cursor.CursorResult`, used
when using a 2.0-style "future" engine, will continue to raise as it does
now.

Fixes: #6427
Change-Id: I4148f28c88039e4141deeab28b1a5994e6d6e098

4 years agoRestore detached object logic for dynamic, but warn
Mike Bayer [Tue, 4 May 2021 15:19:00 +0000 (11:19 -0400)] 
Restore detached object logic for dynamic, but warn

Fixed regression involving ``lazy='dynamic'`` loader in conjunction with a
detached object. The previous behavior was that the dynamic loader upon
calling methods like ``.all()`` returns empty lists for detached objects
without error, this has been restored; however a warning is now emitted as
this is not the correct result. Other dynamic loader scenarios correctly
raise ``DetachedInstanceError``.

Fixes: #6426
Change-Id: Id7ad204bef947491fa7e462c5acda2055fada910

4 years agoVersion 1.4.14 placeholder
Mike Bayer [Mon, 3 May 2021 19:32:53 +0000 (15:32 -0400)] 
Version 1.4.14 placeholder

4 years ago- 1.4.13 rel_1_4_13
Mike Bayer [Mon, 3 May 2021 19:25:21 +0000 (15:25 -0400)] 
- 1.4.13

4 years agochangelog updates
Mike Bayer [Mon, 3 May 2021 19:24:48 +0000 (15:24 -0400)] 
changelog updates

Change-Id: Ieee55faa002cc25b3009f643e1c992180de92292

4 years agoloader strategy regression fixes
Mike Bayer [Mon, 3 May 2021 13:55:12 +0000 (09:55 -0400)] 
loader strategy regression fixes

Fixed regression where using :func:`_orm.selectinload` and
:func:`_orm.subqueryload` to load a two-level-deep path would lead to an
attribute error.

Fixed regression where using the :func:`_orm.noload` loader strategy in
conjunction with a "dynamic" relationship would lead to an attribute error
as the noload strategy would attempt to apply itself to the dynamic loader.

Fixes: #6419
Fixes: #6420
Change-Id: I933b208f16a9723f6ebeab7addbe118903a1f8f5

4 years agorestore legacy begin_nested()->root transaction behavior
Mike Bayer [Sun, 2 May 2021 14:19:16 +0000 (10:19 -0400)] 
restore legacy begin_nested()->root transaction behavior

Restored a legacy transactional behavior that was inadvertently removed
from the :class:`_engine.Connection` as it was never tested as a known use
case in previous versions, where calling upon the
:meth:`_engine.Connection.begin_nested` method, when no transaction were
present, would not create a SAVEPOINT at all, and would instead only start
the outermost transaction alone, and return that :class:`.RootTransaction`
object, acting like the outermost transaction.   Committing the transaction
object returned by :meth:`_engine.Connection.begin_nested` would therefore
emit a real COMMIT on the database connection.

This behavior is not at all what the 2.0 style connection will do - in 2.0
style, calling :meth:`_future.Connection.begin_nested` will "autobegin" the
outer transaction, and then as instructed emit a SAVEPOINT, returning the
:class:`.NestedTransaction` object. The outer transaction is committed by
calling upon :meth:`_future.Connection.commit`, as is "commit-as-you-go"
style usage.

In non-"future" mode, while the old behavior is restored, it also
emits a 2.0 deprecation warning as this is a legacy behavior.

Additionally clarifies and reformats various engine-related
documentation, in particular future connection.begin() which
was a tire fire.

Fixes: #6408
Change-Id: I4b81cc6b481b5493eef4c91bebc03210e2206d39

4 years agofix formatting
Mike Bayer [Sun, 2 May 2021 13:18:04 +0000 (09:18 -0400)] 
fix formatting

Change-Id: Id9026521d878baa2b2fc96159384135c27344def

4 years agoMerge "Support stream_results in the pg8000 dialect"
mike bayer [Sun, 2 May 2021 13:17:00 +0000 (13:17 +0000)] 
Merge "Support stream_results in the pg8000 dialect"

4 years agoMerge "Support filter_by() from columns, functions, Core SQL"
mike bayer [Sun, 2 May 2021 13:13:42 +0000 (13:13 +0000)] 
Merge "Support filter_by() from columns, functions, Core SQL"

4 years agospecify tuple_in for composite selectinload test / mssql
Mike Bayer [Sat, 1 May 2021 18:59:39 +0000 (14:59 -0400)] 
specify tuple_in for composite selectinload test / mssql

Change-Id: Ie527c4aa02d48bf1fcce3e192cd6299c15569fb0

4 years agoAvoid creating asyncio.Lock on the wrong loop.
Federico Caselli [Fri, 30 Apr 2021 20:36:59 +0000 (22:36 +0200)] 
Avoid creating asyncio.Lock on the wrong loop.

Fixed a regression introduced by :ticket:`6337` that would create an
``asyncio.Lock`` which could be attached to the wrong loop when
instantiating the async engine before any asyncio loop was started, leading
to an asyncio error message when attempting to use the engine under certain
circumstances.

Fixes: #6409
Change-Id: I8119c56b44a7bd70a650c0ea676892d4d7814a8b

4 years agoSupport filter_by() from columns, functions, Core SQL
Mike Bayer [Sat, 1 May 2021 12:41:09 +0000 (08:41 -0400)] 
Support filter_by() from columns, functions, Core SQL

Fixed regression where :meth:`_orm.Query.filter_by` would not work if the
lead entity were a SQL function or other expression derived from the
primary entity in question, rather than a simple entity or column of that
entity. Additionally, improved the behavior of
:meth:`_sql.Select.filter_by` overall to work with column expressions even
in a non-ORM context.

Fixes: #6414
Change-Id: I316b5bf98293bec1ede08787f6181dd14be85419

4 years agotrack_on needs to be a fixed size, support sub-tuples
Mike Bayer [Fri, 30 Apr 2021 15:54:52 +0000 (11:54 -0400)] 
track_on needs to be a fixed size, support sub-tuples

Fixed regression in ``selectinload`` loader strategy that would cause it to
cache its internal state incorrectly when handling relationships that join
across more than one column, such as when using a composite foreign key.
The invalid caching would then cause other loader operations to fail.

Fixes: #6410
Change-Id: I9f95ccca3553e7fd5794c619be4cf85c02b04626

4 years agoVersion 1.4.13 placeholder
Mike Bayer [Thu, 29 Apr 2021 21:56:51 +0000 (17:56 -0400)] 
Version 1.4.13 placeholder

4 years ago- 1.4.12 rel_1_4_12
Mike Bayer [Thu, 29 Apr 2021 21:46:15 +0000 (17:46 -0400)] 
- 1.4.12

4 years agofix typo
Mike Bayer [Thu, 29 Apr 2021 21:44:17 +0000 (17:44 -0400)] 
fix typo

Change-Id: I664eb4f4c023ec41d51c444919ca4b6867267738

4 years agoMerge "Ensure iterable passed to Select is not a mapped class"
mike bayer [Thu, 29 Apr 2021 21:28:32 +0000 (21:28 +0000)] 
Merge "Ensure iterable passed to Select is not a mapped class"

4 years agoMerge "Fix ForeignKeyConstraint.copy() error"
mike bayer [Thu, 29 Apr 2021 21:28:19 +0000 (21:28 +0000)] 
Merge "Fix ForeignKeyConstraint.copy() error"

4 years agoEnsure iterable passed to Select is not a mapped class
Mike Bayer [Thu, 29 Apr 2021 20:38:03 +0000 (16:38 -0400)] 
Ensure iterable passed to Select is not a mapped class

Fixed regression caused by :ticket:`5395` where tuning back the check for
sequences in :func:`_sql.select` now caused failures when doing 2.0-style
querying with a mapped class that also happens to have an ``__iter__()``
method. Tuned the check some more to accommodate this as well as some other
interesting ``__iter__()`` scenarios.

Fixes: #6300
Change-Id: Idf1983fd764b91a7d5fa8117aee8a3def3cfe5ff

4 years agoFix ForeignKeyConstraint.copy() error
Gord Thompson [Thu, 29 Apr 2021 18:57:06 +0000 (12:57 -0600)] 
Fix ForeignKeyConstraint.copy() error

Fixed an issue with the (deprecated in 1.4)
:meth:`_schema.ForeignKeyConstraint.copy` method that caused an error when
invoked with the ``schema`` argument.

Fixes: #6353
Change-Id: I03330d9ec254d64377f2b2e86af69a4eaff43ac6

4 years agoMerge "fix mapper._primary_key_propkeys"
mike bayer [Thu, 29 Apr 2021 19:54:00 +0000 (19:54 +0000)] 
Merge "fix mapper._primary_key_propkeys"

4 years agoMerge "Use non-subquery form for empty IN"
mike bayer [Thu, 29 Apr 2021 19:53:02 +0000 (19:53 +0000)] 
Merge "Use non-subquery form for empty IN"

4 years agoUse non-subquery form for empty IN
Mike Bayer [Wed, 28 Apr 2021 22:31:51 +0000 (18:31 -0400)] 
Use non-subquery form for empty IN

Revised the "EMPTY IN" expression to no longer rely upon using a subquery,
as this was causing some compatibility and performance problems. The new
approach for selected databases takes advantage of using a NULL-returning
IN expression combined with the usual "1 != 1" or "1 = 1" expression
appended by AND or OR. The expression is now the default for all backends
other than SQLite, which still had some compatibility issues regarding
tuple "IN" for older SQLite versions.

Third party dialects can still override how the "empty set" expression
renders by implementing a new compiler method
``def visit_empty_set_op_expr(self, type_, expand_op)``, which takes
precedence over the existing
``def visit_empty_set_expr(self, element_types)`` which remains in place.

Fixes: #6258
Fixes: #6397
Change-Id: I2df09eb00d2ad3b57039ae48128fdf94641b5e59

4 years agoSupport stream_results in the pg8000 dialect
Tony Locke [Thu, 29 Apr 2021 18:25:09 +0000 (14:25 -0400)] 
Support stream_results in the pg8000 dialect

### Description
This change adds support for stream_results for the pg8000 dialect by adding a server side cursor. The server-side cursor is a wrapper around a standard DBAPI cursor, and uses the SQL-level cursors. This is being discussed in issue https://github.com/sqlalchemy/sqlalchemy/issues/6198 and this pull request is really to give a concrete example of what I was suggesting.

### Checklist

<!-- go over following points. check them with an `x` if they do apply, (they turn into clickable checkboxes once the PR is submitted, so no need to do everything at once)

-->

This pull request is:

- [ ] A documentation / typographical error fix
- Good to go, no issue or tests are needed
- [ ] A short code fix
- please include the issue number, and create an issue if none exists, which
  must include a complete example of the issue.  one line code fixes without an
  issue and demonstration will not be accepted.
- Please include: `Fixes: #<issue number>` in the commit message
- please include tests.   one line code fixes without tests will not be accepted.
- [x] A new feature implementation
- please include the issue number, and create an issue if none exists, which must
  include a complete example of how the feature would look.
- Please include: `Fixes: #<issue number>` in the commit message
- please include tests.

**Have a nice day!**

Closes: #6356
Pull-request: https://github.com/sqlalchemy/sqlalchemy/pull/6356
Pull-request-sha: 071e118a6b09a26c511b39b0d589ebd2de8d508c

Change-Id: Id1a865adf0ff64294c71814681f5b4d593939db6

4 years agofix mapper._primary_key_propkeys
Mike Bayer [Thu, 29 Apr 2021 16:03:47 +0000 (12:03 -0400)] 
fix mapper._primary_key_propkeys

Fixed issue in :meth:`_orm.Session.bulk_save` when used with persistent
objects which would fail to track the primary key of mappings where the
column name of the primary key were different than the attribute name.

Fixes: #6392
Change-Id: I9b89bf00f900b7d2287517249e4f9356f20f0bdb

4 years agoaccommodate HasEntityNamespace in context.all_selected_columns
Mike Bayer [Thu, 29 Apr 2021 14:40:00 +0000 (10:40 -0400)] 
accommodate HasEntityNamespace in context.all_selected_columns

Fixed regression in hybrid_property where a hybrid against a SQL function
would generate an ``AttributeError`` when attempting to generate an entry
for the ``.c`` collection of a subquery in some cases; among other things
this would impact its use in cases like that of ``Query.count()``.

Fixes: #6401
Change-Id: Icc243c699e9a5c88448076c6427ec389eaa8b8ed

4 years agochangelog updates
Mike Bayer [Thu, 29 Apr 2021 13:18:15 +0000 (09:18 -0400)] 
changelog updates

Change-Id: I43d6373f00d55599bc11f01a2ed8f644c4477dd5

4 years agoMerge "Propertly ignore ``Identity`` in MySQL and MariaDb."
mike bayer [Thu, 29 Apr 2021 12:59:42 +0000 (12:59 +0000)] 
Merge "Propertly ignore ``Identity`` in MySQL and MariaDb."

4 years agoclarify individual isolation level section
Mike Bayer [Thu, 29 Apr 2021 12:42:40 +0000 (08:42 -0400)] 
clarify individual isolation level section

also rewrite the "individual sessions" section
to not rely upon context from the previous section,
this is a bad habit and should be fixed whereever we can
find it becuase people click on individual sections out of
context.

Change-Id: I288ffcc84ff462fb36cd7f4075f39d53c55fbf35

4 years agoPropertly ignore ``Identity`` in MySQL and MariaDb.
Federico Caselli [Wed, 21 Apr 2021 20:49:09 +0000 (22:49 +0200)] 
Propertly ignore ``Identity`` in MySQL and MariaDb.

Ensure that the MySQL and MariaDB dialect ignore the
:class:`_sql.Identity` construct while rendering the
``AUTO_INCREMENT`` keyword in a create table.

The Oracle and PostgreSQL compiler was updated to not render
:class:`_sql.Identity` if the database version does not support it
(Oracle < 12 and PostgreSQL < 10). Previously it was rendered regardless
of the database version.

Fixes: #6338
Change-Id: I2ca0902fdd7b4be4fc1a563cf5585504cbea9360

4 years agoMerge "Use SingletonThreadPool for in-memory SQLite database created using filename...
mike bayer [Wed, 28 Apr 2021 22:53:48 +0000 (22:53 +0000)] 
Merge "Use SingletonThreadPool for in-memory SQLite database created using filename uri"

4 years agoMerge "Add .as_generic() support to mssql BIT columns"
mike bayer [Wed, 28 Apr 2021 22:53:04 +0000 (22:53 +0000)] 
Merge "Add .as_generic() support to mssql BIT columns"

4 years agoMerge "ensure SelectState.all_selected_columns not memoized as a generator"
mike bayer [Wed, 28 Apr 2021 22:51:45 +0000 (22:51 +0000)] 
Merge "ensure SelectState.all_selected_columns not memoized as a generator"

4 years agoMerge "add optional proxy_class to track w/ proxy_key"
mike bayer [Wed, 28 Apr 2021 22:50:31 +0000 (22:50 +0000)] 
Merge "add optional proxy_class to track w/ proxy_key"

4 years agoMerge "accommodate for mutiple copies of bind in ckbm"
mike bayer [Wed, 28 Apr 2021 21:10:09 +0000 (21:10 +0000)] 
Merge "accommodate for mutiple copies of bind in ckbm"

4 years agoUse SingletonThreadPool for in-memory SQLite
YongJieYongJie [Wed, 28 Apr 2021 17:30:09 +0000 (13:30 -0400)] 
Use SingletonThreadPool for in-memory SQLite
database created using filename uri

Default to using ``SingletonThreadPool`` for in-memory SQLite databases
created using URI filenames. Previously the default pool used was the
``NullPool`` that precented sharing the same database between multiple
engines.

Fixes: #6379
Closes: #6380
Pull-request: https://github.com/sqlalchemy/sqlalchemy/pull/6380
Pull-request-sha: 3b8024417a3a54c8269d43e40801aa4e58593540

Change-Id: Ice09622796455e796ede7711c98f3ceec13aa949

4 years ago✏️ Fix minor typos in "Selecting Rows with Core or ORM" (#6381)
Sebastián Ramírez [Wed, 28 Apr 2021 18:42:12 +0000 (20:42 +0200)] 
✏️ Fix minor typos in "Selecting Rows with Core or ORM" (#6381)

4 years ago✏️ Fix typos in "Data Manipulation with the ORM" (#6389)
Sebastián Ramírez [Wed, 28 Apr 2021 18:42:07 +0000 (20:42 +0200)] 
✏️ Fix typos in "Data Manipulation with the ORM" (#6389)

4 years ago✏️ Fix a small typo in the Glossary (#6395)
Sebastián Ramírez [Wed, 28 Apr 2021 18:42:01 +0000 (20:42 +0200)] 
✏️ Fix a small typo in the Glossary (#6395)

4 years ago✏️ Fix typos in "Working with Related Objects" (#6393)
Sebastián Ramírez [Wed, 28 Apr 2021 18:41:54 +0000 (20:41 +0200)] 
✏️ Fix typos in "Working with Related Objects" (#6393)

4 years ago✏️ Fix small typo in "Updating and Deleting Rows with Core" (#6382)
Sebastián Ramírez [Wed, 28 Apr 2021 18:39:29 +0000 (20:39 +0200)] 
✏️ Fix small typo in "Updating and Deleting Rows with Core" (#6382)

4 years agoaccommodate for mutiple copies of bind in ckbm
Mike Bayer [Wed, 28 Apr 2021 16:14:33 +0000 (12:14 -0400)] 
accommodate for mutiple copies of bind in ckbm

Fixed critical regression where bound parameter tracking as used in the SQL
caching system could fail to track all parameters for the case where the
same SQL expression containing a parameter were used in an ORM-related
query using a feature such as class inheritance, which was then embedded in
an enclosing expression which would make use of that same expression
multiple times, such as a UNION. The ORM would individually copy the
individual SELECT statements as part of compilation with class inheritance,
which then embedded in the enclosing statement would fail to accommodate
for all parameters. The logic that tracks this condition has been adjusted
to work for multiple copies of a parameter.

Fixes: #6391
Change-Id: I6db5dee0d361a3bb58d753a2d27ef2eee2b369c5

4 years agoensure SelectState.all_selected_columns not memoized as a generator
Mike Bayer [Wed, 28 Apr 2021 18:11:20 +0000 (14:11 -0400)] 
ensure SelectState.all_selected_columns not memoized as a generator

This regression was found from #6261 before release of 1.4.12

Fixes: #6261
Fixes: #6394
Change-Id: I4c2c5da02dbcf5c2cea26c81d3521de892ef428e

4 years agoadd optional proxy_class to track w/ proxy_key
Mike Bayer [Wed, 28 Apr 2021 13:56:15 +0000 (09:56 -0400)] 
add optional proxy_class to track w/ proxy_key

Fixed regression in ORM where using hybrid property to indicate an
expression from a different entity would confuse the column-labeling logic
in the ORM and attempt to derive the name of the hybrid from that other
class, leading to an attribute error. The owning class of the hybrid
attribute is now tracked along with the name.

Fixes: #6386
Change-Id: Ica9497ea34fef799d6265de44104c1f3f3b30232

4 years agodon't mutate the statement in ORM compile
Mike Bayer [Wed, 28 Apr 2021 00:44:46 +0000 (20:44 -0400)] 
don't mutate the statement in ORM compile

Fixed issue where using a :class:`_sql.Select` as a subquery in an ORM
context would modify the :class:`_sql.Select` in place to disable
eagerloads on that object, which would then cause that same
:class:`_sql.Select` to not eagerload if it were then re-used in a
top-level execution context.

Fixes: #6378
Change-Id: I945048c4c148587b933fb65a3fc83a05d05c052d

4 years ago✏️ Fix small typos in "Working with Database Metadata" (#6369)
Sebastián Ramírez [Tue, 27 Apr 2021 20:22:38 +0000 (22:22 +0200)] 
✏️ Fix small typos in "Working with Database Metadata" (#6369)

4 years agotypo in an import statement in docs (#6362)
Geraint Williams [Tue, 27 Apr 2021 20:22:29 +0000 (21:22 +0100)] 
typo in an import statement in docs (#6362)

* typo in import in docs

* fix typo in documentation import statement

4 years ago✏️ Fix small formatting typo in "Working with Data" (#6370)
Sebastián Ramírez [Tue, 27 Apr 2021 20:22:01 +0000 (22:22 +0200)] 
✏️ Fix small formatting typo in "Working with Data" (#6370)

4 years agoAdd .as_generic() support to mssql BIT columns
Gord Thompson [Thu, 22 Apr 2021 14:52:15 +0000 (08:52 -0600)] 
Add .as_generic() support to mssql BIT columns

Fixes: #6345
Change-Id: I2bdccc88e85c94d87519f58e474689ca7896f063

4 years agoMerge "have SchemaType inherit schema from metadata"
mike bayer [Tue, 27 Apr 2021 18:20:19 +0000 (18:20 +0000)] 
Merge "have SchemaType inherit schema from metadata"

4 years agohave SchemaType inherit schema from metadata
Mike Bayer [Tue, 27 Apr 2021 17:09:04 +0000 (13:09 -0400)] 
have SchemaType inherit schema from metadata

Fixed very old issue where the :class:`_types.Enum` datatype would not
inherit the :paramref:`_schema.MetaData.schema` parameter of a
:class:`_schema.MetaData` object when that object were passed to the
:class:`_types.Enum` using :paramref:`_types.Enum.metadata`.

Fixes: #6373
Change-Id: Ie77d5e8cbc0bd7bfd0039fb60a4a0bde2df58ca9

4 years agoMerge "Pass all datetime values to pyodbc for timezone-naive column"
mike bayer [Tue, 27 Apr 2021 02:03:21 +0000 (02:03 +0000)] 
Merge "Pass all datetime values to pyodbc for timezone-naive column"

4 years agoPass all datetime values to pyodbc for timezone-naive column
Mike Bayer [Mon, 26 Apr 2021 23:17:06 +0000 (19:17 -0400)] 
Pass all datetime values to pyodbc for timezone-naive column

Fixed regression caused by :ticket:`6306` which added support for
``DateTime(timezone=True)``, where the previous behavior of the pyodbc
driver of implicitly dropping the tzinfo from a timezone-aware date when
INSERTing into a timezone-naive DATETIME column were lost, leading to a SQL
Server error when inserting timezone-aware datetime objects into
timezone-native database columns.

Fixes: #6366
Change-Id: Id7821de13d75ede27f2165b37277a7223468dfa4

4 years agoMerge "Handle Sequence in _process_multiparam_default_bind"
mike bayer [Mon, 26 Apr 2021 22:42:48 +0000 (22:42 +0000)] 
Merge "Handle Sequence in _process_multiparam_default_bind"

4 years ago✏️ Fix small typos in SQLAlchemy 1.4 / 2.0 Tutorial (#6358)
Sebastián Ramírez [Mon, 26 Apr 2021 19:49:38 +0000 (21:49 +0200)] 
✏️ Fix small typos in SQLAlchemy 1.4 / 2.0 Tutorial (#6358)

* ✏️ Fix small typos in SQLAlchemy 1.4 / 2.0 Tutorial

* ⏪ Revert bikeshedding about "they", "we"

as I'm not sure changing to "they" actually helps disambiguate or not, so better to leave as it is.

4 years ago✏️ Fix small typo in Working with Transactions and the DBAPI (#6363)
Sebastián Ramírez [Mon, 26 Apr 2021 19:49:02 +0000 (21:49 +0200)] 
✏️ Fix small typo in Working with Transactions and the DBAPI (#6363)

4 years agoRemove py38 profiles
Federico Caselli [Mon, 26 Apr 2021 19:11:32 +0000 (21:11 +0200)] 
Remove py38 profiles

Change-Id: I726477b1c15fc6744ed16192ffca09df85bb01c8

4 years agoHandle Sequence in _process_multiparam_default_bind
Mike Bayer [Mon, 26 Apr 2021 17:30:29 +0000 (13:30 -0400)] 
Handle Sequence in _process_multiparam_default_bind

Fixed issue where usage of an explicit :class:`.Sequence` would produce
inconsistent "inline" behavior for an :class:`.Insert` construct that
includes multiple values phrases; the first seq would be inline but
subsequent ones would be "pre-execute", leading to inconsistent sequence
ordering. The sequence expressions are now fully inline.

Fixes: #6361
Change-Id: Ie16794ec0e19979a7e6c8d1bef5716a9fc199889

4 years agoEnsure autobegin occurs for attribute changes; Document autobegin
Mike Bayer [Mon, 26 Apr 2021 13:50:50 +0000 (09:50 -0400)] 
Ensure autobegin occurs for attribute changes; Document autobegin

The Session autobegin feature was not anticipated as having
any behavioral changes other than the event hook being called
at a different time, however as autobegin impacts the behavior
of the commit() and rollback() methods in that they can now
be no-ops in non-autocommit mode, document the behavior fully.

Fixed issue where the new :ref:`session_autobegin` behavior failed to
"autobegin" in the case where an existing persistent object has an
attribute change, which would then impact the behavior of
:meth:`_orm.Session.rollback` in that no snapshot was created to be rolled
back. The "attribute modify" mechanics have been updated to ensure
"autobegin", which does not perform any database work, does occur when
persistent attributes change in the same manner as when
:meth:`_orm.Session.add` is called. This is a regression as in 1.3, the
rollback() method always had a transaction to roll back and would expire
every time.

Fixes: #6360
Fixes: #6359
Change-Id: I69f231a206f49e3231275d23bbe2cafd4e2bf3ba

4 years agoAdd order by to union example
Mike Bayer [Fri, 23 Apr 2021 23:15:48 +0000 (19:15 -0400)] 
Add order by to union example

the query in the second union example needs order by to
produce determinstic results on all plaforms including
OSX, arm

Change-Id: I88fcc391561db8567c389ed9e904e5de29c1c2ad

4 years agoMerge remote-tracking branch 'origin/pr/6341'
Mike Bayer [Fri, 23 Apr 2021 15:58:57 +0000 (11:58 -0400)] 
Merge remote-tracking branch 'origin/pr/6341'

Change-Id: I48e62f09d4f0f64ec409aa82272bb02a521cd53d

4 years agoMerge "dont assume ClauseElement in attributes, coercions"
mike bayer [Fri, 23 Apr 2021 15:52:40 +0000 (15:52 +0000)] 
Merge "dont assume ClauseElement in attributes, coercions"

4 years agoMerge "implement declared_attr superclass assignment check for dataclasses"
mike bayer [Fri, 23 Apr 2021 15:51:05 +0000 (15:51 +0000)] 
Merge "implement declared_attr superclass assignment check for dataclasses"

4 years agoAdd cross-linking for self-referential examples
Mike Bayer [Fri, 23 Apr 2021 15:29:58 +0000 (11:29 -0400)] 
Add cross-linking for self-referential examples

Change-Id: Ib2cb88210c680baafc26f714263309af11cda15a
References: #6351

4 years agoimplement declared_attr superclass assignment check for dataclasses
Mike Bayer [Fri, 23 Apr 2021 01:45:10 +0000 (21:45 -0400)] 
implement declared_attr superclass assignment check for dataclasses

Adjusted the declarative scan for dataclasses so that the inheritance
behavior of :func:`_orm.declared_attr` established on a mixin, when using
the new form of having it inside of a ``dataclasses.field()`` construct and
not actually a descriptor attribute on the class, correctly accommodates
the case when the target class to be mapped is a subclass of an existing
mapped class which has already mapped that :func:`_orm.declared_attr`, and
therefore should not be re-applied to this class.

Also, as changed in ed3f2c617239668d we now have an "is_dataclass"
boolean set as we iterate through attrs so we can remove this
from declared_attr.

Fixes: #6346
Change-Id: Iec75bdefd3bff7d8a9a157c8dd744ac14ff15ea8

4 years agodont assume ClauseElement in attributes, coercions
Mike Bayer [Fri, 23 Apr 2021 14:19:39 +0000 (10:19 -0400)] 
dont assume ClauseElement in attributes, coercions

Fixed two distinct issues, each of which would come into play under certain
circumstances, most likely however one which is a common mis-configuration
in :class:`_hybrid.hybrid_property`, where the "expression" implementation
would return a non :class:`_sql.ClauseElement` such as a boolean value.
For both issues, 1.3's behavior was to silently ignore the
mis-configuration and ultimately attempt to interpret the value as a
SQL expression, which would lead to an incorrect query.

* Fixed issue regarding interaction of the attribute system with
hybrid_property, where if the ``__clause_element__()`` method of the
attribute returned a non-:class:`_sql.ClauseElement` object, an internal
``AttributeError`` would lead the attribute to return the ``expression``
function on the hybrid_property itself, as the attribute error was
against the name ``.expression`` which would invoke the ``__getattr__()``
method as a fallback. This now raises explicitly. In 1.3 the
non-:class:`_sql.ClauseElement` was returned directly.

* Fixed issue in SQL argument coercions system where passing the wrong
kind of object to methods that expect column expressions would fail if
the object were altogether not a SQLAlchemy object, such as a Python
function, in cases where the object were not just coerced into a bound
value. Again 1.3 did not have a comprehensive argument coercion system
so this case would also pass silently.

Fixes: #6350
Change-Id: I5bba0a6b27f45e5f8ebadfd6d511fa773388ef7c

4 years agoMerge "omit text from selected_columns; clear memoizations"
mike bayer [Thu, 22 Apr 2021 22:59:53 +0000 (22:59 +0000)] 
Merge "omit text from selected_columns; clear memoizations"

4 years agoBreak up data.rst; add unions, literal_column
Mike Bayer [Thu, 22 Apr 2021 20:05:16 +0000 (16:05 -0400)] 
Break up data.rst; add unions, literal_column

This breaks data.rst into three separate sub-sections,
as SELECT is getting very long.  It then adds sections
on select() + text/literal_column as well as unions
and set operations, and also tries to improve the
ORDER BY section a bit.

Change-Id: Id90e6b4ff3699b2bbcb6e2eebbd23193e2ede00a