]> git.ipfire.org Git - thirdparty/sqlalchemy/sqlalchemy.git/log
thirdparty/sqlalchemy/sqlalchemy.git
8 years agoUse regexp to parse cx_oracle version string
Mike Bayer [Tue, 9 May 2017 16:17:04 +0000 (12:17 -0400)] 
Use regexp to parse cx_oracle version string

Fixed bug in cx_Oracle dialect where version string parsing would
fail for cx_Oracle version 6.0b1 due to the "b" character.  Version
string parsing is now via a regexp rather than a simple split.

Change-Id: I2af7172b0d7184e3ea3bd051e9fa8d6ca2a571cd
Fixes: #3975
8 years agoProtect against cls weakref becoming None
Mike Bayer [Mon, 8 May 2017 22:36:57 +0000 (18:36 -0400)] 
Protect against cls weakref becoming None

Protected against testing "None" as a class in the case where
declarative classes are being garbage collected and new
automap prepare() operations are taking place concurrently, very
infrequently hitting a weakref that has not been fully acted upon
after gc.

Change-Id: I32e1dfc5ac46bac4127fe808cfd18368e2fad9dd

8 years agoMerge branch 'master' of https://github.com/aflyhorse/sqlalchemy
Mike Bayer [Mon, 8 May 2017 21:55:28 +0000 (17:55 -0400)] 
Merge branch 'master' of https://github.com/aflyhorse/sqlalchemy

8 years ago- add 1.2 forwards-port version
Mike Bayer [Mon, 8 May 2017 21:54:15 +0000 (17:54 -0400)] 
- add 1.2 forwards-port version

Change-Id: I093f3939be8858a2f327c5ee5884b9629b216855

8 years agoMerge branch 'patch-1' of https://github.com/UnquietCode/sqlalchemy
Mike Bayer [Mon, 8 May 2017 20:21:20 +0000 (16:21 -0400)] 
Merge branch 'patch-1' of https://github.com/UnquietCode/sqlalchemy

8 years agoBreak the lines to fit pdf and fix another broken syntax
LunarShaddow [Mon, 8 May 2017 04:31:50 +0000 (12:31 +0800)] 
Break the lines to fit pdf and fix another broken syntax

8 years ago- big rewrite of the Sequence documentation:
Mike Bayer [Fri, 5 May 2017 18:59:39 +0000 (14:59 -0400)] 
- big rewrite of the Sequence documentation:

1. Sequence should be associated with MetaData always,
except in the really weird case someone is sharing a Sequence
among multiple metadatas.  Make this a "best practice", end the
confusion of #3951, #3979

2. "optional" is not a thing people use, trim this way down

3. remove confusing language

Change-Id: Iab5aec319da2582092fe2615ee50430f76441aff
(cherry picked from commit a1dcf23e371695d8d3be2e1d7875fad10f16a656)

8 years ago- add another note re: 339e2c13b0fc8e95a47d00c0f8fc5afc4b6dff9a
Mike Bayer [Fri, 5 May 2017 14:39:18 +0000 (10:39 -0400)] 
- add another note re: 339e2c13b0fc8e95a47d00c0f8fc5afc4b6dff9a
which clarifies that ForeignKey circumvents this logic as a
"convenience".   issue #3978 is updated to address trying to make
this consistent.

Change-Id: I089acaa89f11b7a6310c2bf32916e26eb62ab9c0

8 years ago- add a note to MetaData.schema indicating that the Table
Mike Bayer [Fri, 5 May 2017 13:19:18 +0000 (09:19 -0400)] 
- add a note to MetaData.schema indicating that the Table
will be cataloged in the .tables collection with its fully
qualified name.   Fixes #3978

Change-Id: I65fa063918efc22658e93c39a0680cb83553dec8

8 years agoremove ambiguous line breakers to help sphinx identify code block
LunarShaddow [Fri, 5 May 2017 06:38:41 +0000 (14:38 +0800)] 
remove ambiguous line breakers to help sphinx identify code block

8 years agofixes a typo
Ben Fagin [Mon, 1 May 2017 17:30:11 +0000 (10:30 -0700)] 
fixes a typo

8 years ago- typo
Mike Bayer [Fri, 28 Apr 2017 14:36:15 +0000 (10:36 -0400)] 
- typo

Change-Id: Iab741ce3739ed4172196f99c519c9333637383fd

8 years agoCall proxied collection before invoking creator in associationlist.append()
Mike Bayer [Thu, 27 Apr 2017 15:24:41 +0000 (11:24 -0400)] 
Call proxied collection before invoking creator in associationlist.append()

Improved the association proxy list collection so that premature
autoflush against a newly created association object can be prevented
in the case where ``list.append()`` is being used, and a lazy load
would be invoked when the association proxy accesses the endpoint
collection.  The endpoint collection is now accessed first before
the creator is invoked to produce the association object.

Change-Id: I008a6dbdfe5b1c0dfd02189c3d954d83a65f3fc5
Fixes: #3941
8 years ago- keep trying to identify the race here. can reproduce locally
Mike Bayer [Thu, 27 Apr 2017 21:44:29 +0000 (17:44 -0400)] 
- keep trying to identify the race here.  can reproduce locally
now and it seems like mock might not be doing the right thing.

Change-Id: I5c108d82631c9217da54a8ace68d7728c3e204d8

8 years agoEnforce boolean result type for all eq_, is_, isnot, comparison
Mike Bayer [Thu, 27 Apr 2017 14:26:10 +0000 (10:26 -0400)] 
Enforce boolean result type for all eq_, is_, isnot, comparison

