]> git.ipfire.org Git - thirdparty/sqlalchemy/sqlalchemy.git/log
thirdparty/sqlalchemy/sqlalchemy.git
5 years agoImprove the method ``__str__`` of :class:`ColumnCollection`
Federico Caselli [Mon, 23 Mar 2020 20:17:01 +0000 (21:17 +0100)] 
Improve the method ``__str__`` of :class:`ColumnCollection`

The change avoids confusing a :class:`ColumnCollection` with a python list since the
previous string representation was the same.

Fixes: #5191
Change-Id: Icdbc08f9991d31ce86372505e3614740eaee56e2

5 years agoMerge "Remove deprecated elements from selectable.py; remove lockmode"
mike bayer [Mon, 23 Mar 2020 18:55:02 +0000 (18:55 +0000)] 
Merge "Remove deprecated elements from selectable.py; remove lockmode"

5 years agoRemove deprecated elements from selectable.py; remove lockmode
Mike Bayer [Sun, 2 Feb 2020 16:39:37 +0000 (11:39 -0500)] 
Remove deprecated elements from selectable.py; remove lockmode

Removed autocommit and legacy "for update" / "lockmode" elements
from selectable.py / query.py.  lockmode was removed from
selectable in 693938dd6fb2f3ee3e031aed4c62355ac97f3ceb
however was not removed from the ORM.

Also removes the ignore_nonexistent_tables option on
join().

Change-Id: I0cfcf9e6a8d4ef6432c9e25ef75173b3b3f5fd87
Partially-fixes: #4643

5 years agoImplement autocommit isolation level for cx_oracle
Gord Thompson [Thu, 12 Mar 2020 18:54:37 +0000 (12:54 -0600)] 
Implement autocommit isolation level for cx_oracle

As part of this change Oracle also gets the concept of a
default isolation level, however since Oracle does not provide a
fixed method of knowing what the isolation level would be without a
server side transaction actually in progress, for now we hardcode
just to "READ COMMITTED".

Enhanced the test suite for isolation level testing in the dialect
test suite and added features to requirements so that the supported
isolation levels can be reported generically for dialects.

Co-authored-by: Mike Bayer <mike_mp@zzzcomputing.com>
Fixes: #5200
Change-Id: I2c4d49da9ff80ccc228c21e196ec9a961de53478

5 years agoMerge "Test instance for matching class hierarchy on get_from_identity"
mike bayer [Sun, 22 Mar 2020 16:47:04 +0000 (16:47 +0000)] 
Merge "Test instance for matching class hierarchy on get_from_identity"

5 years agoTest instance for matching class hierarchy on get_from_identity
Mike Bayer [Sat, 21 Mar 2020 21:26:24 +0000 (17:26 -0400)] 
Test instance for matching class hierarchy on get_from_identity

Fixed issue where a lazyload that uses session-local "get" against a target
many-to-one relationship where an object with the correct primary key is
present, however it's an instance of a sibling class, does not correctly
return None as is the case when the lazy loader actually emits a load for
that row.

Fixes: #5210
Change-Id: I89f9946cfeba61d89a272435f76a5a082b1da30c

5 years agoMerge "Deprecate plain string in execute and introduce `exec_driver_sql`"
mike bayer [Sun, 22 Mar 2020 15:04:59 +0000 (15:04 +0000)] 
Merge "Deprecate plain string in execute and introduce `exec_driver_sql`"

5 years agoDeprecate plain string in execute and introduce `exec_driver_sql`
Federico Caselli [Sat, 14 Mar 2020 13:02:44 +0000 (14:02 +0100)] 
Deprecate plain string in execute and introduce `exec_driver_sql`

Execution of literal sql string is deprecated in the
:meth:`.Connection.execute` and a warning is raised when used stating
that it will be coerced to :func:`.text` in a future release.
To execute a raw sql string the new connection method
:meth:`.Connection.exec_driver_sql` was added, that will retain the previous
behavior, passing the string to the DBAPI driver unchanged.
Usage of scalar or tuple positional parameters in :meth:`.Connection.execute`
is also deprecated.

Fixes: #4848
Fixes: #5178
Change-Id: I2830181054327996d594f7f0d59c157d477c3aa9

5 years agoRemove pyproject.toml from distribution
Mike Bayer [Sat, 21 Mar 2020 14:16:47 +0000 (10:16 -0400)] 
Remove pyproject.toml from distribution

SQLAlchemy does not want to opt-in to pep-517 at this time
as this would require a custom build backend interface
which we have not built yet, and the standard is not
widely adopted at this time in any case.  Per
[1] [2], the presence of this file indicates a positive opt-in
to pep-517, so it must be omitted from source distributions.

[1] https://pip.pypa.io/en/stable/reference/pip/#pep-517-and-518-support
[2] https://www.python.org/dev/peps/pep-0517/#id5

Fixes: #5207
Change-Id: If8d26a9edf942047920d273d8be778df7a018b3e

5 years agoClarify Alembic vs. Migrate
Mike Bayer [Fri, 20 Mar 2020 20:40:47 +0000 (16:40 -0400)] 
Clarify Alembic vs. Migrate

Migrate is fully legacy at this point so continue to mention
it to provide clarity, but ensure it isn't suggested
as a real alternative.  It's unclear if Migrate will be able
to support SQLAlchemy 2.0.

Change-Id: Ia81aaccbd18f197ab533b083e87cc4d04ea05839

5 years agoEmphasize context managers when working with Core
Mike Bayer [Fri, 20 Mar 2020 19:21:10 +0000 (15:21 -0400)] 
Emphasize context managers when working with Core

Prep the main documentation for the changes coming up in 1.4
by first removing references to engine.execute() outside
of the "connectionless" section, and using context managers
in all cases.  For features that have always been confusing
and are going away, add a note that this feature will
be going away.

Change-Id: I94583444734e36f5432c32cb37f88a9fad15634a

5 years agoCorrect misleading guidance on multiprocessing
Mike Bayer [Fri, 20 Mar 2020 15:17:47 +0000 (11:17 -0400)] 
Correct misleading guidance on multiprocessing

