--- /dev/null
+.. change::
+ :tags: bug, orm
+ :tickets: 6591
+
+ Fixed issue in experimental "select ORM objects from INSERT/UPDATE" use
+ case where an error was raised if the statement were against a
+ single-table-inheritance subclass.
if isinstance(
self.statement, (expression.TextClause, expression.UpdateBase)
):
+
+ self.extra_criteria_entities = {}
+
# setup for all entities. Currently, this is not useful
# for eager loaders, as the eager loaders that work are able
# to do their work entirely in row_processor.
# i.e. when each _MappedEntity has its own FROM
if self.compile_options._enable_single_crit:
-
self._adjust_for_extra_criteria()
if not self.primary_columns:
self.supports_execution = getattr(
test_statement, "supports_execution", False
)
+
if self.supports_execution:
self._execution_options = test_statement._execution_options
- if isinstance(
- test_statement, (sql.Insert, sql.Update, sql.Delete)
- ):
+ if hasattr(test_statement, "_returning"):
self._returning = test_statement._returning
- if isinstance(test_statement, (sql.Insert, sql.Update)):
+ if hasattr(test_statement, "_inline"):
self._inline = test_statement._inline
+ if hasattr(test_statement, "_return_defaults"):
self._return_defaults = test_statement._return_defaults
def _default_dialect(self):
"WHERE employees_1.type IN ([POSTCOMPILE_type_1])",
)
+ def test_from_statement_select(self):
+ Engineer = self.classes.Engineer
+
+ stmt = select(Engineer)
+
+ q = select(Engineer).from_statement(stmt)
+
+ self.assert_compile(
+ q,
+ "SELECT employees.employee_id, employees.name, "
+ "employees.manager_data, employees.engineer_info, "
+ "employees.type FROM employees WHERE employees.type "
+ "IN ([POSTCOMPILE_type_1])",
+ )
+
+ def test_from_statement_update(self):
+ """test #6591"""
+
+ Engineer = self.classes.Engineer
+
+ from sqlalchemy import update
+
+ stmt = (
+ update(Engineer)
+ .values(engineer_info="bar")
+ .returning(Engineer.employee_id)
+ )
+
+ q = select(Engineer).from_statement(stmt)
+
+ self.assert_compile(
+ q,
+ "UPDATE employees SET engineer_info=:engineer_info "
+ "WHERE employees.type IN ([POSTCOMPILE_type_1]) "
+ "RETURNING employees.employee_id",
+ dialect="default_enhanced",
+ )
+
def test_union_modifiers(self):
Engineer, Manager = self.classes("Engineer", "Manager")