Repaired issue where the type of an expression that used
:meth:`.ColumnOperators.is_` or similar would not be a "boolean" type,
instead the type would be "nulltype", as well as when using custom
comparison operators against an untyped expression.   This typing can
impact how the expression behaves in larger contexts as well as
in result-row-handling.

Change-Id: Ib810ff686de500d8db26ae35a51005fab29603b6
Fixes: #3873
8 years ago- try to work around a race that can occur in STP when
Mike Bayer [Thu, 27 Apr 2017 19:26:35 +0000 (15:26 -0400)] 
- try to work around a race that can occur in STP when
used in this intentionally broken scenario

Change-Id: I88ea6fa710da2189e6d47e2d12f5f0fd6f6bb7d4

8 years ago- ensure that sqlalchemy.ext is set up for importlater
Mike Bayer [Thu, 27 Apr 2017 18:33:54 +0000 (14:33 -0400)] 
- ensure that sqlalchemy.ext is set up for importlater

otherwise, it fails if you import from ext before orm:

    from sqlalchemy import *
    from sqlalchemy.ext.declarative import declarative_base
    from sqlalchemy.orm import *

and then do a lazyload, as the ext.baked importlater is not
initialized.

Change-Id: I24dcbfc9ca9022316da28507772562833e45dd95

8 years agoAdd selectin loading
Mike Bayer [Thu, 23 Mar 2017 21:55:43 +0000 (17:55 -0400)] 
Add selectin loading

Adding a new kind of relationship loader that is
a cross between the "immediateload" and the "subquery"
eager loader, using an IN criteria to load related items
in bulk immediately after the lead query result is loaded.

Change-Id: If13713fba9b465865aef8fd50b5b6b977fe3ef7d
Fixes: #3944
8 years agotest / document postgresql_ops against a labeled expression
Mike Bayer [Mon, 24 Apr 2017 20:19:08 +0000 (16:19 -0400)] 
test / document postgresql_ops against a labeled expression

Since postgresql_ops explicitly states that it expects
string keys, to apply to a function call or expression one
needs to give the SQL expression a label that can be referred
to by name in the dictionary.   test / document this.

Change-Id: I4bc4ade46dac27f9c1b92e7823433292beab97b9
Fixes: #3970
8 years ago- edits
Mike Bayer [Sat, 22 Apr 2017 20:43:31 +0000 (16:43 -0400)] 
- edits

Change-Id: If2445c4cbcd7eb18e06823e8821940a391890979

8 years agoMerge branch 'master' of ssh://gerrit.sqlalchemy.org:29418/zzzeek/sqlalchemy
Mike Bayer [Fri, 21 Apr 2017 22:24:10 +0000 (18:24 -0400)] 
Merge branch 'master' of ssh://gerrit.sqlalchemy.org:29418/zzzeek/sqlalchemy

8 years ago- update relationship loader docs, backport from
Mike Bayer [Fri, 21 Apr 2017 21:40:11 +0000 (17:40 -0400)] 
- update relationship loader docs, backport from
1.2 wip

Change-Id: I0a3c4a0166f6feed23a021723233d281fad597ec

8 years agoAdd _negate() to Label to negate inner element
Mike Bayer [Fri, 21 Apr 2017 17:35:38 +0000 (13:35 -0400)] 
Add _negate() to Label to negate inner element

Fixed the negation of a :class:`.Label` construct so that the
inner element is negated correctly, when the :func:`.not_` modifier
is applied to the labeled expression.

Change-Id: Ia99917b2959bdfbff28689c962b4203911c57b85
Fixes: #3969
8 years agoMerge branch 'UnmappedInstanceError_typo_fix' of https://github.com/suever/sqlalchemy
Mike Bayer [Mon, 17 Apr 2017 19:34:46 +0000 (15:34 -0400)] 
Merge branch 'UnmappedInstanceError_typo_fix' of https://github.com/suever/sqlalchemy

8 years ago- remove errant doctest comment
Mike Bayer [Mon, 17 Apr 2017 19:33:12 +0000 (15:33 -0400)] 
- remove errant doctest comment

Change-Id: Idb8520ff807074ceca36645728a63b79d1cdff6c

8 years agoAccommodate for query._current_path in subq eager load join_depth
Mike Bayer [Mon, 17 Apr 2017 16:02:18 +0000 (12:02 -0400)] 
Accommodate for query._current_path in subq eager load join_depth

Fixed bug in subquery eager loading where the "join_depth" parameter
for self-referential relationships would not be correctly honored,
loading all available levels deep rather than correctly counting
the specified number of levels for eager loading.

Change-Id: Ifa54085cbab3b41c2196f3ee519f485c63e4cb8d
Fixes: #3967
8 years agoMerge "Use baked lazyloading by default"
mike bayer [Fri, 14 Apr 2017 14:18:10 +0000 (10:18 -0400)] 
Merge "Use baked lazyloading by default"

8 years agoUse baked lazyloading by default
Mike Bayer [Fri, 7 Apr 2017 18:18:22 +0000 (14:18 -0400)] 
Use baked lazyloading by default

The ``lazy="select"`` loader strategy now makes used of the
:class:`.BakedQuery` query caching system in all cases.  This
removes most overhead of generating a :class:`.Query` object and
running it into a :func:`.select` and then string SQL statement from
the process of lazy-loading related collections and objects.  The
"baked" lazy loader has also been improved such that it can now
cache in most cases where query load options are used.

Change-Id: Ic96792fffaa045ae9aa0a4657d6d29235d3efb85
Fixes: #3954
8 years agoRemove MySQL UTC_TIMESTAMP rule
Mike Bayer [Thu, 13 Apr 2017 14:11:41 +0000 (10:11 -0400)] 
Remove MySQL UTC_TIMESTAMP rule