Link the connections intro to the dedicated section
on multiprocessing rather than stating that a separate
engine per process is needed, since this is inaccurate
and vague.

Change-Id: I48c66f88a90db918e864cd198c6aed335e28c7e6

5 years agoDon't include PG INCLUDE columns as regular index columns
mike bayer [Wed, 18 Mar 2020 23:05:20 +0000 (19:05 -0400)] 
Don't include PG INCLUDE columns as regular index columns

Fixed issue where a "covering" index, e.g. those which have an  INCLUDE
clause, would be reflected including all the columns in INCLUDE clause as
regular columns.  A warning is now emitted if these additional columns are
detected indicating that they are currently ignored.  Note that full
support for "covering" indexes is part of :ticket:`4458`.  Pull request
courtesy Marat Sharafutdinov.

Fixes: #5205
Closes: #5206
Pull-request: https://github.com/sqlalchemy/sqlalchemy/pull/5206
Pull-request-sha: 512a3817bb21991142add2d192fa7ce9b285369d

Change-Id: I3196a2bf77dc5a6abd85b2fbf0ebff1b30d4fb00

5 years agoMerge "updated doc string to show `NOT (EXISTS` instead of `NOT EXISTS`, as …"
mike bayer [Wed, 18 Mar 2020 17:01:25 +0000 (17:01 +0000)] 
Merge "updated doc string to show `NOT (EXISTS` instead of `NOT EXISTS`, as …"

5 years agoMerge "import the module as passed before we look in sys.modules"
mike bayer [Tue, 17 Mar 2020 18:08:30 +0000 (18:08 +0000)] 
Merge "import the module as passed before we look in sys.modules"

5 years agoimport the module as passed before we look in sys.modules
Mike Bayer [Fri, 13 Mar 2020 22:37:25 +0000 (18:37 -0400)] 
import the module as passed before we look in sys.modules

in I2e291eba4297867fc0ddb5d875b9f7af34751d01, the importer
is importing tokens[0:-1] and then the final token as the name;
this doesn't always work for the two example modules of "xml.dom"
and "wsgiref.simple_server".  import the complete path we will
pull from sys.modules directly.

Change-Id: I833a770f4c3e7463fa56234d891870083e48cc73

5 years agoFix "special_key" attribute name in association proxy documentation
Mike Bayer [Tue, 17 Mar 2020 02:06:15 +0000 (22:06 -0400)] 
Fix "special_key" attribute name in association proxy documentation

Fixes: #5204
Change-Id: I1366be823d753bdcd92c98b948bdfa7960a27eb7

5 years agoSupport inspection of computed column
Federico Caselli [Sat, 14 Mar 2020 12:57:42 +0000 (13:57 +0100)] 
Support inspection of computed column

Added support for reflection of "computed" columns, which are now returned
as part of the structure returned by :meth:`.Inspector.get_columns`.
When reflecting full :class:`.Table` objects, computed columns will
be represented using the :class:`.Computed` construct.

Also improve the documentation in :meth:`Inspector.get_columns`, correctly
listing all the returned keys.

Fixes: #5063
Fixes: #4051
Closes: #5064
Pull-request: https://github.com/sqlalchemy/sqlalchemy/pull/5064
Pull-request-sha: ba00fc321ce468f8885aad23b3dd33c789e50fbe

Change-Id: I789986554fc8ac7f084270474d0b2c12046b1cc2

5 years agoupdated doc string to show `NOT (EXISTS` instead of `NOT EXISTS`, as …
jonathan vanasco [Sat, 14 Mar 2020 12:27:43 +0000 (08:27 -0400)] 
updated doc string to show `NOT (EXISTS` instead of `NOT EXISTS`, as …

…that is what SqlAlchemy now renders.

SqlAlchemy currently renders `NOT (EXISTS` not `NOT EXISTS`. This fixes the example SQL.

### Description
The change is a docstring only.

### Checklist

This pull request is:

- [x] 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.
- [ ] 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: #4593
Pull-request: https://github.com/sqlalchemy/sqlalchemy/pull/4593
Pull-request-sha: fef577313242a1f79feb18969118a8fbb93bb6e9

Change-Id: Iee826a1754d76c93c014b44374e0f9aeabb8d0b6

5 years agoMerge "Fix IntegerTest for sqlalchemy-firebird"
mike bayer [Fri, 13 Mar 2020 21:11:59 +0000 (21:11 +0000)] 
Merge "Fix IntegerTest for sqlalchemy-firebird"

5 years agoFix tests failing for SQLite file databases; repair provisioning
Gord Thompson [Wed, 26 Feb 2020 19:50:01 +0000 (12:50 -0700)] 
Fix tests failing for SQLite file databases; repair provisioning

1. ensure provision.py loads dialect implementations when running
reap_dbs.py.   Reapers haven't been working since
598f2f7e557073f29563d4d567f43931fc03013f .

2. add some exclusion rules to allow the sqlite_file target to work;
add to tox.

3. add reap dbs target for SQLite, repair SQLite drop_db routine
which also wasn't doing the right thing for memory databases
etc.

4. Fix logging in provision files, as the main provision logger
is the one that's enabled by reap_dbs and maybe others, have all
the provision files use the provision logger.

Fixes: #5180
Fixes: #5168
Change-Id: Ibc1b0106394d20f5bcf847f37b09d185f26ac9b5

5 years agoDisable sqlite_file tests by default, take two
Mike Bayer [Fri, 13 Mar 2020 16:14:12 +0000 (12:14 -0400)] 
Disable sqlite_file tests by default, take two

We need no tests to run for sqlite_file until we merge
a full fix for it.   We'd like Jenkins to include this target.

Change-Id: I2737fa462572f08e2925b232a8f24d1ecd26b3ac

5 years agoInclude schema in all_tab_comments query
Mike Bayer [Fri, 13 Mar 2020 03:11:18 +0000 (23:11 -0400)] 
Include schema in all_tab_comments query