Removed an ancient and unnecessary intercept of the UTC_TIMESTAMP
MySQL function, which was getting in the way of using it with a
parameter.

Change-Id: I6e6b52c051418bcb9d31987e78299310810cb78d
Fixes: #3966
8 years ago- typos and formatting
Mike Bayer [Wed, 12 Apr 2017 20:28:55 +0000 (16:28 -0400)] 
- typos and formatting

Change-Id: I88a304e315b68eded31e91da04265da583bc417b

8 years ago- OK, take oracle out of memory-intensive, if it doesn't leak memory
Mike Bayer [Wed, 12 Apr 2017 20:18:11 +0000 (16:18 -0400)] 
- OK, take oracle out of memory-intensive, if it doesn't leak memory
then we get the TNS error from too many connections

Change-Id: Ie685173cd1490d99c5f37a1045e1312c4d9125ea

8 years ago- try one more test, then we're likely going to give up on cx_Oracle
Mike Bayer [Wed, 12 Apr 2017 19:28:05 +0000 (15:28 -0400)] 
- try one more test, then we're likely going to give up on cx_Oracle

Change-Id: I7f9a1265664b0368ee7a771d01c7ca1612156d1f

8 years ago- move a few memusage tests out of "backend". something is up w/ cx_Oracle
Mike Bayer [Wed, 12 Apr 2017 19:15:16 +0000 (15:15 -0400)] 
- move a few memusage tests out of "backend".  something is up w/ cx_Oracle
when the suite runs, such as a background thread or something like that,
which is affecting these tests a bit.

Change-Id: I52d50a44778ec1eecb8e335ae59b1a4773e80a79

8 years agoWarn on _compiled_cache growth
Mike Bayer [Wed, 12 Apr 2017 15:37:19 +0000 (11:37 -0400)] 
Warn on _compiled_cache growth

Added warnings to the LRU "compiled cache" used by the :class:`.Mapper`
(and ultimately will be for other ORM-based LRU caches) such that
when the cache starts hitting its size limits, the application will
emit a warning that this is a performance-degrading situation that
may require attention.   The LRU caches can reach their size limits
primarily if an application is making use of an unbounded number
of :class:`.Engine` objects, which is an antipattern.  Otherwise,
this may suggest an issue that should be brought to the SQLAlchemy
developer's attention.

Additionally, adjusted the test_memusage algorithm again as the
previous one could still allow a growing memory size to be missed.

Change-Id: I020d1ceafb7a08f6addfa990a1e7acd09f933240

8 years agoSet up base ARRAY to be compatible with postgresql.ARRAY.
Mike Bayer [Tue, 11 Apr 2017 14:26:38 +0000 (10:26 -0400)] 
Set up base ARRAY to be compatible with postgresql.ARRAY.

For some reason, when ARRAY was added to the base it was never linked
to postgresql.ARRAY.   Link the two types and also make base
ARRAY the schema event target so that it supports the same
features as postgresql.ARRAY.

Change-Id: I82fa6c9d2b8c5028dba3a009715f7bc296b2bc0b
Fixes: #3964
8 years agoMerge "Compare entities also on chop_path"
mike bayer [Mon, 10 Apr 2017 18:59:14 +0000 (14:59 -0400)] 
Merge "Compare entities also on chop_path"

8 years agoCompare entities also on chop_path
Mike Bayer [Mon, 10 Apr 2017 17:25:50 +0000 (13:25 -0400)] 
Compare entities also on chop_path

When comparing query._current_path to options, the path chop
was not taking into account that the query or the options are
against aliased classes that don't match the mapper.

The issue does not seem to take place for the Load() version
of _chop_path.

Fixed bug to improve upon the specificity of loader options that
take effect subsequent to the lazy load of a related entity, so
that the loader options will match to an aliased or non-aliased
entity more specifically if those options include entity information.

Fixes: #3963
Change-Id: Ifdff37d579042fcc62bdeabce9e2413e9a03fbba

8 years agoAdd new "expanding" feature to bindparam()
Mike Bayer [Mon, 3 Apr 2017 18:34:58 +0000 (14:34 -0400)] 
Add new "expanding" feature to bindparam()

Added a new kind of :func:`.bindparam` called "expanding".  This is
for use in ``IN`` expressions where the list of elements is rendered
into individual bound parameters at statement execution time, rather
than at statement compilation time.  This allows both a single bound
parameter name to be linked to an IN expression of multiple elements,
as well as allows query caching to be used with IN expressions.  The
new feature allows the related features of "select in" loading and
"polymorphic in" loading to make use of the baked query extension
to reduce call overhead.   This feature should be considered to be
**experimental** for 1.2.

Fixes: #3953
Change-Id: Ie708414a3ab9c0af29998a2c7f239ff7633b1f6e

8 years agoFix of minor typo in the UnmappedInstanceError message
Jonathan Suever [Thu, 6 Apr 2017 19:52:10 +0000 (15:52 -0400)] 
Fix of minor typo in the UnmappedInstanceError message

8 years agoConsider mysql partition options separately from other table options
Mike Bayer [Thu, 6 Apr 2017 00:59:42 +0000 (20:59 -0400)] 
Consider mysql partition options separately from other table options

Move down all the PARTITION, SUBPARTITION options
into a separate segment so that they come out at the
end of CREATE TABLE after the table options.

Change-Id: Iaa1c823848c93680ca22d72bda1b7c49742b9060
Fixes: #3961
8 years ago- add placeholder for 1.1.10
Mike Bayer [Thu, 6 Apr 2017 13:55:04 +0000 (09:55 -0400)] 
- add placeholder for 1.1.10

Change-Id: I068dd3b47dec200740db617891a64798db8f1734