Fixed regression / incorrect fix caused by fix for :ticket:`5146` where the
Oracle dialect reads from the "all_tab_comments" view to get table comments
but fails to accommodate for the current owner of the table being
requested, causing it to read the wrong comment if multiple tables of the
same name exist in multiple schemas.

Fixes: #5146
Change-Id: Id79fbaa81b0e36cd4af60c48e4ab35c593ace057

5 years agoDont raise on pytest deprecation warnings
Mike Bayer [Thu, 12 Mar 2020 23:44:37 +0000 (19:44 -0400)] 
Dont raise on pytest deprecation warnings

py.test 5.4.0 emits deprecation warnings for pytest.Class.
make sure we don't raise for these, and log the code that will
be used for 5.4.0 when we bump requirements.

Fixes: #5201
Change-Id: I83e0402c4a6b2365a63b58d052c6989df3a37328

5 years agoAdd placeholder for sqlite file database
Mike Bayer [Thu, 12 Mar 2020 23:12:09 +0000 (19:12 -0400)] 
Add placeholder for sqlite file database

So that we can enable this in jenkins until
 Ibc1b0106394d20f5bcf847f37b09d185f26ac9b5 is merged.

Change-Id: Ia704e75bf3767e02d448a6af02530dfc89c9920b

5 years agoRemove trailing slashes in pre-commit config
Mike Bayer [Thu, 12 Mar 2020 00:47:25 +0000 (20:47 -0400)] 
Remove trailing slashes in pre-commit config

See https://github.com/sqlalchemy/dogpile.cache/pull/176

Change-Id: Id9a75546d4d0eae93ad837a77c6ffa9249efff5c

5 years agoMerge "Fix link in docs of query_expression and with_expression"
mike bayer [Wed, 11 Mar 2020 18:39:09 +0000 (18:39 +0000)] 
Merge "Fix link in docs of query_expression and with_expression"

5 years agoFix link in docs of query_expression and with_expression
Federico Caselli [Wed, 11 Mar 2020 18:09:41 +0000 (19:09 +0100)] 
Fix link in docs of query_expression and with_expression

Ref #5198

Change-Id: I566c2f7bbe08e9017e09e133079bef1c38469595

5 years agoMerge "Add missing changelog"
mike bayer [Wed, 11 Mar 2020 18:09:08 +0000 (18:09 +0000)] 
Merge "Add missing changelog"

5 years agoMerge "Rework select(), CompoundSelect() in terms of CompileState"
mike bayer [Wed, 11 Mar 2020 18:08:03 +0000 (18:08 +0000)] 
Merge "Rework select(), CompoundSelect() in terms of CompileState"

5 years agoAdd missing changelog
Federico Caselli [Wed, 11 Mar 2020 12:49:57 +0000 (13:49 +0100)] 
Add missing changelog

Add a changelog plus migration notes for the behavior
that's been improved by #4656, #4689

Original patch I2e291eba4297867fc0ddb5d875b9f7af34751d01

Change-Id: Ie956f55ba79b2a4f7a0c972a47c767de2ffd0081

5 years agocherry-pick changelog update for 1.3.16
Mike Bayer [Wed, 11 Mar 2020 16:36:59 +0000 (12:36 -0400)] 
cherry-pick changelog update for 1.3.16

5 years agocherry-pick changelog from 1.3.15
Mike Bayer [Wed, 11 Mar 2020 16:36:59 +0000 (12:36 -0400)] 
cherry-pick changelog from 1.3.15

5 years agoRepair broken call to sys.exc_info()
Mike Bayer [Wed, 11 Mar 2020 14:41:12 +0000 (10:41 -0400)] 
Repair broken call to sys.exc_info()

Fixed regression in 1.3.14 due to :ticket:`4849` where a sys.exc_info()
call failed to be invoked correctly when a flush error would occur. Test
coverage has been added for this exception case.

Fixes: #5196
Change-Id: Ib59a58a3a9d4c9c6f4b751201b794816a9f70225

5 years agoReword implicit left join error; ensure deterministic FROM for columns
Mike Bayer [Tue, 10 Mar 2020 22:48:42 +0000 (18:48 -0400)] 
Reword implicit left join error; ensure deterministic FROM for columns

Adjusted the error message emitted by :meth:`.Query.join` when a left hand
side can't be located that the :meth:`.Query.select_from` method is the
best way to resolve the issue.  Also, within the 1.3 series, used a
deterministic ordering when determining the FROM clause from a given column
entity passed to :class:`.Query` so that the same expression is determined
each time.

Fixes: #5194
Change-Id: I2e4065fd31e98c57edf2f11d5e831be44d2c1ea2

5 years agoMerge "Also run black --check in the tox pep8 env"
mike bayer [Tue, 10 Mar 2020 21:27:15 +0000 (21:27 +0000)] 
Merge "Also run black --check in the tox pep8 env"

5 years agoMerge "Simplified module pre-loading strategy and made it linter friendly"
mike bayer [Tue, 10 Mar 2020 21:26:37 +0000 (21:26 +0000)] 
Merge "Simplified module pre-loading strategy and made it linter friendly"

5 years agoRework select(), CompoundSelect() in terms of CompileState
Mike Bayer [Fri, 6 Mar 2020 21:04:46 +0000 (16:04 -0500)] 
Rework select(), CompoundSelect() in terms of CompileState

Continuation of I408e0b8be91fddd77cf279da97f55020871f75a9

- add an options() method to the base Generative construct.
this will be where ORM options can go
- Change Null, False_, True_ to be singletons, so that
we aren't instantiating them and having to use isinstance.
The previous issue with this was that they would produce dupe
labels in SELECT statements.   Apply the duplicate column
logic, newly added in 1.4, to these objects as well as to
non-apply-labels SELECT statements in general as a means of
improving this.
- create a revised system for generating ClauseList compilation
constructs that simplfies up front creation to not actually
use ClauseList; a simple tuple is rendered by the compiler
using the same constrcution rules as what are used for
ClauseList but without creating the actual object.  Apply
to Select, CompoundSelect, revise Update, Delete
- Select, CompoundSelect get an initial CompileState
implementation.  All methods used only within compilation
are moved here
- refine update/insert/delete compile state to not require
an outside boolean
- refine and simplify Select._copy_internals
- rework bind(), which is going away, to not use some
of the internal traversal stuff
- remove "autocommit", "for_update" parameters from Select,
  references #4643
- remove "autocommit" parameter from TextClause ,
  references #4643
- add deprecation warnings for statement.execute(),
engine.execute(), statement.scalar(), engine.scalar().
Fixes: #5193
Change-Id: I04ca0152b046fd42c5054ba10f37e43fc6e5a57b

5 years agoAlso run black --check in the tox pep8 env
Federico Caselli [Tue, 10 Mar 2020 18:49:39 +0000 (19:49 +0100)] 
Also run black --check in the tox pep8 env

Change-Id: I3b86bb3b4263048646676972bb2a870c7e2a7393

5 years agoDeprecate :func:`.eagerload` and :func:`.relation`
Federico Caselli [Tue, 10 Mar 2020 18:33:51 +0000 (19:33 +0100)] 
Deprecate :func:`.eagerload` and :func:`.relation`

The :func:`.eagerload` and :func:`.relation` were old
aliases and are now deprecated. Use :func:`.joinedload`
and :func:`.relationship` respectively.

Fixes: #5192
Change-Id: Ie13186e117e93e04a9c19d42fed4ef1af629b465

5 years agocherry-pick changelog update for 1.3.15
Mike Bayer [Tue, 10 Mar 2020 15:57:24 +0000 (11:57 -0400)] 
cherry-pick changelog update for 1.3.15

5 years agocherry-pick changelog from 1.3.14
Mike Bayer [Tue, 10 Mar 2020 15:57:23 +0000 (11:57 -0400)] 
cherry-pick changelog from 1.3.14

5 years agoReflect comments from any table accessible by the current user
Gord Thompson [Mon, 9 Mar 2020 21:50:53 +0000 (17:50 -0400)] 
Reflect comments from any table accessible by the current user

Fixed a reflection bug where table comments could only be retrieved for
tables actually owned by the user but not for tables visible to the user
but owned by someone else.  Pull request courtesy Dave Hirschfeld.

Fixes: #5146
Closes: #5147
Pull-request: https://github.com/sqlalchemy/sqlalchemy/pull/5147
Pull-request-sha: 0651e3bed05923765203b37986a2506dac3e634e

Change-Id: If970fda10d6adf04d926d38df1a567df1de9f7b9

5 years agoMerge remote-tracking branch 'origin/pr/5058'
Mike Bayer [Mon, 9 Mar 2020 15:09:29 +0000 (11:09 -0400)] 
Merge remote-tracking branch 'origin/pr/5058'

Change-Id: I83c998ef76adf2853a5d626b78dc76e433a5a8c5

5 years agoSimplified module pre-loading strategy and made it linter friendly
Federico Caselli [Sat, 7 Mar 2020 18:17:07 +0000 (19:17 +0100)] 
Simplified module pre-loading strategy and made it linter friendly

Introduced a modules registry to register modules that should be lazily loaded
in the package init. This ensures that they are in the system module cache,
avoiding potential thread safety issues as when importing them directly
in the function that uses them. The module registry is used to obtain
these modules directly, ensuring that the all the lazily loaded modules
are resolved at the proper time

This replaces dependency_for decorator and the dependencies decorator logic,
removing the need to pass the resolved modules as arguments of the
decodated functions and removes possible errors caused by linters.

Fixes: #4689
Fixes: #4656
Change-Id: I2e291eba4297867fc0ddb5d875b9f7af34751d01

5 years agoClean up list of external dialects
Gord Thompson [Fri, 6 Mar 2020 23:49:22 +0000 (16:49 -0700)] 
Clean up list of external dialects

Fixes: #5190
Change-Id: I3636eeda08bfaa882477397a4cd8064820d25356

5 years agoDecouple compiler state from DML objects; make cacheable
Mike Bayer [Sun, 23 Feb 2020 18:37:18 +0000 (13:37 -0500)] 
Decouple compiler state from DML objects; make cacheable

Targeting select / insert / update / delete, the goal
is to minimize overhead of construction and generative methods
so that only the raw arguments passed are handled.   An interim
stage that converts the raw state into more compiler-ready state
is added, which is analogous to the ORM QueryContext which will
also be rolled in to be a similar concept, as is currently
being prototyped in I19e05b3424b07114cce6c439b05198ac47f7ac10.
the ORM update/delete BulkUD concept is also going to be rolled
onto this idea.   So while the compiler-ready state object,
here called DMLState, looks a little thin, it's the
base of a bigger pattern that will allow for ORM functionality
to embed itself directly into the compiler, execution
context, and result set objects.

This change targets the DML objects, primarily focused on the
values() method which is the most complex process.   The
work done by values() is minimized as much as possible
while still being able to create a cache key.   Additional
computation is then offloaded to a new object ValuesState
that is handled by the compiler.

Architecturally, a big change here is that insert.values()
and update.values() will generate BindParameter objects for
the values now, which are then carefully received by crud.py
so that they generate the expected names.   This is so that
the values() portion of these constructs is cacheable.
for the "multi-values" version of Insert, this is all skipped
and the plan right now is that a multi-values insert is
not worth caching (can always be revisited).

Using the
coercions system in values() also gets us nicer validation
for free, we can remove the NotAClauseElement thing from
schema, and we also now require scalar_subquery() is called
for an insert/update that uses a SELECT as a column value,
1.x deprecation path is added.

The traversal system is then applied to the DML objects
including tests so that they have traversal, cloning, and
cache key support.  cloning is not a use case for DML however
having it present allows better validation of the structure
within the tests.

Special per-dialect DML is explicitly not cacheable at the moment,
more as a proof of concept that third party DML constructs can
exist as gracefully not-cacheable rather than producing an
incomplete cache key.