8 years agoSupport Postgresql INTERVAL fields spec/reflection
Mike Bayer [Wed, 5 Apr 2017 16:55:39 +0000 (12:55 -0400)] 
Support Postgresql INTERVAL fields spec/reflection

Added support for all possible "fields" identifiers when reflecting the
Postgresql ``INTERVAL`` datatype, e.g. "YEAR", "MONTH", "DAY TO
MINUTE", etc..   In addition, the :class:`.postgresql.INTERVAL`
datatype itself now includes a new parameter
:paramref:`.postgresql.INTERVAL.fields` where these qualifiers can be
specified; the qualifier is also reflected back into the resulting
datatype upon reflection / inspection.

Change-Id: I33816e68c533b023e0632db6f4e73fefd2de4721
Fixes: #3959
8 years agoMerge "Double percent signs based on paramstyle, not dialect"
mike bayer [Wed, 5 Apr 2017 17:06:00 +0000 (13:06 -0400)] 
Merge "Double percent signs based on paramstyle, not dialect"

8 years agoDouble percent signs based on paramstyle, not dialect
Mike Bayer [Mon, 4 Jul 2016 19:54:29 +0000 (15:54 -0400)] 
Double percent signs based on paramstyle, not dialect

This patch moves the "doubling" of percent signs into
the base compiler and makes it completely a product
of whether or not the paramstyle is format/pyformat or
not.   Without this paramstyle, percent signs
are not doubled across text(), literal_column(), and
column().

Change-Id: Ie2f278ab1dbb94b5078f85c0096d74dbfa049197
Fixes: #3740
8 years agoMerge "Recognize brackets, quoted_name in SQL Server schema"
mike bayer [Tue, 4 Apr 2017 18:28:39 +0000 (14:28 -0400)] 
Merge "Recognize brackets, quoted_name in SQL Server schema"

8 years ago- 1.1.9 release date
Mike Bayer [Tue, 4 Apr 2017 18:11:05 +0000 (14:11 -0400)] 
- 1.1.9 release date

Change-Id: I8d1d55bde6424e4013c5b16bb27d6fc15fa225c2

8 years agoRecognize brackets, quoted_name in SQL Server schema
Mike Bayer [Mon, 3 Apr 2017 19:05:27 +0000 (15:05 -0400)] 
Recognize brackets, quoted_name in SQL Server schema

The SQL Server dialect now allows for a database and/or owner name
with a dot inside of it, using brackets explicitly in the string around
the owner and optionally the database name as well.  In addition,
sending the :class:`.quoted_name` construct for the schema name will
not split on the dot and will deliver the full string as the "owner".
:class:`.quoted_name` is also now available from the ``sqlalchemy.sql``
import space.

Change-Id: I77491d63ce47638bd23787d903ccde2f35a9d43d
Fixes: #2626
8 years agoAdd much more detail to the "unhashable types" change
Mike Bayer [Tue, 4 Apr 2017 17:09:55 +0000 (13:09 -0400)] 
Add much more detail to the "unhashable types" change

Change-Id: I34cbf54913b81ef2ae8b2e60f03feb78601460e5
Fixes: 3958
(cherry picked from commit 10a3004f2ca29921c844f58689a5f02ed5f10e03)

8 years agoMerge "Apply SQL compilation to sqltext for column-level CHECK constraint"
mike bayer [Tue, 4 Apr 2017 14:22:32 +0000 (10:22 -0400)] 
Merge "Apply SQL compilation to sqltext for column-level CHECK constraint"

8 years agoMerge "Ensure we check that SQL expression has an .info attribute"
mike bayer [Tue, 4 Apr 2017 14:08:49 +0000 (10:08 -0400)] 
Merge "Ensure we check that SQL expression has an .info attribute"

8 years agoApply SQL compilation to sqltext for column-level CHECK constraint
Mike Bayer [Tue, 4 Apr 2017 14:02:39 +0000 (10:02 -0400)] 
Apply SQL compilation to sqltext for column-level CHECK constraint

Fixed bug where a column-level :class:`.CheckConstraint` would fail
to compile the SQL expression using the underlying dialect compiler
as well as apply proper flags to generate literal values as
inline, in the case that the sqltext is a Core expression and
not just a plain string.   This was long-ago fixed for table-level
check constraints in 0.9 as part of :ticket:`2742`, which more commonly
feature Core SQL expressions as opposed to plain string expressions.

Change-Id: I1301ba4b40063e91bc47726aecc5f4990ffcaeda
Fixes: #3957
8 years agoFix typo.
Bertrand Janin [Tue, 4 Apr 2017 13:11:25 +0000 (09:11 -0400)] 
Fix typo.

8 years agoEnsure we check that SQL expression has an .info attribute
Mike Bayer [Tue, 4 Apr 2017 13:06:13 +0000 (09:06 -0400)] 
Ensure we check that SQL expression has an .info attribute

Fixed regression released in 1.1.8 due to :ticket:`3950` where the
deeper search for information about column types in the case of a
"schema type" or a :class:`.TypeDecorator` would produce an attribute
error if the mapping also contained a :obj:`.column_property`.

Change-Id: I38254834d3d79c9b339289a8163eb4789ec4c931
Fixes: #3956
8 years agoResultProxy won't autoclose connection until state flag is set
Mike Bayer [Mon, 3 Apr 2017 21:25:26 +0000 (17:25 -0400)] 
ResultProxy won't autoclose connection until state flag is set

Changed the mechanics of :class:`.ResultProxy` to unconditionally
delay the "autoclose" step until the :class:`.Connection` is done
with the object; in the case where Postgresql ON CONFLICT with
RETURNING returns no rows, autoclose was occurring in this previously
non-existent use case, causing the usual autocommit behavior that
occurs unconditionally upon INSERT/UPDATE/DELETE to fail.

Change-Id: I235a25daf4381b31f523331f810ea04450349722
Fixes: #3955
(cherry picked from commit 8ee363e4917b0dcd64a83b6d26e465c9e61e0ea5)
(cherry picked from commit f52fb5282a046d26b6ee2778e03b995eb117c2ee)

8 years ago- fix version identifier
Mike Bayer [Mon, 3 Apr 2017 21:31:18 +0000 (17:31 -0400)] 
- fix version identifier

Change-Id: I63abfb167f54ea2ea2f8bf4ba22ab38b60c5d59c

8 years agoMerge "Use consistent method signature for Alias.self_group()"
mike bayer [Mon, 3 Apr 2017 16:37:35 +0000 (12:37 -0400)] 
Merge "Use consistent method signature for Alias.self_group()"

8 years agoUse consistent method signature for Alias.self_group()
Mike Bayer [Thu, 16 Mar 2017 21:28:41 +0000 (17:28 -0400)] 
Use consistent method signature for Alias.self_group()

Fixed bug where the use of an :class:`.Alias` object in a column
context would raise an argument error when it tried to group itself
into a parenthesized expression.   Using :class:`.Alias` in this way
is not yet a fully supported API, however it applies to some end-user
recipes and may have a more prominent role in support of some
future Postgresql features.

Change-Id: I81717e30416e0350f08d1e022c3d84656e0a9735
Fixes: #3939
8 years agoReturn self when Variant.coerce_compared_value would return impl
Mike Bayer [Sat, 1 Apr 2017 15:36:16 +0000 (11:36 -0400)] 
Return self when Variant.coerce_compared_value would return impl

Fixed regression released in 1.1.5 due to :ticket:`3859` where
adjustments to the "right-hand-side" evaluation of an expression
based on :class:`.Variant` to honor the underlying type's
"right-hand-side" rules caused the :class:`.Variant` type
to be inappropriately lost, in those cases when we *do* want the
left-hand side type to be transferred directly to the right hand side
so that bind-level rules can be applied to the expression's argument.

Change-Id: Ia54dbbb19398549d654b74668753c4152599d900
Fixes: #3952
8 years ago- 1.1.9 placeholder
Mike Bayer [Sat, 1 Apr 2017 15:36:52 +0000 (11:36 -0400)] 
- 1.1.9 placeholder

Change-Id: Ic7897b5e05d7a20b280d4412d3bdf2ebc85905d4

8 years ago- 1.1.8 release date
Mike Bayer [Fri, 31 Mar 2017 18:31:13 +0000 (14:31 -0400)] 
- 1.1.8 release date

Change-Id: I6243e620e55ad862e8494d64cc754badce25097d

8 years agoTrack SchemaEventTarget types in as_mutable()
Mike Bayer [Thu, 30 Mar 2017 21:52:10 +0000 (17:52 -0400)] 
Track SchemaEventTarget types in as_mutable()

Fixed bug in :mod:`sqlalchemy.ext.mutable` where the
:meth:`.Mutable.as_mutable` method would not track a type that had
been copied using :meth:`.TypeEngine.copy`.  This became more of
a regression in 1.1 compared to 1.0 because the :class:`.TypeDecorator`
class is now a subclass of :class:`.SchemaEventTarget`, which among
other things indicates to the parent :class:`.Column` that the type
should be copied when the :class:`.Column` is.  These copies are
common when using declarative with mixins or abstract classes.

Change-Id: Ib04df862c58263185dbae686c548fea3e12c46f1
Fixes: #3950
8 years agoApply type processing to untyped preexec default clause
Mike Bayer [Mon, 27 Feb 2017 21:43:59 +0000 (16:43 -0500)] 
Apply type processing to untyped preexec default clause

Fixed bug where a SQL-oriented Python-side column default could fail to
be executed properly upon INSERT in the "pre-execute" codepath, if the
SQL itself were an untyped expression, such as plain text.  The "pre-
execute" codepath is fairly uncommon however can apply to non-integer
primary key columns with SQL defaults when RETURNING is not used.

Tests exist here to ensure typing is applied to
a typed expression for default, but in the case of
an untyped SQL value, we know the type from the column,
so apply this.

Change-Id: I5d8b391611c137b9f700115a50a2bf5b30abfe94
Fixes: #3923
8 years agoAdd bindparams support for baked Result count() method
Malaclypse The Younger [Thu, 30 Mar 2017 14:54:14 +0000 (10:54 -0400)] 
Add bindparams support for baked Result count() method

Added support for bound parameters, e.g. those normally set up
via :meth:`.Query.params`, to the :meth:`.baked.Result.count`
method.  Previously, support for parameters were omitted. Pull request
courtesy Pat Deegan.

Change-Id: I8c33548cf2a483699767e459731694c8cadebff6
Pull-request: https://github.com/zzzeek/sqlalchemy/pull/350

8 years agoDocs/faq/performance
Ihor Kalnytskyi [Thu, 30 Mar 2017 14:07:31 +0000 (10:07 -0400)] 
Docs/faq/performance

Some updates for FAQ/Performance documentation page:

* Fix typo in testing script.
* Populate testing script with one more way to achieve higher performance.

See commit messages for details.

Change-Id: Id6fbf328164b14b3b58ca9616b103a35e72f7b8f
Pull-request: https://github.com/zzzeek/sqlalchemy/pull/345

8 years agoSupport Postgresql development version numbers
Sean McCully [Wed, 29 Mar 2017 20:14:02 +0000 (16:14 -0400)] 
Support Postgresql development version numbers

Added support for parsing the Postgresql version string for
a development version like "PostgreSQL 10devel".  Pull request
courtesy Sean McCully.