A few selected performance improvements have been added as well,
simplifying the immutabledict.union() method and adding
a new SQLCompiler function that can generate delimeter-separated
clauses like WHERE and ORDER BY without having to build
a ClauseList object at all.   The use of ClauseList will
be removed from Select in an upcoming commit.  Overall,
ClaustList is unnecessary for internal use and only adds
overhead to statement construction and will likely be removed
as much as possible except for explcit use of conjunctions like
and_() and or_().

Change-Id: I408e0b8be91fddd77cf279da97f55020871f75a9

5 years agoMerge "Render VALUES within composed MySQL on duplicate key expressions"
mike bayer [Thu, 5 Mar 2020 04:18:22 +0000 (04:18 +0000)] 
Merge "Render VALUES within composed MySQL on duplicate key expressions"

5 years agoMerge "Add docker commands to README.unittests"
mike bayer [Wed, 4 Mar 2020 22:50:04 +0000 (22:50 +0000)] 
Merge "Add docker commands to  README.unittests"

5 years agoRender VALUES within composed MySQL on duplicate key expressions
Mike Bayer [Wed, 4 Mar 2020 22:44:40 +0000 (17:44 -0500)] 
Render VALUES within composed MySQL on duplicate key expressions

Fixed issue in MySQL :meth:`.mysql.Insert.on_duplicate_key_update` construct
where using a SQL function or other composed expression for a column argument
would not properly render the ``VALUES`` keyword surrounding the column
itself.

Fixes: #5173
Change-Id: I16d39c2fdb8bbb7f3d1b2ffdd20e1bf69359ab75

5 years agoMerge "Don't import provision.py unconditionally"
mike bayer [Wed, 4 Mar 2020 21:06:57 +0000 (21:06 +0000)] 
Merge "Don't import provision.py unconditionally"

5 years agoAdd docker commands to README.unittests
Federico Caselli [Tue, 3 Mar 2020 22:34:09 +0000 (17:34 -0500)] 
Add docker commands to  README.unittests

Closes: #5116
Pull-request: https://github.com/sqlalchemy/sqlalchemy/pull/5116
Pull-request-sha: e70ad70426de03982c3abb78eb7b8292e86c3950

Change-Id: If9ef93312d8ce78908a76ea84cb95f3068ffb306

5 years agoMerge remote-tracking branch 'origin/pr/5186'
Mike Bayer [Wed, 4 Mar 2020 14:12:27 +0000 (09:12 -0500)] 
Merge remote-tracking branch 'origin/pr/5186'

Change-Id: I35921d46676e77ebdbe93f12406cdde3f6656704

5 years agofix typo in PickleType documentation 5186/head
Federico Caselli [Wed, 4 Mar 2020 12:48:30 +0000 (13:48 +0100)] 
fix typo in PickleType documentation

5 years agoMerge "Remove the deprecated loader options"
mike bayer [Wed, 4 Mar 2020 02:39:52 +0000 (02:39 +0000)] 
Merge "Remove the deprecated loader options"

5 years agoMerge "Restore crud flags if visiting_cte is set"
mike bayer [Wed, 4 Mar 2020 02:32:21 +0000 (02:32 +0000)] 
Merge "Restore crud flags if visiting_cte is set"

5 years agoRun handle_error for any exceptions raised in execute_context()
Mike Bayer [Wed, 4 Mar 2020 00:15:55 +0000 (19:15 -0500)] 
Run handle_error for any exceptions raised in execute_context()

Observing a SQLite connection/cursor being hung on
test_resultset -> PositionalTextTest -> test_dupe_col_obj.
this uses connectionless execution and the result object
fails to be constructed.  When that happens, there is no path
for the cursor or connection to be closed / released.
Recent changes with the exception assertions in #4849 seem to
be causing a cycle to last a little longer than usual which
is exposing this issue for one particular test on SQLite.

As we want to get rid of weakref cleanup, evaluate
why we dont have handle_dbapi_exception for this whole
block, as after_cursor_execute can raise, result construction
can raise, autocommit can raise, close can raise, there
does not seem to be a reason these things should be outside
of the block that gets cleaned up.

Fixes: #5182
Change-Id: I640ac55e8c5f39d287f779fbb5dc0ab727218ca3

5 years agoRestore crud flags if visiting_cte is set
Mike Bayer [Tue, 3 Mar 2020 22:22:30 +0000 (17:22 -0500)] 
Restore crud flags if visiting_cte is set

Fixed bug where a CTE of an INSERT/UPDATE/DELETE that also uses RETURNING
could then not be SELECTed from directly, as the internal state of the
compiler would try to treat the outer SELECT as a DELETE statement itself
and access nonexistent state.

Fixes: #5181
Change-Id: Icba76f2148c8344baa1c04bac4ab6c6d24f23072

5 years agoRemove the deprecated loader options
Federico Caselli [Tue, 3 Mar 2020 21:32:19 +0000 (22:32 +0100)] 
Remove the deprecated loader options

Remove the deprecated loader options ``joinedload_all``, ``subqueryload_all``,
``lazyload_all``, ``selectinload_all``. The normal version with method chaining
should be used in their place.

Fixes: #4642
Change-Id: I12eb4dfa7a86375911a570934ee662653d85d50a

5 years agoDon't import provision.py unconditionally
Mike Bayer [Tue, 3 Mar 2020 21:03:39 +0000 (16:03 -0500)] 
Don't import provision.py unconditionally

Removed the imports for provision.py from each dialect
and instead added a call in the central provision.py to
a new dialect level method load_provisioning().  The
provisioning registry works in the same way, so an existing
dialect that is using the provision.py system right now
by importing it as part of the package will still continue to
function.  However, to avoid pulling in the testing package when
the dialect is used in a non-testing context, the new hook may be
used.   Also removed a module-level dependency
of the testing framework on the orm package.

Revised an internal change to the test system added as a result of
:ticket:`5085` where a testing-related module per dialect would be loaded
unconditionally upon making use of that dialect, pulling in SQLAlchemy's
testing framework as well as the ORM into the module import space.   This
would only impact initial startup time and memory to a modest extent,
however it's best that these additional modules aren't reverse-dependent on
straight Core usage.