Change-Id: I7bc18bc4d290349c23e9796367b7d694d0873096
Pull-request: https://github.com/zzzeek/sqlalchemy/pull/351

8 years ago- start changelog for 1.1.8
Mike Bayer [Wed, 29 Mar 2017 20:15:53 +0000 (16:15 -0400)] 
- start changelog for 1.1.8

Change-Id: I6c23f43ca76aeca469980fc8be228af20c2c700d

8 years ago- reorg migration notes a bit
Mike Bayer [Tue, 28 Mar 2017 13:26:56 +0000 (09:26 -0400)] 
- reorg migration notes a bit

Change-Id: Id2a727a2a13eb84ad104ab049ae37b9e708af6b5

8 years ago- update release date for 1.1.7
Mike Bayer [Mon, 27 Mar 2017 21:34:15 +0000 (17:34 -0400)] 
- update release date for 1.1.7

Change-Id: I6ce86e2e0c54135194c60d99b433b2f38c467dbd

8 years agoAllow aliased() to be passed to Query.select_entity_from().
Mike Bayer [Mon, 27 Mar 2017 17:48:40 +0000 (13:48 -0400)] 
Allow aliased() to be passed to Query.select_entity_from().

An :func:`.aliased()` construct can now be passed to the
:meth:`.Query.select_entity_from` method.   Entities will be pulled
from the selectable represented by the :func:`.aliased` construct.
This allows special options for :func:`.aliased` such as
:paramref:`.aliased.adapt_on_names` to be used in conjunction with
:meth:`.Query.select_entity_from`.

Additionally rewrote the docstring for :meth:`.Query.select_entity_from`,
including starting with explicit use of :func:`.aliased` as the
usual idiomatic pattern.  An example using text().columns() is added
as well as the use case from :ticket:`3933` using name matching.

Change-Id: If7e182965236993064a2a086e3b6d55a4f097ca8
Fixes: #3933
8 years agoMerge "Add safe_reraise() + warnings only to Connection._autorollback"
mike bayer [Mon, 27 Mar 2017 16:27:56 +0000 (12:27 -0400)] 
Merge "Add safe_reraise() + warnings only to Connection._autorollback"

8 years agoMerge branch 'patch-1' of https://github.com/tamentis/sqlalchemy
Mike Bayer [Mon, 27 Mar 2017 15:30:37 +0000 (11:30 -0400)] 
Merge branch 'patch-1' of https://github.com/tamentis/sqlalchemy

8 years agoAdd safe_reraise() + warnings only to Connection._autorollback
Mike Bayer [Mon, 27 Mar 2017 14:52:58 +0000 (10:52 -0400)] 
Add safe_reraise() + warnings only to Connection._autorollback

Added an exception handler that will warn for the "cause" exception on
Py2K when the "autorollback" feature of :class:`.Connection` itself
raises an exception. In Py3K, the two exceptions are naturally reported
by the interpreter as one occurring during the handling of the other.
This is continuing with the series of changes for rollback failure
handling that were last visited as part of :ticket:`2696` in 1.0.12.

Change-Id: I600ba455a14ebaea27c6189889181f97c632f179
Fixes: #3946
8 years agoPre-load alias.c within JoinedEagerLoader cached AliasedClass
Mike Bayer [Sun, 26 Mar 2017 02:17:17 +0000 (22:17 -0400)] 
Pre-load alias.c within JoinedEagerLoader cached AliasedClass

Fixed a race condition which could occur under threaded environments
as a result of the caching added via :ticket:`3915`.   An internal
collection of ``Column`` objects could be regenerated on an alias
object inappropriately, confusing a joined eager loader when it
attempts to render SQL and collect results and resulting in an
attribute error.   The collection is now generated up front before
the alias object is cached and shared among threads.

Change-Id: I97d5b205992d38af8d2b4307178a15c086ef9993
Fixes: #3947
8 years agoTreat collation names as identifiers
Mike Bayer [Thu, 23 Mar 2017 19:11:03 +0000 (15:11 -0400)] 
Treat collation names as identifiers

The expression used for COLLATE as rendered by the column-level
:func:`.expression.collate` and :meth:`.ColumnOperators.collate` is now
quoted as an identifier when the name is case sensitive, e.g. has
uppercase characters.  Note that this does not impact type-level
collation, which is already quoted.

Change-Id: I83d5d9cd1e66a4f20b96303bb84c5f360d5d6a1a
Fixes: #3785
8 years agoSupport hybrids/composites with bulk updates
Mike Bayer [Wed, 22 Mar 2017 16:56:23 +0000 (12:56 -0400)] 
Support hybrids/composites with bulk updates

The :meth:`.Query.update` method can now accommodate both
hybrid attributes as well as composite attributes as a source
of the key to be placed in the SET clause.   For hybrids, an
additional decorator :meth:`.hybrid_property.update_expression`
is supplied for which the user supplies a tuple-returning function.

Change-Id: I15e97b02381d553f30b3301308155e19128d2cfb
Fixes: #3229
8 years agoUse config.db global opts as defaults for all testing_engine()
Mike Bayer [Wed, 22 Mar 2017 14:13:15 +0000 (10:13 -0400)] 
Use config.db global opts as defaults for all testing_engine()

Some options need to be passed to engines in all cases,
such as currently the oracle 12516 workaround.   make sure
calls to testing_engine also set up the dictionary with
defaults even if options is passed.    not clear if this affects
other backends yet.

Change-Id: I5a1f7634e4ce5af6fe55dc21a24db6afacd19bb7

8 years agoRaise on flag_modified() for non-present attribute
Mike Bayer [Tue, 21 Mar 2017 21:11:18 +0000 (17:11 -0400)] 
Raise on flag_modified() for non-present attribute

The :func:`.attributes.flag_modified` function now raises
:class:`.InvalidRequestError` if the named attribute key is not
present within the object, as this is assumed to be present
in the flush process.  To mark an object "dirty" for a flush
without referring to any specific attribute, the
:func:`.attributes.flag_dirty` function may be used.

Change-Id: I6c64e4d253c239e38632f38c27bb16e68fe8dfbe
Fixes: #3753
8 years agoAllow reuse of hybrid_property across subclasses
Diana Clarke [Thu, 16 Mar 2017 20:05:18 +0000 (16:05 -0400)] 
Allow reuse of hybrid_property across subclasses

The :class:`sqlalchemy.ext.hybrid.hybrid_property` class now supports
calling mutators like ``@setter``, ``@expression`` etc. multiple times
across subclasses, and now provides a ``@getter`` mutator, so that
a particular hybrid can be repurposed across subclasses or other
classes.  This now matches the behavior of ``@property`` in standard
Python.

Co-authored-by: Mike Bayer <mike_mp@zzzcomputing.com>
Fixes: #3911
Fixes: #3912
Change-Id: Iff033d8ccaae20ded9289cbfa789c376759381f5

8 years agoIntegrate "pre-ping" into connection pool.
Mike Bayer [Fri, 24 Feb 2017 15:50:14 +0000 (10:50 -0500)] 
Integrate "pre-ping" into connection pool.

Added native "pessimistic disconnection" handling to the :class:`.Pool`
object.  The new parameter :paramref:`.Pool.pre_ping`, available from
the engine as :paramref:`.create_engine.pool_pre_ping`, applies an
efficient form of the "pre-ping" recipe featured in the pooling
documentation, which upon each connection check out, emits a simple
statement, typically "SELECT 1", to test the connection for liveness.
If the existing connection is no longer able to respond to commands,
the connection is transparently recycled, and all other connections
made prior to the current timestamp are invalidated.

Change-Id: I89700d0075e60abd2250e54b9bd14daf03c71c00
Fixes: #3919
8 years agoFix a title typo
Bertrand Janin [Sun, 19 Mar 2017 22:05:54 +0000 (18:05 -0400)] 
Fix a title typo

Utilites -> Utilities

8 years agoMerge branch 'master' of https://bitbucket.org/jalessio/sqlalchemy
Mike Bayer [Sat, 18 Mar 2017 18:57:41 +0000 (14:57 -0400)] 
Merge branch 'master' of https://bitbucket.org/jalessio/sqlalchemy

8 years agofix pep8 errors in association example
Paul Brown [Fri, 17 Mar 2017 05:24:15 +0000 (00:24 -0500)] 
fix pep8 errors in association example

(cherry picked from commit 6aad7fb4217ef294f68f693be5b3137c28184949)

8 years agofix pep8 errors in adjacency_list example
Paul Brown [Fri, 17 Mar 2017 05:23:49 +0000 (00:23 -0500)] 
fix pep8 errors in adjacency_list example

(cherry picked from commit ff230f1862892eb2b479ed85e6858a82159b435f)

8 years agoNew features from python 2.7
Катаев Денис [Fri, 17 Mar 2017 18:19:21 +0000 (14:19 -0400)] 
New features from python 2.7

After bump minimum supported version to 2.7 (1da9d3752160430c91534a8868ceb8c5ad1451d4), we can use new syntax.

Change-Id: Ib064c75a00562e641d132f9c57e5e69744200e05
Pull-request: https://github.com/zzzeek/sqlalchemy/pull/347

8 years agoMerge "Implement comments for tables, columns"
mike bayer [Fri, 17 Mar 2017 18:16:27 +0000 (14:16 -0400)] 
Merge "Implement comments for tables, columns"

8 years agoImplement comments for tables, columns
Frazer McLean [Sat, 11 Jun 2016 19:47:33 +0000 (21:47 +0200)] 
Implement comments for tables, columns

Added support for SQL comments on :class:`.Table` and :class:`.Column`
objects, via the new :paramref:`.Table.comment` and
:paramref:`.Column.comment` arguments.   The comments are included
as part of DDL on table creation, either inline or via an appropriate
ALTER statement, and are also reflected back within table reflection,
as well as via the :class:`.Inspector`.   Supported backends currently
include MySQL, Postgresql, and Oracle.

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

8 years agoAdd bulk_replace event, integrate with @validates
Mike Bayer [Wed, 25 Jan 2017 16:51:04 +0000 (11:51 -0500)] 
Add bulk_replace event, integrate with @validates

Added new attribute event :meth:`.AttributeEvents.bulk_replace`.
This event is triggered when a collection is assigned to a
relationship, before the incoming collection is compared with the
existing one.  This early event allows for conversion of incoming
non-ORM objects as well.  The event is integrated with the
``@validates`` decorator.

The ``@validates`` decorator now allows the decorated method to receive
objects from a "bulk collection set" operation that have not yet
been compared to the existing collection.  This allows incoming values
to be converted to compatible ORM objects as is already allowed
from an "append" event.   Note that this means that the
``@validates`` method is called for **all** values during a collection
assignment, rather than just the ones that are new.

Change-Id: I27f59db008d9e521d31a3e30143d7cd997e4b7b3
Fixes: #3896
8 years agoAnnotate parentmapper in primaryjoin / secondaryjoin
Mike Bayer [Mon, 16 Jan 2017 18:34:55 +0000 (13:34 -0500)] 
Annotate parentmapper in primaryjoin / secondaryjoin