Fixes: #5180
Change-Id: I6355601da5f6f44d85a2bbc3acb5928559942b9c

5 years agoInclude column_property composition examples
Mike Bayer [Tue, 3 Mar 2020 13:58:35 +0000 (08:58 -0500)] 
Include column_property composition examples

Add cross-linking between column_property() and ColumnProperty

Add section to describe using .expression

remove inherited-members from ColumnProperty to greatly
decrease verbosity

Fixes: #5179
Change-Id: Ic477b16350dbf551100b31d14ff3ba8ba8221a43

5 years agoMerge "Ensure all nested exception throws have a cause"
mike bayer [Mon, 2 Mar 2020 23:45:35 +0000 (23:45 +0000)] 
Merge "Ensure all nested exception throws have a cause"

5 years agoEnsure all nested exception throws have a cause
Mike Bayer [Sat, 29 Feb 2020 19:40:45 +0000 (14:40 -0500)] 
Ensure all nested exception throws have a cause

Applied an explicit "cause" to most if not all internally raised exceptions
that are raised from within an internal exception catch, to avoid
misleading stacktraces that suggest an error within the handling of an
exception.  While it would be preferable to suppress the internally caught
exception in the way that the ``__suppress_context__`` attribute would,
there does not as yet seem to be a way to do this without suppressing an
enclosing user constructed context, so for now it exposes the internally
caught exception as the cause so that full information about the context
of the error is maintained.

Fixes: #4849
Change-Id: I55a86b29023675d9e5e49bc7edc5a2dc0bcd4751

5 years agoMerge "Remove obsolete util.compat.nested"
mike bayer [Mon, 2 Mar 2020 19:21:24 +0000 (19:21 +0000)] 
Merge "Remove obsolete util.compat.nested"

5 years agoRemove obsolete util.compat.nested
Gord Thompson [Sun, 1 Mar 2020 18:30:56 +0000 (11:30 -0700)] 
Remove obsolete util.compat.nested

Fixes: #5177
Change-Id: Ie02b0c065e3833f43e056ad9c31f414871d9e8ee

5 years agoMerge "Deprecate the databases packages"
mike bayer [Mon, 2 Mar 2020 16:35:47 +0000 (16:35 +0000)] 
Merge "Deprecate the databases packages"

5 years agoUpdate dialect API documentation
Mike Bayer [Mon, 2 Mar 2020 15:28:32 +0000 (10:28 -0500)] 
Update dialect API documentation

The docstrings for connect() and on_connect() were incorrect
between Dialect vs. DefaultDialect.   Redocumented related
methods, clean up formatting, and remove unicode-related
attribute descriptions from the top level Dialect document
as these don't apply to Python 3.

Change-Id: I45baab757f8e20627eba42c30b9e8dbe26356275

5 years agoMerge "Discontinue dynamic __visit_name__"
mike bayer [Mon, 2 Mar 2020 02:27:00 +0000 (02:27 +0000)] 
Merge "Discontinue dynamic __visit_name__"

5 years agoDiscontinue dynamic __visit_name__
Mike Bayer [Fri, 28 Feb 2020 19:56:25 +0000 (14:56 -0500)] 
Discontinue dynamic __visit_name__

Removed very antiquated logic that checks if __visit_name__
is a property.  There's no need for this as the compiler can handle
switching between implementations.  Convert _compile_dispatch()
to be fully inlined.

Change-Id: Ic0c7247c2d7dfed93a27f09250a8ed6352370764

5 years agoMerge "While parsing for check constraints, ignore newline characters in the check...
mike bayer [Sun, 1 Mar 2020 00:20:47 +0000 (00:20 +0000)] 
Merge "While parsing for check constraints, ignore newline characters in the check condition"

5 years agoWhile parsing for check constraints, ignore newline characters in the check condition
Eric Borczuk [Fri, 28 Feb 2020 16:05:13 +0000 (11:05 -0500)] 
While parsing for check constraints, ignore newline characters in the check condition

Fixed bug where PostgreSQL reflection of CHECK constraints would fail to
parse the constraint if the SQL text contained newline characters. The
regular expression has been adjusted to accommodate for this case. Pull
request courtesy Eric Borczuk.

Fixes: #5170
Closes: #5172
Pull-request: https://github.com/sqlalchemy/sqlalchemy/pull/5172
Pull-request-sha: 5701b7f09f723b727bbee95d19d107d6cc1d7717

Change-Id: If727e9140b645e8b685c3476fb0fa4417c1e6526

5 years agoMerge "Open up check for relationships that write to the same column"
mike bayer [Sat, 29 Feb 2020 22:18:58 +0000 (22:18 +0000)] 
Merge "Open up check for relationships that write to the same column"

5 years agoDeprecate the databases packages
Federico Caselli [Fri, 28 Feb 2020 18:26:03 +0000 (19:26 +0100)] 
Deprecate the databases packages

The databases package is an old alias to the dialect package, and its usage
is now deprecated

Change-Id: I5343a2d270ed5a8c654b9fe13dff40cdf54649ed

5 years agoMerge "Remove print statement in favor of print() function in docs and examples"
mike bayer [Fri, 28 Feb 2020 00:27:27 +0000 (00:27 +0000)] 
Merge "Remove print statement in favor of print() function in docs and examples"

5 years agoOpen up check for relationships that write to the same column
Mike Bayer [Wed, 26 Feb 2020 21:51:32 +0000 (16:51 -0500)] 
Open up check for relationships that write to the same column

Enhanced logic that tracks if relationships will be conflicting with each
other when they write to the same column to include simple cases of two
relationships that should have a "backref" between them.   This means that
if two relationships are not viewonly, are not linked with back_populates
and are not otherwise in an inheriting sibling/overriding arrangement, and
will populate the same foreign key column, a warning is emitted at mapper
configuration time warning that a conflict may arise.  A new parameter
:paramref:`.relationship.overlaps` is added to suit those very rare cases
where such an overlapping persistence arrangement may be unavoidable.

Fixes: #5171
Change-Id: Ifae5998fc1c7e49ce059aec8a67c80cabee768ad

5 years agoDon't call pre_ping for fresh connection
Mike Bayer [Tue, 5 Mar 2019 20:37:00 +0000 (15:37 -0500)] 
Don't call pre_ping for fresh connection

The pool "pre-ping" feature has been refined to not invoke for a DBAPI
connection that was just opened in the same checkout operation.  pre ping
only applies to a DBAPI connection that's been checked into the pool
and is being checked out again.

Fixes: #4524
Change-Id: Ibe3dfb709dbdc24aa94e96513cfbea456c33b895

5 years agoRemove print statement in favor of print() function in docs and examples
Albert Tugushev [Wed, 26 Feb 2020 16:09:29 +0000 (11:09 -0500)] 
Remove print statement in favor of print() function in docs and examples

<!-- Provide a general summary of your proposed changes in the Title field above -->

### Description
<!-- Describe your changes in detail -->
Remove print statements

### 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:

- [X] 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.
- [ ] 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: #5166
Pull-request: https://github.com/sqlalchemy/sqlalchemy/pull/5166
Pull-request-sha: 04a7394f71298322188f0861b4dfe93e5485839d

Change-Id: Ib90a59fac929661a18748c6e44966fb87e3978c6

5 years agoFix IntegerTest for sqlalchemy-firebird
Gord Thompson [Tue, 25 Feb 2020 16:46:48 +0000 (09:46 -0700)] 
Fix IntegerTest for sqlalchemy-firebird

Recent cleanup of test_types.py introduced a
regression for sqlalchemy-firebird (and possibly
other external dialects). With this change,
`test_huge_int` now passes for
sqlalchemy-firebird.

Change-Id: Ieeb4b33ec5985f2e2bf6832d1cdef294f85407a0

5 years agoMerge "Revise cx_Oracle, mysqlclient versions"
mike bayer [Mon, 24 Feb 2020 23:39:04 +0000 (23:39 +0000)] 
Merge "Revise cx_Oracle, mysqlclient versions"

5 years agoMerge "Clean up test_types.py in test suite"
mike bayer [Mon, 24 Feb 2020 23:38:24 +0000 (23:38 +0000)] 
Merge "Clean up test_types.py in test suite"

5 years agoRemove needless clauseelement check for batch
Mike Bayer [Mon, 24 Feb 2020 19:45:38 +0000 (14:45 -0500)] 
Remove needless clauseelement check for batch

Also document more detail as to why SQL expression support
is not turned on for batch.

Fixes: #5165
Change-Id: Ia93bbf75f22b8781400086c45b86a60ef9cec360

5 years agoDeprecate row.keys() for 2.0, not 1.x
Mike Bayer [Mon, 24 Feb 2020 18:54:37 +0000 (13:54 -0500)] 
Deprecate row.keys() for 2.0, not 1.x

row.keys() is used by any use case that applies dict() to
a row.  Access of elements by string key is also a 2.0 deprecation
not 1.4 so for rudimental dict(row) support make sure that is all
a 2.0 thing.

Fixes current Alembic test suite.

Change-Id: I895496324133d615676cd76bc5f2c5f4a83e9131

5 years agoMerge "Ensure schema-level table includes annotations in caching"
mike bayer [Mon, 24 Feb 2020 18:41:56 +0000 (18:41 +0000)] 
Merge "Ensure schema-level table includes annotations in caching"

5 years agoEnsure schema-level table includes annotations in caching
Mike Bayer [Mon, 24 Feb 2020 15:44:14 +0000 (10:44 -0500)] 
Ensure schema-level table includes annotations in caching

In 29330ec159 we ensured that annotations are part of cache keys.
However we failed to do so for the schema-level Table which
will definitely need to distinguish between ORM and non-ORM
annotated tables when caching, so ensure this is part of the
cache key.

Change-Id: I8d996873f2d7fa63230ef837db7e69a0101973b2

5 years agoClean up test_types.py in test suite
Gord Thompson [Sun, 23 Feb 2020 20:14:21 +0000 (13:14 -0700)] 
Clean up test_types.py in test suite

Convert connectionless execution calls to use
preferred methods

Change-Id: I64c49cb9b495007d43fc6c83e677a19cc2c6c9b9

5 years agoEnsure descendants of mixins don't become cacheable
Mike Bayer [Sat, 22 Feb 2020 18:11:20 +0000 (13:11 -0500)] 
Ensure descendants of mixins don't become cacheable

HasPrefix / HasSuffixes / SupportsCloneAnnotations exported
a _traverse_internals attribute that does not represent a
complete traversal, meaning non-traversible subclasses would
seem traversible.  rename these attributes so that this
does not occur.  DML is currently not traversible (will be soon).

Change-Id: I2605e61c8c3d49965335e66e09f4aeedc5e73bd3

5 years agoMerge "Repair inline flag"
mike bayer [Sat, 22 Feb 2020 17:57:17 +0000 (17:57 +0000)] 
Merge "Repair inline flag"

5 years agoRepair inline flag
Mike Bayer [Sat, 22 Feb 2020 15:22:18 +0000 (10:22 -0500)] 
Repair inline flag

In 9fca5d827d we attempted to deprecate the "inline=True" flag
and add a generative inline() method, however failed to include
any tests and the method was implemented incorrectly such that
it would get overwritten with the boolean flag immediately.

Rename the internal "inline" flag to "_inline" and add test
support both for the method as well as deprecated support
for the flag, including a fixture addition to assert the expected
value of the flag as it generally does not affect the
actual compiled SQL string.

Change-Id: I0450049f17f1f0d91e22d27f1a973a2b6c0e59f7

5 years agoMerge remote-tracking branch 'origin/pr/5141'
Mike Bayer [Sat, 22 Feb 2020 15:47:07 +0000 (10:47 -0500)] 
Merge remote-tracking branch 'origin/pr/5141'

Change-Id: If7e15115de22b0aa562a93f09d2287966914d96c