This patch applies the "parentmapper" annotation to the columns
in the primaryjoin/secondaryjoin, but more dramatically,
also removes all the "deannotate" steps that were historically
applied to the relationship primaryjoin/secondaryjoin.
These deannotation steps were left over from the initial
implementations of annotations where the behaviors were not
as reliable.

By ensuring these annotations are present,
the evaluator no longer needs to do a name-based lookup
when it sees a column that has no "parentmapper",
because it can be assured this is not a mapped column.
This fixes the issue where the expression were based on
a relationship primaryjoin but the name of a column
in the join condition didn't match the attribute name.

Change-Id: I8c1d4594116d4109fef314a87c96a24d2efa0058
Fixes: #3366
8 years agoDon't mutate old collection on bulk replace
Mike Bayer [Tue, 14 Feb 2017 16:39:44 +0000 (11:39 -0500)] 
Don't mutate old collection on bulk replace

For a bulk replace, assume the old collection is no longer
useful to the attribute system and only send the removal events,
not actually mutated the collection.

this changes behavior significantly and also means that dispose_collection
now receives the old collection intact.

Change-Id: Ic2685c85438191f07797d9ef97833a2cfdc4fcc2
Fixes: #3913
8 years agoMerge "Consult _select_from_entity in _adjust_for_single_inheritance"
mike bayer [Wed, 15 Mar 2017 21:12:03 +0000 (17:12 -0400)] 
Merge "Consult _select_from_entity in _adjust_for_single_inheritance"

8 years agoConsult compiled paramstyle on execute_compiled
Mike Bayer [Wed, 15 Mar 2017 14:15:12 +0000 (10:15 -0400)] 
Consult compiled paramstyle on execute_compiled

Fixed bug where in the unusual case of passing a
:class:`.Compiled` object directly to :meth:`.Connection.execute`,
the dialect with which the :class:`.Compiled` object were generated
was not consulted for the paramstyle of the string statement, instead
assuming it would match the dialect-level paramstyle, causing
mismatches to occur.

Change-Id: I114e4db2183fbb75bb7c0b0641f5a161855696ee
Fixes: #3938
8 years agoFix typos ('expicit' -> 'explicit')
Jamie Alessio [Wed, 15 Mar 2017 02:02:38 +0000 (19:02 -0700)] 
Fix typos ('expicit' -> 'explicit')

8 years agoConsult _select_from_entity in _adjust_for_single_inheritance
Mike Bayer [Mon, 16 Jan 2017 18:06:44 +0000 (13:06 -0500)] 
Consult _select_from_entity in _adjust_for_single_inheritance

Fixed bug in single-table inheritance where the select_from()
argument would not be taken into account when limiting rows
to a subclass.  Previously, only expressions in the
columns requested would be taken into account.

Change-Id: Id353c45eade52b264d8f6685a58ba53975669eea
Fixes: #3891
8 years agoMerge "Add "empty in" strategies; default to "static""
mike bayer [Tue, 14 Mar 2017 23:39:37 +0000 (19:39 -0400)] 
Merge "Add "empty in" strategies; default to "static""

8 years agoMerge "Improve serializer behavior"
mike bayer [Tue, 14 Mar 2017 23:38:06 +0000 (19:38 -0400)] 
Merge "Improve serializer behavior"

8 years ago- add missing hyperlink for change 3934
Mike Bayer [Tue, 14 Mar 2017 21:14:02 +0000 (17:14 -0400)] 
- add missing hyperlink for change 3934

Change-Id: I4f6f1d24588f5f8aa8cf8f7f67627a08552d4c93

8 years agoAdd "empty in" strategies; default to "static"
Mike Bayer [Tue, 14 Mar 2017 16:00:56 +0000 (12:00 -0400)] 
Add "empty in" strategies; default to "static"

The longstanding behavior of the :meth:`.Operators.in_` and
:meth:`.Operators.not_in_` operators emitting a warning when
the right-hand condition is an empty sequence has been revised;
a new flag :paramref:`.create_engine.empty_in_strategy` allows an
empty "IN" expression to generate a simple boolean expression, or
to invoke the previous behavior of dis-equating the expression to
itself, with or without a warning.  The default behavior is now
to emit the simple boolean expression, allowing an empty IN to
be evaulated without any performance penalty.

Change-Id: I65cc37f2d7cf65a59bf217136c42fee446929352
Fixes: #3907
8 years agoImprove serializer behavior
Mike Bayer [Thu, 9 Mar 2017 16:36:19 +0000 (11:36 -0500)] 
Improve serializer behavior

Fix an issue where the Annotated system needs to have a
__reduce__ method, also see why we can't default to HIGHEST_PROTOCOL.
This latter part might not be a good idea until 1.2 for compatibility
reasons.

Change-Id: I0239e38259fc768c9e3b6c448c29161e271a969c
Fixes: #3918
8 years agoEmit after_rollback() event before snapshot removal
Mike Bayer [Sat, 11 Mar 2017 15:52:43 +0000 (10:52 -0500)] 
Emit after_rollback() event before snapshot removal

The state of the :class:`.Session` is now present when the
:meth:`.SessionEvents.after_rollback` event is emitted, that is,  the
attribute state of objects prior to their being expired.   This is now
consistent with the  behavior of the
:meth:`.SessionEvents.after_commit` event which  also emits before the
attribute state of objects is expired.

Change-Id: I9c572656ec5a9bfaeab817e9c95107c75aca1b51
Fixes: #3934
8 years agoEnable sane_multi_rowcount for cx_Oracle
Mike Bayer [Tue, 14 Mar 2017 17:38:12 +0000 (13:38 -0400)] 
Enable sane_multi_rowcount for cx_Oracle

Also add some tests to test_rowcount.

Change-Id: Idaa18fdc4fcfeb615725531c37de77decf76a783
Fixes: #3932