5 years agoUpdate test_unicode and move to test suite
Gord Thompson [Thu, 20 Feb 2020 22:38:09 +0000 (15:38 -0700)] 
Update test_unicode and move to test suite

External dialects will definitely want to
be able to test their handling of Unicode
table/column names.

Change-Id: If1b67cf170dc9e4a42e3f51760ced8ddb7a34fcf

5 years agoResult initial introduction
Mike Bayer [Tue, 4 Jun 2019 21:29:20 +0000 (17:29 -0400)] 
Result initial introduction

This builds on cc718cccc0bf8a01abdf4068c7ea4f3 which moved
RowProxy to Row, allowing Row to be more like a named tuple.

- KeyedTuple in ORM is replaced with Row

- ResultSetMetaData broken out into "simple" and "cursor" versions
  for ORM and Core, as well as LegacyCursor version.

- Row now has _mapping attribute that supplies full mapping behavior.
Row and SimpleRow both have named tuple behavior otherwise.
LegacyRow has some mapping features on the tuple which emit
deprecation warnings (e.g. keys(), values(), etc).   the biggest
change for mapping->tuple is the behavior of __contains__ which
moves from testing of "key in row" to "value in row".

- ResultProxy breaks into ResultProxy and FutureResult (interim),
the latter has the newer APIs.   Made available to dialects
using execution options.

- internal reflection methods and most tests move off of implicit
Row mapping behavior and move to row._mapping, result.mappings()
method using future result

- a new strategy system for cursor handling replaces the various
subclasses of RowProxy

- some execution context adjustments. We will leave EC in but
refined things like get_result_proxy() and out parameter handling.
Dialects for 1.4 will need to adjust from get_result_proxy()
to get_result_cursor_strategy(), if they are using this method

- out parameter handling now accommodated by get_out_parameter_values()
EC method.   Oracle changes for this.  external dialect for
DB2 for example will also need to adjust for this.

- deprecate case_insensitive flag for engine / result, this
feature is not used

mapping-methods on Row are deprecated, and replaced with
Row._mapping.<meth>, including:

   row.keys()  -> use row._mapping.keys()
   row.items()  -> use row._mapping.items()
   row.values() -> use row._mapping.values()
   key in row  -> use key in row._mapping
   int in row  -> use int < len(row)

Fixes: #4710
Fixes: #4878
Change-Id: Ieb9085e9bcff564359095b754da9ae0af55679f0

5 years agoDeprecate connection branching
Mike Bayer [Sun, 2 Feb 2020 18:24:40 +0000 (13:24 -0500)] 
Deprecate connection branching

The :meth:`.Connection.connect` method is deprecated as is the concept of
"connection branching", which copies a :class:`.Connection` into a new one
that has a no-op ".close()" method.  This pattern is oriented around the
"connectionless execution" concept which is also being removed in 2.0.

As part of this change we begin to move the internals away from
"connectionless execution" overall.   Remove the "connectionless
execution" concept from the reflection internals and replace with
explicit patterns at the Inspector level.

Fixes: #5131
Change-Id: Id23d28a9889212ac5ae7329b85136157815d3e6f

5 years agodoc updates to 2.0 migration document
Mike Bayer [Fri, 21 Feb 2020 18:41:35 +0000 (13:41 -0500)] 
doc updates to 2.0 migration document

use Result instead of InvocationContext which will place
itself in the execution sequence in mostly the same way
as ResultProxy does.

Change-Id: Ice9e231734b67d31af4fc9da8190b06a5404d970

5 years agoMerge "Remove unnecessary tuple; prepare for "iterator" verbiage"
mike bayer [Thu, 20 Feb 2020 20:31:49 +0000 (20:31 +0000)] 
Merge "Remove unnecessary tuple; prepare for "iterator" verbiage"

5 years agoRemove unnecessary tuple; prepare for "iterator" verbiage
Mike Bayer [Thu, 20 Feb 2020 14:01:36 +0000 (09:01 -0500)] 
Remove unnecessary tuple; prepare for "iterator" verbiage

Remove a tuple surrounding a generator expression that
is immediately iterated in any case.   Additionally
note that the bulk methods can likely accept non-list
objects such as arbitrary iterables, however without test
coverage this is not yet guaranteed; use the term "sequence"
for now.

Also added a warmup to a cache key profiling test to get
consistent results.

Fixes: #5163
Change-Id: If838fe214da574763115855c1a65171533c96e64

5 years agoModernize test_rowcount and move to dialect suite
Mike Bayer [Wed, 19 Feb 2020 22:59:52 +0000 (17:59 -0500)] 
Modernize test_rowcount and move to dialect suite

Amazingly there are no "rowcount" tests in suite, so these
tests should definitely be there.

Change-Id: Ib4c595fe6e16b457680ce4ee01180ccc8ddb6a40

5 years agoMerge "Replace engine.execute w/ context manager (step1)"
mike bayer [Wed, 19 Feb 2020 22:59:46 +0000 (22:59 +0000)] 
Merge "Replace engine.execute w/ context manager (step1)"

5 years agoRevise cx_Oracle, mysqlclient versions
Mike Bayer [Tue, 18 Feb 2020 16:09:43 +0000 (11:09 -0500)] 
Revise cx_Oracle, mysqlclient versions

cx_Oracle is dropping Python 2 in version 8.0
mysqlclient is dropping Python 2 in version 2.0

We are no longer testing cx_Oracle < 7 on CI so drop older
cx_Oracle versions from tox.

Change-Id: I18d8b47077d50ac02aedb6fdeb24f7c99b56aa7c

5 years agoMerge "Pass DDLCompiler IdentifierPreparer to visit_ENUM"
mike bayer [Mon, 17 Feb 2020 22:16:37 +0000 (22:16 +0000)] 
Merge "Pass DDLCompiler IdentifierPreparer to visit_ENUM"

5 years agoMerge "Create initial future package, RemovedIn20Warning"
mike bayer [Mon, 17 Feb 2020 21:09:22 +0000 (21:09 +0000)] 
Merge "Create initial future package, RemovedIn20Warning"