activerecord 6.0.6.1 → 6.1.7.3
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +1146 -788
- data/MIT-LICENSE +1 -1
- data/README.rdoc +2 -2
- data/lib/active_record/aggregations.rb +5 -5
- data/lib/active_record/association_relation.rb +30 -12
- data/lib/active_record/associations/alias_tracker.rb +19 -15
- data/lib/active_record/associations/association.rb +49 -26
- data/lib/active_record/associations/association_scope.rb +18 -20
- data/lib/active_record/associations/belongs_to_association.rb +23 -10
- data/lib/active_record/associations/belongs_to_polymorphic_association.rb +8 -3
- data/lib/active_record/associations/builder/association.rb +32 -5
- data/lib/active_record/associations/builder/belongs_to.rb +10 -7
- data/lib/active_record/associations/builder/collection_association.rb +5 -4
- data/lib/active_record/associations/builder/has_and_belongs_to_many.rb +0 -1
- data/lib/active_record/associations/builder/has_many.rb +6 -2
- data/lib/active_record/associations/builder/has_one.rb +11 -14
- data/lib/active_record/associations/builder/singular_association.rb +1 -1
- data/lib/active_record/associations/collection_association.rb +32 -18
- data/lib/active_record/associations/collection_proxy.rb +12 -5
- data/lib/active_record/associations/foreign_association.rb +13 -0
- data/lib/active_record/associations/has_many_association.rb +24 -2
- data/lib/active_record/associations/has_many_through_association.rb +10 -4
- data/lib/active_record/associations/has_one_association.rb +15 -1
- data/lib/active_record/associations/join_dependency/join_association.rb +37 -21
- data/lib/active_record/associations/join_dependency/join_part.rb +1 -1
- data/lib/active_record/associations/join_dependency.rb +63 -49
- data/lib/active_record/associations/preloader/association.rb +14 -8
- data/lib/active_record/associations/preloader/through_association.rb +1 -1
- data/lib/active_record/associations/preloader.rb +5 -3
- data/lib/active_record/associations/singular_association.rb +1 -1
- data/lib/active_record/associations.rb +118 -11
- data/lib/active_record/attribute_assignment.rb +10 -8
- data/lib/active_record/attribute_methods/before_type_cast.rb +13 -9
- data/lib/active_record/attribute_methods/dirty.rb +1 -11
- data/lib/active_record/attribute_methods/primary_key.rb +6 -2
- data/lib/active_record/attribute_methods/query.rb +3 -6
- data/lib/active_record/attribute_methods/read.rb +8 -11
- data/lib/active_record/attribute_methods/serialization.rb +11 -5
- data/lib/active_record/attribute_methods/time_zone_conversion.rb +12 -13
- data/lib/active_record/attribute_methods/write.rb +12 -20
- data/lib/active_record/attribute_methods.rb +64 -54
- data/lib/active_record/attributes.rb +33 -8
- data/lib/active_record/autosave_association.rb +47 -30
- data/lib/active_record/base.rb +2 -14
- data/lib/active_record/callbacks.rb +152 -22
- data/lib/active_record/coders/yaml_column.rb +1 -1
- data/lib/active_record/connection_adapters/abstract/connection_pool.rb +185 -134
- data/lib/active_record/connection_adapters/abstract/database_limits.rb +2 -44
- data/lib/active_record/connection_adapters/abstract/database_statements.rb +66 -23
- data/lib/active_record/connection_adapters/abstract/query_cache.rb +3 -8
- data/lib/active_record/connection_adapters/abstract/quoting.rb +34 -34
- data/lib/active_record/connection_adapters/abstract/savepoints.rb +3 -3
- data/lib/active_record/connection_adapters/abstract/schema_creation.rb +153 -116
- data/lib/active_record/connection_adapters/abstract/schema_definitions.rb +114 -26
- data/lib/active_record/connection_adapters/abstract/schema_dumper.rb +3 -3
- data/lib/active_record/connection_adapters/abstract/schema_statements.rb +228 -83
- data/lib/active_record/connection_adapters/abstract/transaction.rb +92 -33
- data/lib/active_record/connection_adapters/abstract_adapter.rb +52 -76
- data/lib/active_record/connection_adapters/abstract_mysql_adapter.rb +123 -87
- data/lib/active_record/connection_adapters/column.rb +15 -1
- data/lib/active_record/connection_adapters/deduplicable.rb +29 -0
- data/lib/active_record/connection_adapters/legacy_pool_manager.rb +35 -0
- data/lib/active_record/connection_adapters/mysql/database_statements.rb +24 -24
- data/lib/active_record/connection_adapters/mysql/explain_pretty_printer.rb +1 -1
- data/lib/active_record/connection_adapters/mysql/quoting.rb +18 -3
- data/lib/active_record/connection_adapters/mysql/schema_creation.rb +32 -6
- data/lib/active_record/connection_adapters/mysql/schema_definitions.rb +8 -0
- data/lib/active_record/connection_adapters/mysql/schema_dumper.rb +5 -2
- data/lib/active_record/connection_adapters/mysql/schema_statements.rb +7 -4
- data/lib/active_record/connection_adapters/mysql/type_metadata.rb +10 -1
- data/lib/active_record/connection_adapters/mysql2_adapter.rb +31 -12
- data/lib/active_record/connection_adapters/pool_config.rb +73 -0
- data/lib/active_record/connection_adapters/pool_manager.rb +47 -0
- data/lib/active_record/connection_adapters/postgresql/column.rb +24 -1
- data/lib/active_record/connection_adapters/postgresql/database_statements.rb +14 -53
- data/lib/active_record/connection_adapters/postgresql/oid/cidr.rb +3 -5
- data/lib/active_record/connection_adapters/postgresql/oid/date.rb +2 -2
- data/lib/active_record/connection_adapters/postgresql/oid/date_time.rb +2 -2
- data/lib/active_record/connection_adapters/postgresql/oid/interval.rb +49 -0
- data/lib/active_record/connection_adapters/postgresql/oid/legacy_point.rb +2 -2
- data/lib/active_record/connection_adapters/postgresql/oid/macaddr.rb +25 -0
- data/lib/active_record/connection_adapters/postgresql/oid/point.rb +2 -2
- data/lib/active_record/connection_adapters/postgresql/oid/uuid.rb +11 -1
- data/lib/active_record/connection_adapters/postgresql/oid.rb +2 -0
- data/lib/active_record/connection_adapters/postgresql/quoting.rb +30 -4
- data/lib/active_record/connection_adapters/postgresql/referential_integrity.rb +1 -1
- data/lib/active_record/connection_adapters/postgresql/schema_creation.rb +5 -1
- data/lib/active_record/connection_adapters/postgresql/schema_statements.rb +61 -29
- data/lib/active_record/connection_adapters/postgresql/type_metadata.rb +8 -0
- data/lib/active_record/connection_adapters/postgresql_adapter.rb +75 -64
- data/lib/active_record/connection_adapters/schema_cache.rb +130 -15
- data/lib/active_record/connection_adapters/sql_type_metadata.rb +8 -0
- data/lib/active_record/connection_adapters/sqlite3/database_statements.rb +32 -5
- data/lib/active_record/connection_adapters/sqlite3/quoting.rb +1 -1
- data/lib/active_record/connection_adapters/sqlite3/schema_creation.rb +5 -1
- data/lib/active_record/connection_adapters/sqlite3/schema_statements.rb +36 -3
- data/lib/active_record/connection_adapters/sqlite3_adapter.rb +48 -50
- data/lib/active_record/connection_adapters.rb +52 -0
- data/lib/active_record/connection_handling.rb +218 -71
- data/lib/active_record/core.rb +264 -63
- data/lib/active_record/database_configurations/connection_url_resolver.rb +99 -0
- data/lib/active_record/database_configurations/database_config.rb +52 -9
- data/lib/active_record/database_configurations/hash_config.rb +54 -8
- data/lib/active_record/database_configurations/url_config.rb +15 -40
- data/lib/active_record/database_configurations.rb +125 -85
- data/lib/active_record/delegated_type.rb +209 -0
- data/lib/active_record/destroy_association_async_job.rb +36 -0
- data/lib/active_record/enum.rb +69 -34
- data/lib/active_record/errors.rb +47 -12
- data/lib/active_record/explain.rb +9 -4
- data/lib/active_record/explain_subscriber.rb +1 -1
- data/lib/active_record/fixture_set/file.rb +10 -17
- data/lib/active_record/fixture_set/model_metadata.rb +1 -2
- data/lib/active_record/fixture_set/render_context.rb +1 -1
- data/lib/active_record/fixture_set/table_row.rb +2 -2
- data/lib/active_record/fixtures.rb +58 -9
- data/lib/active_record/gem_version.rb +3 -3
- data/lib/active_record/inheritance.rb +40 -18
- data/lib/active_record/insert_all.rb +38 -5
- data/lib/active_record/integration.rb +3 -5
- data/lib/active_record/internal_metadata.rb +18 -7
- data/lib/active_record/legacy_yaml_adapter.rb +7 -3
- data/lib/active_record/locking/optimistic.rb +24 -17
- data/lib/active_record/locking/pessimistic.rb +6 -2
- data/lib/active_record/log_subscriber.rb +27 -8
- data/lib/active_record/middleware/database_selector/resolver/session.rb +3 -0
- data/lib/active_record/middleware/database_selector/resolver.rb +5 -0
- data/lib/active_record/middleware/database_selector.rb +4 -1
- data/lib/active_record/migration/command_recorder.rb +47 -27
- data/lib/active_record/migration/compatibility.rb +72 -18
- data/lib/active_record/migration.rb +114 -84
- data/lib/active_record/model_schema.rb +89 -14
- data/lib/active_record/nested_attributes.rb +2 -3
- data/lib/active_record/no_touching.rb +1 -1
- data/lib/active_record/persistence.rb +50 -45
- data/lib/active_record/query_cache.rb +15 -5
- data/lib/active_record/querying.rb +11 -6
- data/lib/active_record/railtie.rb +64 -44
- data/lib/active_record/railties/console_sandbox.rb +2 -4
- data/lib/active_record/railties/databases.rake +279 -101
- data/lib/active_record/readonly_attributes.rb +4 -0
- data/lib/active_record/reflection.rb +60 -44
- data/lib/active_record/relation/batches/batch_enumerator.rb +25 -9
- data/lib/active_record/relation/batches.rb +38 -31
- data/lib/active_record/relation/calculations.rb +104 -43
- data/lib/active_record/relation/finder_methods.rb +44 -14
- data/lib/active_record/relation/from_clause.rb +1 -1
- data/lib/active_record/relation/merger.rb +20 -23
- data/lib/active_record/relation/predicate_builder/array_handler.rb +8 -9
- data/lib/active_record/relation/predicate_builder/association_query_value.rb +4 -5
- data/lib/active_record/relation/predicate_builder/polymorphic_array_value.rb +10 -6
- data/lib/active_record/relation/predicate_builder/relation_handler.rb +1 -1
- data/lib/active_record/relation/predicate_builder.rb +61 -38
- data/lib/active_record/relation/query_methods.rb +322 -196
- data/lib/active_record/relation/record_fetch_warning.rb +3 -3
- data/lib/active_record/relation/spawn_methods.rb +8 -7
- data/lib/active_record/relation/where_clause.rb +111 -61
- data/lib/active_record/relation.rb +100 -81
- data/lib/active_record/result.rb +41 -33
- data/lib/active_record/runtime_registry.rb +2 -2
- data/lib/active_record/sanitization.rb +6 -17
- data/lib/active_record/schema_dumper.rb +34 -4
- data/lib/active_record/schema_migration.rb +2 -8
- data/lib/active_record/scoping/default.rb +1 -3
- data/lib/active_record/scoping/named.rb +1 -17
- data/lib/active_record/secure_token.rb +16 -8
- data/lib/active_record/serialization.rb +5 -3
- data/lib/active_record/signed_id.rb +116 -0
- data/lib/active_record/statement_cache.rb +20 -4
- data/lib/active_record/store.rb +8 -3
- data/lib/active_record/suppressor.rb +2 -2
- data/lib/active_record/table_metadata.rb +42 -51
- data/lib/active_record/tasks/database_tasks.rb +140 -113
- data/lib/active_record/tasks/mysql_database_tasks.rb +34 -35
- data/lib/active_record/tasks/postgresql_database_tasks.rb +24 -26
- data/lib/active_record/tasks/sqlite_database_tasks.rb +13 -9
- data/lib/active_record/test_databases.rb +5 -4
- data/lib/active_record/test_fixtures.rb +79 -31
- data/lib/active_record/timestamp.rb +4 -6
- data/lib/active_record/touch_later.rb +21 -21
- data/lib/active_record/transactions.rb +19 -66
- data/lib/active_record/type/serialized.rb +6 -2
- data/lib/active_record/type.rb +8 -1
- data/lib/active_record/type_caster/connection.rb +0 -1
- data/lib/active_record/type_caster/map.rb +8 -5
- data/lib/active_record/validations/associated.rb +1 -1
- data/lib/active_record/validations/numericality.rb +35 -0
- data/lib/active_record/validations/uniqueness.rb +24 -4
- data/lib/active_record/validations.rb +1 -0
- data/lib/active_record.rb +7 -14
- data/lib/arel/attributes/attribute.rb +4 -0
- data/lib/arel/collectors/bind.rb +5 -0
- data/lib/arel/collectors/composite.rb +8 -0
- data/lib/arel/collectors/sql_string.rb +7 -0
- data/lib/arel/collectors/substitute_binds.rb +7 -0
- data/lib/arel/nodes/binary.rb +82 -8
- data/lib/arel/nodes/bind_param.rb +8 -0
- data/lib/arel/nodes/casted.rb +21 -9
- data/lib/arel/nodes/equality.rb +6 -9
- data/lib/arel/nodes/grouping.rb +3 -0
- data/lib/arel/nodes/homogeneous_in.rb +76 -0
- data/lib/arel/nodes/in.rb +8 -1
- data/lib/arel/nodes/infix_operation.rb +13 -1
- data/lib/arel/nodes/join_source.rb +1 -1
- data/lib/arel/nodes/node.rb +7 -6
- data/lib/arel/nodes/ordering.rb +27 -0
- data/lib/arel/nodes/sql_literal.rb +3 -0
- data/lib/arel/nodes/table_alias.rb +7 -3
- data/lib/arel/nodes/unary.rb +0 -1
- data/lib/arel/nodes.rb +3 -1
- data/lib/arel/predications.rb +12 -18
- data/lib/arel/select_manager.rb +1 -2
- data/lib/arel/table.rb +13 -5
- data/lib/arel/visitors/dot.rb +14 -2
- data/lib/arel/visitors/mysql.rb +11 -1
- data/lib/arel/visitors/postgresql.rb +15 -4
- data/lib/arel/visitors/to_sql.rb +89 -78
- data/lib/arel/visitors.rb +0 -7
- data/lib/arel.rb +5 -13
- data/lib/rails/generators/active_record/migration/migration_generator.rb +1 -0
- data/lib/rails/generators/active_record/migration/templates/create_table_migration.rb.tt +2 -0
- data/lib/rails/generators/active_record/migration/templates/migration.rb.tt +3 -3
- data/lib/rails/generators/active_record/migration.rb +6 -1
- data/lib/rails/generators/active_record/model/model_generator.rb +39 -2
- data/lib/rails/generators/active_record/model/templates/abstract_base_class.rb.tt +7 -0
- metadata +24 -25
- data/lib/active_record/advisory_lock_base.rb +0 -18
- data/lib/active_record/attribute_decorators.rb +0 -88
- data/lib/active_record/connection_adapters/connection_specification.rb +0 -296
- data/lib/active_record/connection_adapters/determine_if_preparable_visitor.rb +0 -29
- data/lib/active_record/define_callbacks.rb +0 -22
- data/lib/active_record/railties/collection_cache_association_loading.rb +0 -34
- data/lib/active_record/relation/predicate_builder/base_handler.rb +0 -18
- data/lib/active_record/relation/where_clause_factory.rb +0 -33
- data/lib/arel/attributes.rb +0 -22
- data/lib/arel/visitors/depth_first.rb +0 -203
- data/lib/arel/visitors/ibm_db.rb +0 -34
- data/lib/arel/visitors/informix.rb +0 -62
- data/lib/arel/visitors/mssql.rb +0 -156
- data/lib/arel/visitors/oracle.rb +0 -158
- data/lib/arel/visitors/oracle12.rb +0 -65
- data/lib/arel/visitors/where_sql.rb +0 -22
data/CHANGELOG.md
CHANGED
@@ -1,6 +1,16 @@
|
|
1
|
-
## Rails 6.
|
1
|
+
## Rails 6.1.7.3 (March 13, 2023) ##
|
2
2
|
|
3
|
-
*
|
3
|
+
* No changes.
|
4
|
+
|
5
|
+
|
6
|
+
## Rails 6.1.7.2 (January 24, 2023) ##
|
7
|
+
|
8
|
+
* No changes.
|
9
|
+
|
10
|
+
|
11
|
+
## Rails 6.1.7.1 (January 17, 2023) ##
|
12
|
+
|
13
|
+
* Make sanitize_as_sql_comment more strict
|
4
14
|
|
5
15
|
Though this method was likely never meant to take user input, it was
|
6
16
|
attempting sanitization. That sanitization could be bypassed with
|
@@ -16,15 +26,38 @@
|
|
16
26
|
|
17
27
|
[CVE-2023-22794]
|
18
28
|
|
29
|
+
* Added integer width check to PostgreSQL::Quoting
|
19
30
|
|
20
|
-
|
31
|
+
Given a value outside the range for a 64bit signed integer type
|
32
|
+
PostgreSQL will treat the column type as numeric. Comparing
|
33
|
+
integer values against numeric values can result in a slow
|
34
|
+
sequential scan.
|
35
|
+
|
36
|
+
This behavior is configurable via
|
37
|
+
ActiveRecord::Base.raise_int_wider_than_64bit which defaults to true.
|
38
|
+
|
39
|
+
[CVE-2022-44566]
|
40
|
+
|
41
|
+
## Rails 6.1.7 (September 09, 2022) ##
|
21
42
|
|
22
43
|
* Symbol is allowed by default for YAML columns
|
23
44
|
|
24
45
|
*Étienne Barrié*
|
25
46
|
|
47
|
+
* Fix `ActiveRecord::Store` to serialize as a regular Hash
|
48
|
+
|
49
|
+
Previously it would serialize as an `ActiveSupport::HashWithIndifferentAccess`
|
50
|
+
which is wasteful and cause problem with YAML safe_load.
|
51
|
+
|
52
|
+
*Jean Boussier*
|
53
|
+
|
54
|
+
* Fix PG.connect keyword arguments deprecation warning on ruby 2.7
|
55
|
+
|
56
|
+
Fixes #44307.
|
57
|
+
|
58
|
+
*Nikita Vasilevsky*
|
26
59
|
|
27
|
-
## Rails 6.
|
60
|
+
## Rails 6.1.6.1 (July 12, 2022) ##
|
28
61
|
|
29
62
|
* Change ActiveRecord::Coders::YAMLColumn default to safe_load
|
30
63
|
|
@@ -52,1398 +85,1723 @@
|
|
52
85
|
[CVE-2022-32224]
|
53
86
|
|
54
87
|
|
55
|
-
## Rails 6.
|
88
|
+
## Rails 6.1.6 (May 09, 2022) ##
|
56
89
|
|
57
90
|
* No changes.
|
58
91
|
|
59
92
|
|
60
|
-
## Rails 6.
|
93
|
+
## Rails 6.1.5.1 (April 26, 2022) ##
|
61
94
|
|
62
95
|
* No changes.
|
63
96
|
|
64
97
|
|
65
|
-
## Rails 6.
|
98
|
+
## Rails 6.1.5 (March 09, 2022) ##
|
66
99
|
|
67
|
-
*
|
100
|
+
* Fix `ActiveRecord::ConnectionAdapters::SchemaCache#deep_deduplicate` for Ruby 2.6.
|
68
101
|
|
102
|
+
Ruby 2.6 and 2.7 have slightly different implementations of the `String#-@` method.
|
103
|
+
In Ruby 2.6, the receiver of the `String#-@` method is modified under certain circumstances.
|
104
|
+
This was later identified as a bug (https://bugs.ruby-lang.org/issues/15926) and only
|
105
|
+
fixed in Ruby 2.7.
|
69
106
|
|
70
|
-
|
107
|
+
Before the changes in this commit, the
|
108
|
+
`ActiveRecord::ConnectionAdapters::SchemaCache#deep_deduplicate` method, which internally
|
109
|
+
calls the `String#-@` method, could also modify an input string argument in Ruby 2.6 --
|
110
|
+
changing a tainted, unfrozen string into a tainted, frozen string.
|
71
111
|
|
72
|
-
|
112
|
+
Fixes #43056
|
73
113
|
|
114
|
+
*Eric O'Hanlon*
|
74
115
|
|
75
|
-
|
116
|
+
* Fix migration compatibility to create SQLite references/belongs_to column as integer when
|
117
|
+
migration version is 6.0.
|
76
118
|
|
77
|
-
|
119
|
+
`reference`/`belongs_to` in migrations with version 6.0 were creating columns as
|
120
|
+
bigint instead of integer for the SQLite Adapter.
|
78
121
|
|
122
|
+
*Marcelo Lauxen*
|
79
123
|
|
80
|
-
|
124
|
+
* Fix dbconsole for 3-tier config.
|
81
125
|
|
82
|
-
*
|
126
|
+
*Eileen M. Uchitelle*
|
83
127
|
|
128
|
+
* Better handle SQL queries with invalid encoding.
|
84
129
|
|
85
|
-
|
130
|
+
```ruby
|
131
|
+
Post.create(name: "broken \xC8 UTF-8")
|
132
|
+
```
|
86
133
|
|
87
|
-
|
134
|
+
Would cause all adapters to fail in a non controlled way in the code
|
135
|
+
responsible to detect write queries.
|
88
136
|
|
137
|
+
The query is now properly passed to the database connection, which might or might
|
138
|
+
not be able to handle it, but will either succeed or failed in a more correct way.
|
89
139
|
|
90
|
-
|
140
|
+
*Jean Boussier*
|
91
141
|
|
92
|
-
*
|
142
|
+
* Ignore persisted in-memory records when merging target lists.
|
93
143
|
|
144
|
+
*Kevin Sjöberg*
|
94
145
|
|
95
|
-
|
146
|
+
* Fix regression bug that caused ignoring additional conditions for preloading
|
147
|
+
`has_many` through relations.
|
96
148
|
|
97
|
-
|
149
|
+
Fixes #43132
|
98
150
|
|
151
|
+
*Alexander Pauly*
|
99
152
|
|
100
|
-
|
153
|
+
* Fix `ActiveRecord::InternalMetadata` to not be broken by
|
154
|
+
`config.active_record.record_timestamps = false`
|
101
155
|
|
102
|
-
|
156
|
+
Since the model always create the timestamp columns, it has to set them, otherwise it breaks
|
157
|
+
various DB management tasks.
|
103
158
|
|
104
|
-
Fixes #
|
159
|
+
Fixes #42983
|
105
160
|
|
106
|
-
*
|
161
|
+
*Jean Boussier*
|
107
162
|
|
108
|
-
*
|
163
|
+
* Fix duplicate active record objects on `inverse_of`.
|
109
164
|
|
110
|
-
|
165
|
+
*Justin Carvalho*
|
111
166
|
|
112
|
-
|
167
|
+
* Fix duplicate objects stored in has many association after save.
|
113
168
|
|
114
|
-
|
169
|
+
Fixes #42549.
|
115
170
|
|
116
|
-
|
171
|
+
*Alex Ghiculescu*
|
117
172
|
|
118
|
-
|
173
|
+
* Fix performance regression in `CollectionAssocation#build`.
|
119
174
|
|
120
|
-
*
|
175
|
+
*Alex Ghiculescu*
|
121
176
|
|
122
|
-
|
177
|
+
* Fix retrieving default value for text column for MariaDB.
|
123
178
|
|
124
|
-
*
|
179
|
+
*fatkodima*
|
125
180
|
|
126
|
-
Fixes #39173.
|
127
181
|
|
128
|
-
|
182
|
+
## Rails 6.1.4.7 (March 08, 2022) ##
|
129
183
|
|
130
|
-
*
|
184
|
+
* No changes.
|
131
185
|
|
132
|
-
When the `:unique_by` option of `ActiveRecord::Persistence.insert_all` and
|
133
|
-
`ActiveRecord::Persistence.upsert_all` was used with the name of an expression index, an error
|
134
|
-
was raised. Adding a guard around the formatting behavior for the `:unique_by` corrects this.
|
135
186
|
|
136
|
-
|
187
|
+
## Rails 6.1.4.6 (February 11, 2022) ##
|
137
188
|
|
138
|
-
|
139
|
-
create_table :books, id: :integer, force: true do |t|
|
140
|
-
t.column :name, :string
|
141
|
-
t.index "lower(name)", unique: true
|
142
|
-
end
|
189
|
+
* No changes.
|
143
190
|
|
144
|
-
Book.insert_all [{ name: "MyTest" }], unique_by: :index_books_on_lower_name
|
145
|
-
```
|
146
191
|
|
147
|
-
|
192
|
+
## Rails 6.1.4.5 (February 11, 2022) ##
|
148
193
|
|
149
|
-
|
194
|
+
* No changes.
|
150
195
|
|
151
|
-
* Fix preloading for polymorphic association with custom scope.
|
152
196
|
|
153
|
-
|
197
|
+
## Rails 6.1.4.4 (December 15, 2021) ##
|
154
198
|
|
155
|
-
*
|
199
|
+
* No changes.
|
156
200
|
|
157
|
-
*Takumi Shotoku*
|
158
201
|
|
159
|
-
|
202
|
+
## Rails 6.1.4.3 (December 14, 2021) ##
|
160
203
|
|
161
|
-
|
162
|
-
cache. This avoids raising an unnecessary `ActiveRecord::StaleObjectError`
|
163
|
-
upon subsequent transactions by maintaining parity with the corresponding
|
164
|
-
database record's `lock_version` column.
|
204
|
+
* No changes.
|
165
205
|
|
166
|
-
Fixes #16449.
|
167
206
|
|
168
|
-
|
207
|
+
## Rails 6.1.4.2 (December 14, 2021) ##
|
169
208
|
|
170
|
-
*
|
209
|
+
* No changes.
|
171
210
|
|
172
|
-
*Ryuta Kamizono*
|
173
211
|
|
174
|
-
|
212
|
+
## Rails 6.1.4.1 (August 19, 2021) ##
|
175
213
|
|
176
|
-
|
214
|
+
* No changes.
|
177
215
|
|
178
|
-
* Fix eager load with Arel joins to maintain the original joins order.
|
179
216
|
|
180
|
-
|
217
|
+
## Rails 6.1.4 (June 24, 2021) ##
|
181
218
|
|
182
|
-
*
|
219
|
+
* Do not try to rollback transactions that failed due to a `ActiveRecord::TransactionRollbackError`.
|
183
220
|
|
184
|
-
*
|
221
|
+
*Jamie McCarthy*
|
185
222
|
|
186
|
-
*
|
223
|
+
* Raise an error if `pool_config` is `nil` in `set_pool_config`.
|
187
224
|
|
188
|
-
*
|
225
|
+
*Eileen M. Uchitelle*
|
189
226
|
|
190
|
-
* Fix
|
227
|
+
* Fix compatibility with `psych >= 4`.
|
191
228
|
|
192
|
-
|
229
|
+
Starting in Psych 4.0.0 `YAML.load` behaves like `YAML.safe_load`. To preserve compatibility
|
230
|
+
Active Record's schema cache loader and `YAMLColumn` now uses `YAML.unsafe_load` if available.
|
193
231
|
|
194
|
-
*
|
195
|
-
doesn't support the feature.
|
232
|
+
*Jean Boussier*
|
196
233
|
|
197
|
-
|
234
|
+
* Support using replicas when using `rails dbconsole`.
|
198
235
|
|
199
|
-
*
|
236
|
+
*Christopher Thornton*
|
200
237
|
|
201
|
-
|
238
|
+
* Restore connection pools after transactional tests.
|
202
239
|
|
203
|
-
*
|
240
|
+
*Eugene Kenny*
|
204
241
|
|
205
|
-
|
242
|
+
* Change `upsert_all` to fails cleanly for MySQL when `:unique_by` is used.
|
206
243
|
|
244
|
+
*Bastian Bartmann*
|
207
245
|
|
208
|
-
|
246
|
+
* Fix user-defined `self.default_scope` to respect table alias.
|
209
247
|
|
210
|
-
*
|
248
|
+
*Ryuta Kamizono*
|
211
249
|
|
250
|
+
* Clear `@cache_keys` cache after `update_all`, `delete_all`, `destroy_all`.
|
212
251
|
|
213
|
-
|
252
|
+
*Ryuta Kamizono*
|
214
253
|
|
215
|
-
*
|
254
|
+
* Changed Arel predications `contains` and `overlaps` to use
|
255
|
+
`quoted_node` so that PostgreSQL arrays are quoted properly.
|
216
256
|
|
257
|
+
*Bradley Priest*
|
217
258
|
|
218
|
-
|
259
|
+
* Fix `merge` when the `where` clauses have string contents.
|
219
260
|
|
220
|
-
*
|
261
|
+
*Ryuta Kamizono*
|
221
262
|
|
222
|
-
|
223
|
-
for validating the money format in the PostgreSQL adapter. This patch
|
224
|
-
fixes the regexp.
|
263
|
+
* Fix rollback of parent destruction with nested `dependent: :destroy`.
|
225
264
|
|
226
|
-
|
265
|
+
*Jacopo Beschi*
|
227
266
|
|
228
|
-
|
267
|
+
* Fix binds logging for `"WHERE ... IN ..."` statements.
|
229
268
|
|
230
|
-
*
|
269
|
+
*Ricardo Díaz*
|
231
270
|
|
271
|
+
* Handle `false` in relation strict loading checks.
|
232
272
|
|
233
|
-
|
273
|
+
Previously when a model had strict loading set to true and then had a
|
274
|
+
relation set `strict_loading` to false the false wasn't considered when
|
275
|
+
deciding whether to raise/warn about strict loading.
|
234
276
|
|
235
|
-
|
277
|
+
```
|
278
|
+
class Dog < ActiveRecord::Base
|
279
|
+
self.strict_loading_by_default = true
|
236
280
|
|
281
|
+
has_many :treats, strict_loading: false
|
282
|
+
end
|
283
|
+
```
|
237
284
|
|
238
|
-
|
285
|
+
In the example, `dog.treats` would still raise even though
|
286
|
+
`strict_loading` was set to false. This is a bug affecting more than
|
287
|
+
Active Storage which is why I made this PR superseding #41461. We need
|
288
|
+
to fix this for all applications since the behavior is a little
|
289
|
+
surprising. I took the test from #41461 and the code suggestion from #41453
|
290
|
+
with some additions.
|
239
291
|
|
240
|
-
*
|
292
|
+
*Eileen M. Uchitelle*, *Radamés Roriz*
|
241
293
|
|
294
|
+
* Fix numericality validator without precision.
|
242
295
|
|
243
|
-
|
296
|
+
*Ryuta Kamizono*
|
244
297
|
|
245
|
-
*
|
298
|
+
* Fix aggregate attribute on Enum types.
|
246
299
|
|
300
|
+
*Ryuta Kamizono*
|
247
301
|
|
248
|
-
|
302
|
+
* Fix `CREATE INDEX` statement generation for PostgreSQL.
|
249
303
|
|
250
|
-
*
|
304
|
+
*eltongo*
|
251
305
|
|
306
|
+
* Fix where clause on enum attribute when providing array of strings.
|
252
307
|
|
253
|
-
|
308
|
+
*Ryuta Kamizono*
|
254
309
|
|
255
|
-
*
|
310
|
+
* Fix `unprepared_statement` to work it when nesting.
|
256
311
|
|
257
|
-
|
312
|
+
*Ryuta Kamizono*
|
258
313
|
|
259
|
-
*Eileen M. Uchitelle*
|
260
314
|
|
261
|
-
|
315
|
+
## Rails 6.1.3.2 (May 05, 2021) ##
|
262
316
|
|
263
|
-
|
317
|
+
* No changes.
|
264
318
|
|
265
|
-
* Add support for beginless ranges, introduced in Ruby 2.7.
|
266
319
|
|
267
|
-
|
320
|
+
## Rails 6.1.3.1 (March 26, 2021) ##
|
268
321
|
|
269
|
-
*
|
322
|
+
* No changes.
|
270
323
|
|
271
|
-
Fixes #38716.
|
272
324
|
|
273
|
-
|
325
|
+
## Rails 6.1.3 (February 17, 2021) ##
|
274
326
|
|
275
|
-
*
|
327
|
+
* Fix the MySQL adapter to always set the right collation and charset
|
328
|
+
to the connection session.
|
276
329
|
|
277
|
-
|
330
|
+
*Rafael Mendonça França*
|
278
331
|
|
279
|
-
|
332
|
+
* Fix MySQL adapter handling of time objects when prepared statements
|
333
|
+
are enabled.
|
280
334
|
|
281
|
-
*
|
335
|
+
*Rafael Mendonça França*
|
282
336
|
|
283
|
-
|
337
|
+
* Fix scoping in enum fields using conditions that would generate
|
338
|
+
an `IN` clause.
|
284
339
|
|
285
|
-
|
340
|
+
*Ryuta Kamizono*
|
286
341
|
|
287
|
-
|
342
|
+
* Skip optimised #exist? query when #include? is called on a relation
|
343
|
+
with a having clause
|
288
344
|
|
289
|
-
|
345
|
+
Relations that have aliased select values AND a having clause that
|
346
|
+
references an aliased select value would generate an error when
|
347
|
+
#include? was called, due to an optimisation that would generate
|
348
|
+
call #exists? on the relation instead, which effectively alters
|
349
|
+
the select values of the query (and thus removes the aliased select
|
350
|
+
values), but leaves the having clause intact. Because the having
|
351
|
+
clause is then referencing an aliased column that is no longer
|
352
|
+
present in the simplified query, an ActiveRecord::InvalidStatement
|
353
|
+
error was raised.
|
290
354
|
|
291
|
-
|
355
|
+
An sample query affected by this problem:
|
292
356
|
|
293
|
-
|
357
|
+
```ruby
|
358
|
+
Author.select('COUNT(*) as total_posts', 'authors.*')
|
359
|
+
.joins(:posts)
|
360
|
+
.group(:id)
|
361
|
+
.having('total_posts > 2')
|
362
|
+
.include?(Author.first)
|
363
|
+
```
|
294
364
|
|
295
|
-
|
296
|
-
|
297
|
-
|
298
|
-
is enabled, requests using ConditionalGet don't return the same ETag header
|
299
|
-
after a collection is modified. Fixes #38078.
|
365
|
+
This change adds an addition check to the condition that skips the
|
366
|
+
simplified #exists? query, which simply checks for the presence of
|
367
|
+
a having clause.
|
300
368
|
|
301
|
-
|
369
|
+
Fixes #41417
|
302
370
|
|
303
|
-
*
|
371
|
+
*Michael Smart*
|
304
372
|
|
305
|
-
|
373
|
+
* Increment postgres prepared statement counter before making a prepared statement, so if the statement is aborted
|
374
|
+
without Rails knowledge (e.g., if app gets kill -9d during long-running query or due to Rack::Timeout), app won't end
|
375
|
+
up in perpetual crash state for being inconsistent with Postgres.
|
306
376
|
|
307
|
-
*
|
377
|
+
*wbharding*, *Martin Tepper*
|
308
378
|
|
309
|
-
Resolves #34889.
|
310
379
|
|
311
|
-
|
380
|
+
## Rails 6.1.2.1 (February 10, 2021) ##
|
312
381
|
|
382
|
+
* Fix possible DoS vector in PostgreSQL money type
|
313
383
|
|
314
|
-
|
384
|
+
Carefully crafted input can cause a DoS via the regular expressions used
|
385
|
+
for validating the money format in the PostgreSQL adapter. This patch
|
386
|
+
fixes the regexp.
|
315
387
|
|
316
|
-
|
388
|
+
Thanks to @dee-see from Hackerone for this patch!
|
317
389
|
|
390
|
+
[CVE-2021-22880]
|
318
391
|
|
319
|
-
|
392
|
+
*Aaron Patterson*
|
320
393
|
|
321
|
-
* No changes.
|
322
394
|
|
395
|
+
## Rails 6.1.2 (February 09, 2021) ##
|
323
396
|
|
324
|
-
|
397
|
+
* Fix timestamp type for sqlite3.
|
325
398
|
|
326
|
-
*
|
327
|
-
transactional tests for the same database.
|
399
|
+
*Eileen M. Uchitelle*
|
328
400
|
|
329
|
-
|
401
|
+
* Make destroy async transactional.
|
330
402
|
|
331
|
-
|
332
|
-
|
403
|
+
An active record rollback could occur while enqueuing a job. In this
|
404
|
+
case the job would enqueue even though the database deletion
|
405
|
+
rolledback putting things in a funky state.
|
333
406
|
|
334
|
-
|
407
|
+
Now the jobs are only enqueued until after the db transaction has been committed.
|
335
408
|
|
336
|
-
*
|
409
|
+
*Cory Gwin*
|
337
410
|
|
338
|
-
|
411
|
+
* Fix malformed packet error in MySQL statement for connection configuration.
|
339
412
|
|
340
|
-
*
|
413
|
+
*robinroestenburg*
|
341
414
|
|
342
|
-
|
343
|
-
|
344
|
-
|
345
|
-
|
415
|
+
* Connection specification now passes the "url" key as a configuration for the
|
416
|
+
adapter if the "url" protocol is "jdbc", "http", or "https". Previously only
|
417
|
+
urls with the "jdbc" prefix were passed to the Active Record Adapter, others
|
418
|
+
are assumed to be adapter specification urls.
|
346
419
|
|
347
|
-
|
420
|
+
Fixes #41137.
|
348
421
|
|
349
|
-
*
|
350
|
-
to the previous database.
|
422
|
+
*Jonathan Bracy*
|
351
423
|
|
352
|
-
|
353
|
-
resulting in the last one to be used by subsequent rake tasks.
|
354
|
-
We should reestablish a connection to the connection that was
|
355
|
-
established before the migrate tasks was run
|
424
|
+
* Fix granular connection swapping when there are multiple abstract classes.
|
356
425
|
|
357
|
-
*
|
426
|
+
*Eileen M. Uchitelle*
|
358
427
|
|
359
|
-
* Fix
|
428
|
+
* Fix `find_by` with custom primary key for belongs_to association.
|
360
429
|
|
361
430
|
*Ryuta Kamizono*
|
362
431
|
|
432
|
+
* Add support for `rails console --sandbox` for multiple database applications.
|
363
433
|
|
364
|
-
|
365
|
-
|
366
|
-
* Common Table Expressions are allowed on read-only connections.
|
434
|
+
*alpaca-tc*
|
367
435
|
|
368
|
-
|
436
|
+
* Fix `where` on polymorphic association with empty array.
|
369
437
|
|
370
|
-
*
|
371
|
-
|
372
|
-
*Ryuta Kamizono*
|
438
|
+
*Ryuta Kamizono*
|
373
439
|
|
374
|
-
*
|
440
|
+
* Fix preventing writes for `ApplicationRecord`.
|
375
441
|
|
376
|
-
|
442
|
+
*Eileen M. Uchitelle*
|
377
443
|
|
378
|
-
* Autosaved associations always perform validations when a custom validation
|
379
|
-
context is used.
|
380
444
|
|
381
|
-
|
445
|
+
## Rails 6.1.1 (January 07, 2021) ##
|
382
446
|
|
383
|
-
*
|
384
|
-
their payloads.
|
447
|
+
* Fix fixtures loading when strict loading is enabled for the association.
|
385
448
|
|
386
|
-
|
449
|
+
*Alex Ghiculescu*
|
387
450
|
|
388
|
-
*
|
389
|
-
previously-committed record state.
|
451
|
+
* Fix `where` with custom primary key for belongs_to association.
|
390
452
|
|
391
|
-
|
453
|
+
*Ryuta Kamizono*
|
392
454
|
|
393
|
-
*
|
455
|
+
* Fix `where` with aliased associations.
|
394
456
|
|
395
|
-
|
457
|
+
*Ryuta Kamizono*
|
396
458
|
|
397
|
-
* `
|
459
|
+
* Fix `composed_of` with symbol mapping.
|
398
460
|
|
399
|
-
*
|
461
|
+
*Ryuta Kamizono*
|
400
462
|
|
401
|
-
*
|
463
|
+
* Don't skip money's type cast for pluck and calculations.
|
402
464
|
|
403
|
-
*
|
465
|
+
*Ryuta Kamizono*
|
404
466
|
|
405
|
-
*
|
406
|
-
fixes that idle connections in forked processes wouldn't be reaped.
|
467
|
+
* Fix `where` on polymorphic association with non Active Record object.
|
407
468
|
|
408
|
-
*
|
469
|
+
*Ryuta Kamizono*
|
409
470
|
|
410
|
-
*
|
411
|
-
when `ActiveRecord::Relation#reset` or `ActiveRecord::Relation#reload`
|
412
|
-
is called.
|
471
|
+
* Make sure `db:prepare` works even the schema file doesn't exist.
|
413
472
|
|
414
|
-
*
|
473
|
+
*Rafael Mendonça França*
|
415
474
|
|
416
|
-
*
|
475
|
+
* Fix complicated `has_many :through` with nested where condition.
|
417
476
|
|
418
|
-
*
|
477
|
+
*Ryuta Kamizono*
|
419
478
|
|
420
|
-
*
|
479
|
+
* Handle STI models for `has_many dependent: :destroy_async`.
|
421
480
|
|
422
|
-
*
|
481
|
+
*Muhammad Usman*
|
423
482
|
|
424
|
-
*
|
483
|
+
* Restore possibility of passing `false` to :polymorphic option of `belongs_to`.
|
425
484
|
|
426
|
-
|
485
|
+
Previously, passing `false` would trigger the option validation logic
|
486
|
+
to throw an error saying :polymorphic would not be a valid option.
|
427
487
|
|
428
|
-
|
488
|
+
*glaszig*
|
429
489
|
|
430
|
-
|
490
|
+
* Allow adding nonnamed expression indexes to be revertible.
|
431
491
|
|
432
|
-
|
492
|
+
Fixes #40732.
|
433
493
|
|
434
|
-
|
494
|
+
Previously, the following code would raise an error, when executed while rolling back,
|
495
|
+
and the index name should be specified explicitly. Now, the index name is inferred
|
496
|
+
automatically.
|
435
497
|
|
498
|
+
```ruby
|
499
|
+
add_index(:items, "to_tsvector('english', description)")
|
500
|
+
```
|
436
501
|
|
437
|
-
|
502
|
+
*fatkodima*
|
438
503
|
|
439
|
-
* Preserve user supplied joins order as much as possible.
|
440
504
|
|
441
|
-
|
505
|
+
## Rails 6.1.0 (December 09, 2020) ##
|
442
506
|
|
443
|
-
|
507
|
+
* Only warn about negative enums if a positive form that would cause conflicts exists.
|
444
508
|
|
445
|
-
|
509
|
+
Fixes #39065.
|
446
510
|
|
447
|
-
*
|
511
|
+
*Alex Ghiculescu*
|
448
512
|
|
449
|
-
*
|
513
|
+
* Change `attribute_for_inspect` to take `filter_attributes` in consideration.
|
450
514
|
|
451
|
-
|
452
|
-
enum status: [:sent, :not_sent]
|
453
|
-
end
|
515
|
+
*Rafael Mendonça França*
|
454
516
|
|
455
|
-
|
517
|
+
* Fix odd behavior of inverse_of with multiple belongs_to to same class.
|
456
518
|
|
457
|
-
|
519
|
+
Fixes #35204.
|
458
520
|
|
459
|
-
*
|
521
|
+
*Tomoyuki Kai*
|
460
522
|
|
523
|
+
* Build predicate conditions with objects that delegate `#id` and primary key:
|
461
524
|
|
462
|
-
|
525
|
+
```ruby
|
526
|
+
class AdminAuthor
|
527
|
+
delegate_missing_to :@author
|
463
528
|
|
464
|
-
|
529
|
+
def initialize(author)
|
530
|
+
@author = author
|
531
|
+
end
|
532
|
+
end
|
465
533
|
|
466
|
-
|
534
|
+
Post.where(author: AdminAuthor.new(author))
|
535
|
+
```
|
467
536
|
|
468
|
-
*
|
537
|
+
*Sean Doyle*
|
469
538
|
|
470
|
-
|
539
|
+
* Add `connected_to_many` API.
|
471
540
|
|
472
|
-
|
541
|
+
This API allows applications to connect to multiple databases at once without switching all of them or implementing a deeply nested stack.
|
473
542
|
|
474
|
-
|
543
|
+
Before:
|
475
544
|
|
476
|
-
|
545
|
+
AnimalsRecord.connected_to(role: :reading) do
|
546
|
+
MealsRecord.connected_to(role: :reading) do
|
547
|
+
Dog.first # read from animals replica
|
548
|
+
Dinner.first # read from meals replica
|
549
|
+
Person.first # read from primary writer
|
550
|
+
end
|
551
|
+
end
|
477
552
|
|
478
|
-
|
553
|
+
After:
|
479
554
|
|
480
|
-
|
555
|
+
ActiveRecord::Base.connected_to_many([AnimalsRecord, MealsRecord], role: :reading) do
|
556
|
+
Dog.first # read from animals replica
|
557
|
+
Dinner.first # read from meals replica
|
558
|
+
Person.first # read from primary writer
|
559
|
+
end
|
481
560
|
|
482
|
-
*
|
561
|
+
*Eileen M. Uchitelle*, *John Crepezzi*
|
483
562
|
|
484
|
-
*
|
563
|
+
* Add option to raise or log for `ActiveRecord::StrictLoadingViolationError`.
|
485
564
|
|
486
|
-
|
565
|
+
Some applications may not want to raise an error in production if using `strict_loading`. This would allow an application to set strict loading to log for the production environment while still raising in development and test environments.
|
487
566
|
|
488
|
-
|
567
|
+
Set `config.active_record.action_on_strict_loading_violation` to `:log` errors instead of raising.
|
489
568
|
|
490
|
-
*
|
569
|
+
*Eileen M. Uchitelle*
|
491
570
|
|
492
|
-
|
571
|
+
* Allow the inverse of a `has_one` association that was previously autosaved to be loaded.
|
493
572
|
|
494
|
-
|
573
|
+
Fixes #34255.
|
495
574
|
|
496
|
-
|
575
|
+
*Steven Weber*
|
497
576
|
|
498
|
-
|
577
|
+
* Optimise the length of index names for polymorphic references by using the reference name rather than the type and id column names.
|
499
578
|
|
579
|
+
Because the default behaviour when adding an index with multiple columns is to use all column names in the index name, this could frequently lead to overly long index names for polymorphic references which would fail the migration if it exceeded the database limit.
|
500
580
|
|
501
|
-
|
581
|
+
This change reduces the chance of that happening by using the reference name, e.g. `index_my_table_on_my_reference`.
|
502
582
|
|
503
|
-
|
583
|
+
Fixes #38655.
|
504
584
|
|
505
|
-
*
|
585
|
+
*Luke Redpath*
|
506
586
|
|
507
|
-
*
|
587
|
+
* MySQL: Uniqueness validator now respects default database collation,
|
588
|
+
no longer enforce case sensitive comparison by default.
|
508
589
|
|
509
|
-
|
510
|
-
all = [treasures(:diamond), treasures(:sapphire), cars(:honda), treasures(:sapphire)]
|
511
|
-
assert_equal all, PriceEstimate.all.map(&:estimate_of)
|
512
|
-
```
|
590
|
+
*Ryuta Kamizono*
|
513
591
|
|
514
|
-
|
592
|
+
* Remove deprecated methods from `ActiveRecord::ConnectionAdapters::DatabaseLimits`.
|
515
593
|
|
516
|
-
|
517
|
-
|
518
|
-
|
519
|
-
|
520
|
-
|
521
|
-
|
522
|
-
|
523
|
-
}
|
524
|
-
assert_equal [cars(:honda)], nor
|
525
|
-
|
526
|
-
without_sapphire = PriceEstimate.where.not(
|
527
|
-
estimate_of_type: sapphire.class.polymorphic_name, estimate_of_id: sapphire.id
|
528
|
-
)
|
529
|
-
assert_equal nor, without_sapphire.map(&:estimate_of)
|
530
|
-
```
|
594
|
+
`column_name_length`
|
595
|
+
`table_name_length`
|
596
|
+
`columns_per_table`
|
597
|
+
`indexes_per_table`
|
598
|
+
`columns_per_multicolumn_index`
|
599
|
+
`sql_query_length`
|
600
|
+
`joins_per_query`
|
531
601
|
|
532
|
-
|
602
|
+
*Rafael Mendonça França*
|
533
603
|
|
534
|
-
|
535
|
-
sapphire = treasures(:sapphire)
|
604
|
+
* Remove deprecated `ActiveRecord::ConnectionAdapters::AbstractAdapter#supports_multi_insert?`.
|
536
605
|
|
537
|
-
|
538
|
-
assert_equal [treasures(:diamond), cars(:honda)], nand
|
606
|
+
*Rafael Mendonça França*
|
539
607
|
|
540
|
-
|
541
|
-
estimate_of_type: sapphire.class.polymorphic_name, estimate_of_id: sapphire.id
|
542
|
-
)
|
543
|
-
assert_equal nand, without_sapphire.map(&:estimate_of)
|
544
|
-
```
|
608
|
+
* Remove deprecated `ActiveRecord::ConnectionAdapters::AbstractAdapter#supports_foreign_keys_in_create?`.
|
545
609
|
|
546
|
-
*
|
610
|
+
*Rafael Mendonça França*
|
547
611
|
|
548
|
-
*
|
612
|
+
* Remove deprecated `ActiveRecord::ConnectionAdapters::PostgreSQLAdapter#supports_ranges?`.
|
549
613
|
|
550
|
-
|
614
|
+
*Rafael Mendonça França*
|
551
615
|
|
552
|
-
|
616
|
+
* Remove deprecated `ActiveRecord::Base#update_attributes` and `ActiveRecord::Base#update_attributes!`.
|
553
617
|
|
554
|
-
*
|
555
|
-
the versioned entries in `ActiveSupport::Cache`. This also means that
|
556
|
-
`ActiveRecord::Relation#cache_key` will now return a stable key that does not
|
557
|
-
include the max timestamp or count any more.
|
618
|
+
*Rafael Mendonça França*
|
558
619
|
|
559
|
-
|
560
|
-
cache keys with timestamps until you set `ActiveRecord::Base.collection_cache_versioning = true`.
|
561
|
-
That's the setting for all new apps on Rails 6.0+
|
620
|
+
* Remove deprecated `migrations_path` argument in `ActiveRecord::ConnectionAdapter::SchemaStatements#assume_migrated_upto_version`.
|
562
621
|
|
563
|
-
*
|
622
|
+
*Rafael Mendonça França*
|
564
623
|
|
565
|
-
*
|
624
|
+
* Remove deprecated `config.active_record.sqlite3.represent_boolean_as_integer`.
|
566
625
|
|
567
|
-
|
626
|
+
*Rafael Mendonça França*
|
568
627
|
|
569
|
-
|
628
|
+
* `relation.create` does no longer leak scope to class level querying methods
|
629
|
+
in initialization block and callbacks.
|
570
630
|
|
571
|
-
|
572
|
-
`to` and `from` options are specified.
|
631
|
+
Before:
|
573
632
|
|
574
|
-
|
633
|
+
User.where(name: "John").create do |john|
|
634
|
+
User.find_by(name: "David") # => nil
|
635
|
+
end
|
575
636
|
|
576
|
-
|
637
|
+
After:
|
577
638
|
|
578
|
-
|
639
|
+
User.where(name: "John").create do |john|
|
640
|
+
User.find_by(name: "David") # => #<User name: "David", ...>
|
641
|
+
end
|
579
642
|
|
580
643
|
*Ryuta Kamizono*
|
581
644
|
|
582
|
-
*
|
583
|
-
|
584
|
-
Prior to the fix, when there was a circular series of `autosave: true`
|
585
|
-
associations, the callback for a `has_many` association was run while
|
586
|
-
another instance of the same callback on the same association hadn't
|
587
|
-
finished running. When control returned to the first instance of the
|
588
|
-
callback, the instance variable had changed, and subsequent associated
|
589
|
-
records weren't saved correctly. Specifically, the ID field for the
|
590
|
-
`belongs_to` corresponding to the `has_many` was `nil`.
|
591
|
-
|
592
|
-
Fixes #28080.
|
593
|
-
|
594
|
-
*Larry Reid*
|
645
|
+
* Named scope chain does no longer leak scope to class level querying methods.
|
595
646
|
|
596
|
-
|
647
|
+
class User < ActiveRecord::Base
|
648
|
+
scope :david, -> { User.where(name: "David") }
|
649
|
+
end
|
597
650
|
|
598
651
|
Before:
|
599
652
|
|
600
|
-
|
601
|
-
|
602
|
-
add_column :items, :attr2, :decimal, scale: 10 # => ArgumentError
|
603
|
-
add_column :items, :attr3, :integer, limit: 10 # => ActiveRecordError
|
604
|
-
add_column :items, :attr4, :datetime, precision: 10 # => ActiveRecordError
|
605
|
-
```
|
653
|
+
User.where(name: "John").david
|
654
|
+
# SELECT * FROM users WHERE name = 'John' AND name = 'David'
|
606
655
|
|
607
656
|
After:
|
608
657
|
|
609
|
-
|
610
|
-
|
611
|
-
add_column :items, :attr2, :decimal, scale: 10 # => ArgumentError
|
612
|
-
add_column :items, :attr3, :integer, limit: 10 # => ArgumentError
|
613
|
-
add_column :items, :attr4, :datetime, precision: 10 # => ArgumentError
|
614
|
-
```
|
658
|
+
User.where(name: "John").david
|
659
|
+
# SELECT * FROM users WHERE name = 'David'
|
615
660
|
|
616
661
|
*Ryuta Kamizono*
|
617
662
|
|
618
|
-
*
|
619
|
-
whether preloaded / eager loaded or not, with the exception of `unscoped`.
|
663
|
+
* Remove deprecated methods from `ActiveRecord::DatabaseConfigurations`.
|
620
664
|
|
621
|
-
|
665
|
+
`fetch`
|
666
|
+
`each`
|
667
|
+
`first`
|
668
|
+
`values`
|
669
|
+
`[]=`
|
622
670
|
|
623
|
-
|
624
|
-
Post.where("1=0").scoping do
|
625
|
-
Comment.find(1).post # => nil
|
626
|
-
Comment.preload(:post).find(1).post # => #<Post id: 1, ...>
|
627
|
-
Comment.eager_load(:post).find(1).post # => #<Post id: 1, ...>
|
628
|
-
end
|
629
|
-
```
|
671
|
+
*Rafael Mendonça França*
|
630
672
|
|
631
|
-
|
673
|
+
* `where.not` now generates NAND predicates instead of NOR.
|
632
674
|
|
633
|
-
|
634
|
-
Post.where("1=0").scoping do
|
635
|
-
Comment.find(1).post # => #<Post id: 1, ...>
|
636
|
-
Comment.preload(:post).find(1).post # => #<Post id: 1, ...>
|
637
|
-
Comment.eager_load(:post).find(1).post # => #<Post id: 1, ...>
|
638
|
-
end
|
639
|
-
```
|
675
|
+
Before:
|
640
676
|
|
641
|
-
|
677
|
+
User.where.not(name: "Jon", role: "admin")
|
678
|
+
# SELECT * FROM users WHERE name != 'Jon' AND role != 'admin'
|
642
679
|
|
643
|
-
|
680
|
+
After:
|
644
681
|
|
645
|
-
|
682
|
+
User.where.not(name: "Jon", role: "admin")
|
683
|
+
# SELECT * FROM users WHERE NOT (name == 'Jon' AND role == 'admin')
|
646
684
|
|
647
|
-
|
685
|
+
*Rafael Mendonça França*
|
648
686
|
|
649
|
-
|
687
|
+
* Remove deprecated `ActiveRecord::Result#to_hash` method.
|
650
688
|
|
651
|
-
*
|
689
|
+
*Rafael Mendonça França*
|
652
690
|
|
653
|
-
|
691
|
+
* Deprecate `ActiveRecord::Base.allow_unsafe_raw_sql`.
|
654
692
|
|
655
|
-
*
|
656
|
-
`before_add` and `after_add` callbacks for `has_many :through` associations.
|
693
|
+
*Rafael Mendonça França*
|
657
694
|
|
658
|
-
|
695
|
+
* Remove deprecated support for using unsafe raw SQL in `ActiveRecord::Relation` methods.
|
659
696
|
|
660
|
-
*
|
697
|
+
*Rafael Mendonça França*
|
698
|
+
|
699
|
+
* Allow users to silence the "Rails couldn't infer whether you are using multiple databases..."
|
700
|
+
message using `config.active_record.suppress_multiple_database_warning`.
|
701
|
+
|
702
|
+
*Omri Gabay*
|
703
|
+
|
704
|
+
* Connections can be granularly switched for abstract classes when `connected_to` is called.
|
661
705
|
|
662
|
-
|
706
|
+
This change allows `connected_to` to switch a `role` and/or `shard` for a single abstract class instead of all classes globally. Applications that want to use the new feature need to set `config.active_record.legacy_connection_handling` to `false` in their application configuration.
|
663
707
|
|
708
|
+
Example usage:
|
709
|
+
|
710
|
+
Given an application we have a `User` model that inherits from `ApplicationRecord` and a `Dog` model that inherits from `AnimalsRecord`. `AnimalsRecord` and `ApplicationRecord` have writing and reading connections as well as shard `default`, `one`, and `two`.
|
711
|
+
|
712
|
+
```ruby
|
713
|
+
ActiveRecord::Base.connected_to(role: :reading) do
|
714
|
+
User.first # reads from default replica
|
715
|
+
Dog.first # reads from default replica
|
716
|
+
|
717
|
+
AnimalsRecord.connected_to(role: :writing, shard: :one) do
|
718
|
+
User.first # reads from default replica
|
719
|
+
Dog.first # reads from shard one primary
|
720
|
+
end
|
721
|
+
|
722
|
+
User.first # reads from default replica
|
723
|
+
Dog.first # reads from default replica
|
724
|
+
|
725
|
+
ApplicationRecord.connected_to(role: :writing, shard: :two) do
|
726
|
+
User.first # reads from shard two primary
|
727
|
+
Dog.first # reads from default replica
|
728
|
+
end
|
729
|
+
end
|
664
730
|
```
|
665
|
-
|
666
|
-
|
731
|
+
|
732
|
+
*Eileen M. Uchitelle*, *John Crepezzi*
|
733
|
+
|
734
|
+
* Allow double-dash comment syntax when querying read-only databases
|
735
|
+
|
736
|
+
*James Adam*
|
737
|
+
|
738
|
+
* Add `values_at` method.
|
739
|
+
|
740
|
+
Returns an array containing the values associated with the given methods.
|
741
|
+
|
742
|
+
```ruby
|
743
|
+
topic = Topic.first
|
744
|
+
topic.values_at(:title, :author_name)
|
745
|
+
# => ["Budget", "Jason"]
|
667
746
|
```
|
668
747
|
|
669
|
-
|
748
|
+
Similar to `Hash#values_at` but on an Active Record instance.
|
670
749
|
|
671
|
-
*
|
750
|
+
*Guillaume Briday*
|
672
751
|
|
673
|
-
|
752
|
+
* Fix `read_attribute_before_type_cast` to consider attribute aliases.
|
753
|
+
|
754
|
+
*Marcelo Lauxen*
|
755
|
+
|
756
|
+
* Support passing record to uniqueness validator `:conditions` callable:
|
674
757
|
|
758
|
+
```ruby
|
759
|
+
class Article < ApplicationRecord
|
760
|
+
validates_uniqueness_of :title, conditions: ->(article) {
|
761
|
+
published_at = article.published_at
|
762
|
+
where(published_at: published_at.beginning_of_year..published_at.end_of_year)
|
763
|
+
}
|
764
|
+
end
|
675
765
|
```
|
676
|
-
|
677
|
-
|
766
|
+
|
767
|
+
*Eliot Sykes*
|
768
|
+
|
769
|
+
* `BatchEnumerator#update_all` and `BatchEnumerator#delete_all` now return the
|
770
|
+
total number of rows affected, just like their non-batched counterparts.
|
771
|
+
|
772
|
+
```ruby
|
773
|
+
Person.in_batches.update_all("first_name = 'Eugene'") # => 42
|
774
|
+
Person.in_batches.delete_all # => 42
|
678
775
|
```
|
679
776
|
|
680
|
-
|
777
|
+
Fixes #40287.
|
681
778
|
|
682
|
-
*
|
779
|
+
*Eugene Kenny*
|
683
780
|
|
684
|
-
*
|
781
|
+
* Add support for PostgreSQL `interval` data type with conversion to
|
782
|
+
`ActiveSupport::Duration` when loading records from database and
|
783
|
+
serialization to ISO 8601 formatted duration string on save.
|
784
|
+
Add support to define a column in migrations and get it in a schema dump.
|
785
|
+
Optional column precision is supported.
|
685
786
|
|
686
|
-
|
687
|
-
which can be specified within individual statements.
|
787
|
+
To use this in 6.1, you need to place the next string to your model file:
|
688
788
|
|
689
|
-
|
789
|
+
attribute :duration, :interval
|
690
790
|
|
691
|
-
|
692
|
-
# SELECT /*+ MAX_EXECUTION_TIME(50000) NO_INDEX_MERGE(topics) */ `topics`.* FROM `topics`
|
791
|
+
To keep old behavior until 7.0 is released:
|
693
792
|
|
694
|
-
|
793
|
+
attribute :duration, :string
|
695
794
|
|
696
|
-
|
697
|
-
# SELECT /*+ SeqScan(topics) Parallel(topics 8) */ "topics".* FROM "topics"
|
795
|
+
Example:
|
698
796
|
|
699
|
-
|
797
|
+
create_table :events do |t|
|
798
|
+
t.string :name
|
799
|
+
t.interval :duration
|
800
|
+
end
|
700
801
|
|
701
|
-
|
702
|
-
|
703
|
-
|
704
|
-
* https://docs.microsoft.com/en-us/sql/t-sql/queries/hints-transact-sql-query?view=sql-server-2017
|
705
|
-
* https://www.ibm.com/support/knowledgecenter/en/SSEPGG_11.1.0/com.ibm.db2.luw.admin.perf.doc/doc/c0070117.html
|
802
|
+
class Event < ApplicationRecord
|
803
|
+
attribute :duration, :interval
|
804
|
+
end
|
706
805
|
|
707
|
-
|
806
|
+
Event.create!(name: 'Rock Fest', duration: 2.days)
|
807
|
+
Event.last.duration # => 2 days
|
808
|
+
Event.last.duration.iso8601 # => "P2D"
|
809
|
+
Event.new(duration: 'P1DT12H3S').duration # => 1 day, 12 hours, and 3 seconds
|
810
|
+
Event.new(duration: '1 day') # Unknown value will be ignored and NULL will be written to database
|
708
811
|
|
709
|
-
*
|
812
|
+
*Andrey Novikov*
|
710
813
|
|
711
|
-
|
814
|
+
* Allow associations supporting the `dependent:` key to take `dependent: :destroy_async`.
|
712
815
|
|
713
|
-
```
|
714
|
-
class
|
715
|
-
|
816
|
+
```ruby
|
817
|
+
class Account < ActiveRecord::Base
|
818
|
+
belongs_to :supplier, dependent: :destroy_async
|
716
819
|
end
|
717
|
-
|
718
|
-
Post.new(user_defined_text: "false").user_defined_text? # => true
|
719
820
|
```
|
720
821
|
|
721
|
-
|
822
|
+
`:destroy_async` will enqueue a job to destroy associated records in the background.
|
722
823
|
|
723
|
-
*
|
824
|
+
*DHH*, *George Claghorn*, *Cory Gwin*, *Rafael Mendonça França*, *Adrianna Chang*
|
724
825
|
|
725
|
-
|
826
|
+
* Add `SKIP_TEST_DATABASE` environment variable to disable modifying the test database when `rails db:create` and `rails db:drop` are called.
|
726
827
|
|
727
|
-
*
|
728
|
-
allowing bulk inserts akin to the bulk updates provided by `update_all` and
|
729
|
-
bulk deletes by `delete_all`.
|
828
|
+
*Jason Schweier*
|
730
829
|
|
731
|
-
|
732
|
-
for PostgreSQL (9.5+) and SQLite (3.24+) and `ON DUPLICATE KEY UPDATE` syntax
|
733
|
-
for MySQL.
|
830
|
+
* `connects_to` can only be called on `ActiveRecord::Base` or abstract classes.
|
734
831
|
|
735
|
-
|
832
|
+
Ensure that `connects_to` can only be called from `ActiveRecord::Base` or abstract classes. This protects the application from opening duplicate or too many connections.
|
736
833
|
|
737
|
-
*
|
738
|
-
for current environment and loads the seeds.
|
834
|
+
*Eileen M. Uchitelle*, *John Crepezzi*
|
739
835
|
|
740
|
-
|
836
|
+
* All connection adapters `execute` now raises `ActiveRecord::ConnectionNotEstablished` rather than
|
837
|
+
`ActiveRecord::StatementInvalid` when they encounter a connection error.
|
741
838
|
|
742
|
-
*
|
839
|
+
*Jean Boussier*
|
743
840
|
|
744
|
-
|
841
|
+
* `Mysql2Adapter#quote_string` now raises `ActiveRecord::ConnectionNotEstablished` rather than
|
842
|
+
`ActiveRecord::StatementInvalid` when it can't connect to the MySQL server.
|
745
843
|
|
746
|
-
*
|
844
|
+
*Jean Boussier*
|
747
845
|
|
748
|
-
|
749
|
-
To continue case sensitive comparison on the case insensitive column,
|
750
|
-
pass `case_sensitive: true` option explicitly to the uniqueness validator.
|
846
|
+
* Add support for check constraints that are `NOT VALID` via `validate: false` (PostgreSQL-only).
|
751
847
|
|
752
|
-
*
|
848
|
+
*Alex Robbin*
|
753
849
|
|
754
|
-
*
|
850
|
+
* Ensure the default configuration is considered primary or first for an environment
|
755
851
|
|
756
|
-
|
852
|
+
If a multiple database application provides a configuration named primary, that will be treated as default. In applications that do not have a primary entry, the default database configuration will be the first configuration for an environment.
|
757
853
|
|
758
|
-
*
|
854
|
+
*Eileen M. Uchitelle*
|
759
855
|
|
760
|
-
*
|
856
|
+
* Allow `where` references association names as joined table name aliases.
|
761
857
|
|
762
|
-
|
858
|
+
```ruby
|
859
|
+
class Comment < ActiveRecord::Base
|
860
|
+
enum label: [:default, :child]
|
861
|
+
has_many :children, class_name: "Comment", foreign_key: :parent_id
|
862
|
+
end
|
763
863
|
|
764
|
-
|
765
|
-
|
766
|
-
|
864
|
+
# ... FROM comments LEFT OUTER JOIN comments children ON ... WHERE children.label = 1
|
865
|
+
Comment.includes(:children).where("children.label": "child")
|
866
|
+
```
|
867
|
+
|
868
|
+
*Ryuta Kamizono*
|
767
869
|
|
768
|
-
|
769
|
-
Post.not_active # => where.not(status: :active)
|
770
|
-
Post.not_trashed # => where.not(status: :trashed)
|
870
|
+
* Support storing demodulized class name for polymorphic type.
|
771
871
|
|
772
|
-
|
872
|
+
Before Rails 6.1, storing demodulized class name is supported only for STI type
|
873
|
+
by `store_full_sti_class` class attribute.
|
773
874
|
|
774
|
-
|
875
|
+
Now `store_full_class_name` class attribute can handle both STI and polymorphic types.
|
775
876
|
|
776
|
-
|
877
|
+
*Ryuta Kamizono*
|
777
878
|
|
778
|
-
|
879
|
+
* Deprecate `rails db:structure:{load, dump}` tasks and extend
|
880
|
+
`rails db:schema:{load, dump}` tasks to work with either `:ruby` or `:sql` format,
|
881
|
+
depending on `config.active_record.schema_format` configuration value.
|
779
882
|
|
883
|
+
*fatkodima*
|
780
884
|
|
781
|
-
|
885
|
+
* Respect the `select` values for eager loading.
|
782
886
|
|
783
|
-
|
887
|
+
```ruby
|
888
|
+
post = Post.select("UPPER(title) AS title").first
|
889
|
+
post.title # => "WELCOME TO THE WEBLOG"
|
890
|
+
post.body # => ActiveModel::MissingAttributeError
|
891
|
+
|
892
|
+
# Rails 6.0 (ignore the `select` values)
|
893
|
+
post = Post.select("UPPER(title) AS title").eager_load(:comments).first
|
894
|
+
post.title # => "Welcome to the weblog"
|
895
|
+
post.body # => "Such a lovely day"
|
896
|
+
|
897
|
+
# Rails 6.1 (respect the `select` values)
|
898
|
+
post = Post.select("UPPER(title) AS title").eager_load(:comments).first
|
899
|
+
post.title # => "WELCOME TO THE WEBLOG"
|
900
|
+
post.body # => ActiveModel::MissingAttributeError
|
901
|
+
```
|
784
902
|
|
903
|
+
*Ryuta Kamizono*
|
785
904
|
|
786
|
-
|
905
|
+
* Allow attribute's default to be configured but keeping its own type.
|
787
906
|
|
788
|
-
|
907
|
+
```ruby
|
908
|
+
class Post < ActiveRecord::Base
|
909
|
+
attribute :written_at, default: -> { Time.now.utc }
|
910
|
+
end
|
911
|
+
|
912
|
+
# Rails 6.0
|
913
|
+
Post.type_for_attribute(:written_at) # => #<Type::Value ... precision: nil, ...>
|
914
|
+
|
915
|
+
# Rails 6.1
|
916
|
+
Post.type_for_attribute(:written_at) # => #<Type::DateTime ... precision: 6, ...>
|
917
|
+
```
|
789
918
|
|
790
919
|
*Ryuta Kamizono*
|
791
920
|
|
792
|
-
*
|
921
|
+
* Allow default to be configured for Enum.
|
922
|
+
|
923
|
+
```ruby
|
924
|
+
class Book < ActiveRecord::Base
|
925
|
+
enum status: [:proposed, :written, :published], _default: :published
|
926
|
+
end
|
927
|
+
|
928
|
+
Book.new.status # => "published"
|
929
|
+
```
|
793
930
|
|
794
931
|
*Ryuta Kamizono*
|
795
932
|
|
796
|
-
*
|
933
|
+
* Deprecate YAML loading from legacy format older than Rails 5.0.
|
797
934
|
|
798
935
|
*Ryuta Kamizono*
|
799
936
|
|
800
|
-
*
|
937
|
+
* Added the setting `ActiveRecord::Base.immutable_strings_by_default`, which
|
938
|
+
allows you to specify that all string columns should be frozen unless
|
939
|
+
otherwise specified. This will reduce memory pressure for applications which
|
940
|
+
do not generally mutate string properties of Active Record objects.
|
801
941
|
|
802
|
-
|
803
|
-
`destroy_all` on the matched records.
|
942
|
+
*Sean Griffin*, *Ryuta Kamizono*
|
804
943
|
|
805
|
-
|
944
|
+
* Deprecate `map!` and `collect!` on `ActiveRecord::Result`.
|
806
945
|
|
807
|
-
|
808
|
-
Person.destroy_by(name: 'David', rating: 4)
|
946
|
+
*Ryuta Kamizono*
|
809
947
|
|
810
|
-
|
811
|
-
david.posts.destroy_by(id: [1, 2, 3])
|
948
|
+
* Support `relation.and` for intersection as Set theory.
|
812
949
|
|
813
|
-
|
814
|
-
|
950
|
+
```ruby
|
951
|
+
david_and_mary = Author.where(id: [david, mary])
|
952
|
+
mary_and_bob = Author.where(id: [mary, bob])
|
815
953
|
|
816
|
-
|
954
|
+
david_and_mary.merge(mary_and_bob) # => [mary, bob]
|
817
955
|
|
818
|
-
|
819
|
-
|
956
|
+
david_and_mary.and(mary_and_bob) # => [mary]
|
957
|
+
david_and_mary.or(mary_and_bob) # => [david, mary, bob]
|
958
|
+
```
|
820
959
|
|
821
|
-
|
822
|
-
david.posts.delete_by(id: [1, 2, 3])
|
960
|
+
*Ryuta Kamizono*
|
823
961
|
|
824
|
-
|
962
|
+
* Merging conditions on the same column no longer maintain both conditions,
|
963
|
+
and will be consistently replaced by the latter condition in Rails 7.0.
|
964
|
+
To migrate to Rails 7.0's behavior, use `relation.merge(other, rewhere: true)`.
|
825
965
|
|
826
|
-
|
966
|
+
```ruby
|
967
|
+
# Rails 6.1 (IN clause is replaced by merger side equality condition)
|
968
|
+
Author.where(id: [david.id, mary.id]).merge(Author.where(id: bob)) # => [bob]
|
827
969
|
|
828
|
-
|
970
|
+
# Rails 6.1 (both conflict conditions exists, deprecated)
|
971
|
+
Author.where(id: david.id..mary.id).merge(Author.where(id: bob)) # => []
|
829
972
|
|
830
|
-
|
973
|
+
# Rails 6.1 with rewhere to migrate to Rails 7.0's behavior
|
974
|
+
Author.where(id: david.id..mary.id).merge(Author.where(id: bob), rewhere: true) # => [bob]
|
831
975
|
|
832
|
-
|
976
|
+
# Rails 7.0 (same behavior with IN clause, mergee side condition is consistently replaced)
|
977
|
+
Author.where(id: [david.id, mary.id]).merge(Author.where(id: bob)) # => [bob]
|
978
|
+
Author.where(id: david.id..mary.id).merge(Author.where(id: bob)) # => [bob]
|
979
|
+
```
|
833
980
|
|
834
981
|
*Ryuta Kamizono*
|
835
982
|
|
836
|
-
*
|
837
|
-
regarded as leaked. Use `klass.unscoped` to avoid the leaking scope.
|
983
|
+
* Do not mark Postgresql MAC address and UUID attributes as changed when the assigned value only varies by case.
|
838
984
|
|
839
|
-
*
|
985
|
+
*Peter Fry*
|
840
986
|
|
841
|
-
*
|
987
|
+
* Resolve issue with insert_all unique_by option when used with expression index.
|
842
988
|
|
843
|
-
|
844
|
-
|
845
|
-
|
989
|
+
When the `:unique_by` option of `ActiveRecord::Persistence.insert_all` and
|
990
|
+
`ActiveRecord::Persistence.upsert_all` was used with the name of an expression index, an error
|
991
|
+
was raised. Adding a guard around the formatting behavior for the `:unique_by` corrects this.
|
846
992
|
|
847
|
-
|
848
|
-
a write in the last 2 seconds, otherwise they will read from the primary.
|
849
|
-
Non-get requests will always write to the primary. The middleware accepts
|
850
|
-
an argument for a Resolver class and an Operations class where you are able
|
851
|
-
to change how the auto-switcher works to be most beneficial for your
|
852
|
-
application.
|
993
|
+
Usage:
|
853
994
|
|
854
|
-
|
855
|
-
|
995
|
+
```ruby
|
996
|
+
create_table :books, id: :integer, force: true do |t|
|
997
|
+
t.column :name, :string
|
998
|
+
t.index "lower(name)", unique: true
|
999
|
+
end
|
856
1000
|
|
1001
|
+
Book.insert_all [{ name: "MyTest" }], unique_by: :index_books_on_lower_name
|
857
1002
|
```
|
858
|
-
|
859
|
-
|
860
|
-
|
1003
|
+
|
1004
|
+
Fixes #39516.
|
1005
|
+
|
1006
|
+
*Austen Madden*
|
1007
|
+
|
1008
|
+
* Add basic support for CHECK constraints to database migrations.
|
1009
|
+
|
1010
|
+
Usage:
|
1011
|
+
|
1012
|
+
```ruby
|
1013
|
+
add_check_constraint :products, "price > 0", name: "price_check"
|
1014
|
+
remove_check_constraint :products, name: "price_check"
|
861
1015
|
```
|
862
1016
|
|
863
|
-
|
864
|
-
|
1017
|
+
*fatkodima*
|
1018
|
+
|
1019
|
+
* Add `ActiveRecord::Base.strict_loading_by_default` and `ActiveRecord::Base.strict_loading_by_default=`
|
1020
|
+
to enable/disable strict_loading mode by default for a model. The configuration's value is
|
1021
|
+
inheritable by subclasses, but they can override that value and it will not impact parent class.
|
865
1022
|
|
1023
|
+
Usage:
|
1024
|
+
|
1025
|
+
```ruby
|
1026
|
+
class Developer < ApplicationRecord
|
1027
|
+
self.strict_loading_by_default = true
|
1028
|
+
|
1029
|
+
has_many :projects
|
1030
|
+
end
|
1031
|
+
|
1032
|
+
dev = Developer.first
|
1033
|
+
dev.projects.first
|
1034
|
+
# => ActiveRecord::StrictLoadingViolationError Exception: Developer is marked as strict_loading and Project cannot be lazily loaded.
|
866
1035
|
```
|
867
|
-
|
868
|
-
|
869
|
-
|
1036
|
+
|
1037
|
+
*bogdanvlviv*
|
1038
|
+
|
1039
|
+
* Deprecate passing an Active Record object to `quote`/`type_cast` directly.
|
1040
|
+
|
1041
|
+
*Ryuta Kamizono*
|
1042
|
+
|
1043
|
+
* Default engine `ENGINE=InnoDB` is no longer dumped to make schema more agnostic.
|
1044
|
+
|
1045
|
+
Before:
|
1046
|
+
|
1047
|
+
```ruby
|
1048
|
+
create_table "accounts", options: "ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci", force: :cascade do |t|
|
1049
|
+
end
|
870
1050
|
```
|
871
1051
|
|
872
|
-
|
1052
|
+
After:
|
873
1053
|
|
874
|
-
|
1054
|
+
```ruby
|
1055
|
+
create_table "accounts", charset: "utf8mb4", collation: "utf8mb4_0900_ai_ci", force: :cascade do |t|
|
1056
|
+
end
|
1057
|
+
```
|
875
1058
|
|
876
1059
|
*Ryuta Kamizono*
|
877
1060
|
|
878
|
-
*
|
1061
|
+
* Added delegated type as an alternative to single-table inheritance for representing class hierarchies.
|
1062
|
+
See ActiveRecord::DelegatedType for the full description.
|
1063
|
+
|
1064
|
+
*DHH*
|
1065
|
+
|
1066
|
+
* Deprecate aggregations with group by duplicated fields.
|
1067
|
+
|
1068
|
+
To migrate to Rails 7.0's behavior, use `uniq!(:group)` to deduplicate group fields.
|
1069
|
+
|
1070
|
+
```ruby
|
1071
|
+
accounts = Account.group(:firm_id)
|
1072
|
+
|
1073
|
+
# duplicated group fields, deprecated.
|
1074
|
+
accounts.merge(accounts.where.not(credit_limit: nil)).sum(:credit_limit)
|
1075
|
+
# => {
|
1076
|
+
# [1, 1] => 50,
|
1077
|
+
# [2, 2] => 60
|
1078
|
+
# }
|
1079
|
+
|
1080
|
+
# use `uniq!(:group)` to deduplicate group fields.
|
1081
|
+
accounts.merge(accounts.where.not(credit_limit: nil)).uniq!(:group).sum(:credit_limit)
|
1082
|
+
# => {
|
1083
|
+
# 1 => 50,
|
1084
|
+
# 2 => 60
|
1085
|
+
# }
|
1086
|
+
```
|
879
1087
|
|
880
1088
|
*Ryuta Kamizono*
|
881
1089
|
|
1090
|
+
* Deprecate duplicated query annotations.
|
882
1091
|
|
883
|
-
|
1092
|
+
To migrate to Rails 7.0's behavior, use `uniq!(:annotate)` to deduplicate query annotations.
|
884
1093
|
|
885
|
-
|
1094
|
+
```ruby
|
1095
|
+
accounts = Account.where(id: [1, 2]).annotate("david and mary")
|
886
1096
|
|
887
|
-
|
1097
|
+
# duplicated annotations, deprecated.
|
1098
|
+
accounts.merge(accounts.rewhere(id: 3))
|
1099
|
+
# SELECT accounts.* FROM accounts WHERE accounts.id = 3 /* david and mary */ /* david and mary */
|
888
1100
|
|
889
|
-
|
1101
|
+
# use `uniq!(:annotate)` to deduplicate annotations.
|
1102
|
+
accounts.merge(accounts.rewhere(id: 3)).uniq!(:annotate)
|
1103
|
+
# SELECT accounts.* FROM accounts WHERE accounts.id = 3 /* david and mary */
|
1104
|
+
```
|
890
1105
|
|
891
|
-
*
|
1106
|
+
*Ryuta Kamizono*
|
892
1107
|
|
893
|
-
*
|
1108
|
+
* Resolve conflict between counter cache and optimistic locking.
|
894
1109
|
|
895
|
-
|
1110
|
+
Bump an Active Record instance's lock version after updating its counter
|
1111
|
+
cache. This avoids raising an unnecessary `ActiveRecord::StaleObjectError`
|
1112
|
+
upon subsequent transactions by maintaining parity with the corresponding
|
1113
|
+
database record's `lock_version` column.
|
896
1114
|
|
897
|
-
|
1115
|
+
Fixes #16449.
|
898
1116
|
|
899
|
-
*
|
1117
|
+
*Aaron Lipman*
|
900
1118
|
|
901
|
-
*
|
1119
|
+
* Support merging option `:rewhere` to allow mergee side condition to be replaced exactly.
|
902
1120
|
|
903
|
-
|
1121
|
+
```ruby
|
1122
|
+
david_and_mary = Author.where(id: david.id..mary.id)
|
904
1123
|
|
905
|
-
|
1124
|
+
# both conflict conditions exists
|
1125
|
+
david_and_mary.merge(Author.where(id: bob)) # => []
|
906
1126
|
|
907
|
-
|
1127
|
+
# mergee side condition is replaced by rewhere
|
1128
|
+
david_and_mary.merge(Author.rewhere(id: bob)) # => [bob]
|
908
1129
|
|
909
|
-
|
1130
|
+
# mergee side condition is replaced by rewhere option
|
1131
|
+
david_and_mary.merge(Author.where(id: bob), rewhere: true) # => [bob]
|
1132
|
+
```
|
910
1133
|
|
911
|
-
*
|
1134
|
+
*Ryuta Kamizono*
|
912
1135
|
|
913
|
-
*
|
1136
|
+
* Add support for finding records based on signed ids, which are tamper-proof, verified ids that can be
|
1137
|
+
set to expire and scoped with a purpose. This is particularly useful for things like password reset
|
1138
|
+
or email verification, where you want the bearer of the signed id to be able to interact with the
|
1139
|
+
underlying record, but usually only within a certain time period.
|
914
1140
|
|
915
|
-
|
1141
|
+
```ruby
|
1142
|
+
signed_id = User.first.signed_id expires_in: 15.minutes, purpose: :password_reset
|
916
1143
|
|
917
|
-
|
1144
|
+
User.find_signed signed_id # => nil, since the purpose does not match
|
918
1145
|
|
919
|
-
|
1146
|
+
travel 16.minutes
|
1147
|
+
User.find_signed signed_id, purpose: :password_reset # => nil, since the signed id has expired
|
920
1148
|
|
921
|
-
|
1149
|
+
travel_back
|
1150
|
+
User.find_signed signed_id, purpose: :password_reset # => User.first
|
922
1151
|
|
923
|
-
|
1152
|
+
User.find_signed! "bad data" # => ActiveSupport::MessageVerifier::InvalidSignature
|
1153
|
+
```
|
924
1154
|
|
925
|
-
*
|
1155
|
+
*DHH*
|
926
1156
|
|
927
|
-
|
1157
|
+
* Support `ALGORITHM = INSTANT` DDL option for index operations on MySQL.
|
928
1158
|
|
929
|
-
*
|
1159
|
+
*Ryuta Kamizono*
|
930
1160
|
|
931
|
-
|
1161
|
+
* Fix index creation to preserve index comment in bulk change table on MySQL.
|
932
1162
|
|
933
|
-
*
|
1163
|
+
*Ryuta Kamizono*
|
934
1164
|
|
935
|
-
|
1165
|
+
* Allow `unscope` to be aware of table name qualified values.
|
936
1166
|
|
937
|
-
|
1167
|
+
It is possible to unscope only the column in the specified table.
|
938
1168
|
|
939
|
-
|
1169
|
+
```ruby
|
1170
|
+
posts = Post.joins(:comments).group(:"posts.hidden")
|
1171
|
+
posts = posts.where("posts.hidden": false, "comments.hidden": false)
|
940
1172
|
|
941
|
-
|
1173
|
+
posts.count
|
1174
|
+
# => { false => 10 }
|
942
1175
|
|
943
|
-
|
1176
|
+
# unscope both hidden columns
|
1177
|
+
posts.unscope(where: :hidden).count
|
1178
|
+
# => { false => 11, true => 1 }
|
944
1179
|
|
945
|
-
|
1180
|
+
# unscope only comments.hidden column
|
1181
|
+
posts.unscope(where: :"comments.hidden").count
|
1182
|
+
# => { false => 11 }
|
1183
|
+
```
|
946
1184
|
|
947
|
-
*
|
1185
|
+
*Ryuta Kamizono*, *Slava Korolev*
|
948
1186
|
|
949
|
-
|
1187
|
+
* Fix `rewhere` to truly overwrite collided where clause by new where clause.
|
950
1188
|
|
951
|
-
|
1189
|
+
```ruby
|
1190
|
+
steve = Person.find_by(name: "Steve")
|
1191
|
+
david = Author.find_by(name: "David")
|
952
1192
|
|
953
|
-
|
1193
|
+
relation = Essay.where(writer: steve)
|
954
1194
|
|
955
|
-
|
1195
|
+
# Before
|
1196
|
+
relation.rewhere(writer: david).to_a # => []
|
956
1197
|
|
957
|
-
|
958
|
-
|
959
|
-
|
1198
|
+
# After
|
1199
|
+
relation.rewhere(writer: david).to_a # => [david]
|
1200
|
+
```
|
960
1201
|
|
961
1202
|
*Ryuta Kamizono*
|
962
1203
|
|
963
|
-
*
|
1204
|
+
* Inspect time attributes with subsec and time zone offset.
|
964
1205
|
|
965
|
-
|
1206
|
+
```ruby
|
1207
|
+
p Knot.create
|
1208
|
+
=> #<Knot id: 1, created_at: "2016-05-05 01:29:47.116928000 +0000">
|
1209
|
+
```
|
966
1210
|
|
967
|
-
*
|
1211
|
+
*akinomaeni*, *Jonathan Hefner*
|
968
1212
|
|
969
|
-
|
1213
|
+
* Deprecate passing a column to `type_cast`.
|
1214
|
+
|
1215
|
+
*Ryuta Kamizono*
|
970
1216
|
|
971
|
-
*
|
1217
|
+
* Deprecate `in_clause_length` and `allowed_index_name_length` in `DatabaseLimits`.
|
972
1218
|
|
973
1219
|
*Ryuta Kamizono*
|
974
1220
|
|
975
|
-
*
|
1221
|
+
* Support bulk insert/upsert on relation to preserve scope values.
|
976
1222
|
|
977
|
-
*
|
1223
|
+
*Josef Šimánek*, *Ryuta Kamizono*
|
978
1224
|
|
979
|
-
*
|
1225
|
+
* Preserve column comment value on changing column name on MySQL.
|
980
1226
|
|
981
|
-
|
982
|
-
you're building out multiple databases and want to make sure you're not sending
|
983
|
-
writes when you want a read.
|
1227
|
+
*Islam Taha*
|
984
1228
|
|
985
|
-
|
986
|
-
query the database will raise an exception regardless of whether the database
|
987
|
-
user is able to write.
|
1229
|
+
* Add support for `if_exists` option for removing an index.
|
988
1230
|
|
989
|
-
|
990
|
-
read-only queries without opening a second connection. One purpose of this is to
|
991
|
-
catch accidental writes, not all writes.
|
1231
|
+
The `remove_index` method can take an `if_exists` option. If this is set to true an error won't be raised if the index doesn't exist.
|
992
1232
|
|
993
1233
|
*Eileen M. Uchitelle*
|
994
1234
|
|
995
|
-
*
|
1235
|
+
* Remove ibm_db, informix, mssql, oracle, and oracle12 Arel visitors which are not used in the code base.
|
996
1236
|
|
997
|
-
*
|
1237
|
+
*Ryuta Kamizono*
|
998
1238
|
|
999
|
-
*
|
1239
|
+
* Prevent `build_association` from `touching` a parent record if the record isn't persisted for `has_one` associations.
|
1000
1240
|
|
1001
|
-
Fixes
|
1241
|
+
Fixes #38219.
|
1002
1242
|
|
1003
|
-
*
|
1243
|
+
*Josh Brody*
|
1244
|
+
|
1245
|
+
* Add support for `if_not_exists` option for adding index.
|
1004
1246
|
|
1005
|
-
|
1247
|
+
The `add_index` method respects `if_not_exists` option. If it is set to true
|
1248
|
+
index won't be added.
|
1006
1249
|
|
1007
|
-
|
1008
|
-
was passing for SQLite and MySQL, but failed for PostgreSQL:
|
1250
|
+
Usage:
|
1009
1251
|
|
1010
1252
|
```ruby
|
1011
|
-
|
1012
|
-
|
1013
|
-
"Developer: #{value}"
|
1014
|
-
end
|
1015
|
-
end
|
1253
|
+
add_index :users, :account_id, if_not_exists: true
|
1254
|
+
```
|
1016
1255
|
|
1017
|
-
|
1018
|
-
|
1256
|
+
The `if_not_exists` option passed to `create_table` also gets propagated to indexes
|
1257
|
+
created within that migration so that if table and its indexes exist then there is no
|
1258
|
+
attempt to create them again.
|
1019
1259
|
|
1020
|
-
|
1260
|
+
*Prathamesh Sonpatki*
|
1021
1261
|
|
1022
|
-
|
1023
|
-
end
|
1262
|
+
* Add `ActiveRecord::Base#previously_new_record?` to show if a record was new before the last save.
|
1024
1263
|
|
1025
|
-
|
1026
|
-
developer.update_column :name, "name"
|
1264
|
+
*Tom Ward*
|
1027
1265
|
|
1028
|
-
|
1029
|
-
puts loaded_developer.name # should be "Developer: name" but it's just "name"
|
1030
|
-
```
|
1266
|
+
* Support descending order for `find_each`, `find_in_batches`, and `in_batches`.
|
1031
1267
|
|
1032
|
-
|
1268
|
+
Batch processing methods allow you to work with the records in batches, greatly reducing memory consumption, but records are always batched from oldest id to newest.
|
1033
1269
|
|
1034
|
-
|
1270
|
+
This change allows reversing the order, batching from newest to oldest. This is useful when you need to process newer batches of records first.
|
1035
1271
|
|
1036
|
-
|
1037
|
-
explicit order clause, ActiveRecord sorts records by primary key. This can
|
1038
|
-
result in unpredictable and surprising behaviour when the primary key is
|
1039
|
-
not an auto-incrementing integer, for example when it's a UUID. This change
|
1040
|
-
makes it possible to override the column used for implicit ordering such
|
1041
|
-
that `first` and `last` will return more predictable results.
|
1272
|
+
Pass `order: :desc` to yield batches in descending order. The default remains `order: :asc`.
|
1042
1273
|
|
1043
|
-
|
1274
|
+
```ruby
|
1275
|
+
Person.find_each(order: :desc) do |person|
|
1276
|
+
person.party_all_night!
|
1277
|
+
end
|
1278
|
+
```
|
1044
1279
|
|
1045
|
-
|
1046
|
-
self.implicit_order_column = "created_at"
|
1047
|
-
end
|
1280
|
+
*Alexey Vasiliev*
|
1048
1281
|
|
1049
|
-
|
1282
|
+
* Fix `insert_all` with enum values.
|
1050
1283
|
|
1051
|
-
|
1284
|
+
Fixes #38716.
|
1052
1285
|
|
1053
|
-
*
|
1286
|
+
*Joel Blum*
|
1054
1287
|
|
1055
|
-
*
|
1288
|
+
* Add support for `db:rollback:name` for multiple database applications.
|
1056
1289
|
|
1057
|
-
|
1290
|
+
Multiple database applications will now raise if `db:rollback` is call and recommend using the `db:rollback:[NAME]` to rollback migrations.
|
1058
1291
|
|
1059
|
-
*
|
1292
|
+
*Eileen M. Uchitelle*
|
1060
1293
|
|
1061
|
-
|
1294
|
+
* `Relation#pick` now uses already loaded results instead of making another query.
|
1062
1295
|
|
1063
|
-
|
1296
|
+
*Eugene Kenny*
|
1064
1297
|
|
1065
|
-
|
1298
|
+
* Deprecate using `return`, `break` or `throw` to exit a transaction block after writes.
|
1066
1299
|
|
1067
|
-
|
1300
|
+
*Dylan Thacker-Smith*
|
1068
1301
|
|
1069
|
-
|
1070
|
-
class MySubclassedError < ActiveRecord::StatementInvalid
|
1071
|
-
def initialize(message, sql:, binds:)
|
1072
|
-
super(message, sql: sql, binds: binds)
|
1073
|
-
end
|
1074
|
-
end
|
1075
|
-
```
|
1302
|
+
* Dump the schema or structure of a database when calling `db:migrate:name`.
|
1076
1303
|
|
1077
|
-
|
1304
|
+
In previous versions of Rails, `rails db:migrate` would dump the schema of the database. In Rails 6, that holds true (`rails db:migrate` dumps all databases' schemas), but `rails db:migrate:name` does not share that behavior.
|
1078
1305
|
|
1079
|
-
|
1306
|
+
Going forward, calls to `rails db:migrate:name` will dump the schema (or structure) of the database being migrated.
|
1080
1307
|
|
1081
|
-
|
1308
|
+
*Kyle Thompson*
|
1082
1309
|
|
1083
|
-
|
1084
|
-
t.string :title
|
1085
|
-
end
|
1310
|
+
* Reset the `ActiveRecord::Base` connection after `rails db:migrate:name`.
|
1086
1311
|
|
1087
|
-
|
1312
|
+
When `rails db:migrate` has finished, it ensures the `ActiveRecord::Base` connection is reset to its original configuration. Going forward, `rails db:migrate:name` will have the same behavior.
|
1088
1313
|
|
1089
|
-
|
1090
|
-
...
|
1091
|
-
)
|
1314
|
+
*Kyle Thompson*
|
1092
1315
|
|
1093
|
-
|
1094
|
-
exception whereas `if_not_exists: true` does nothing.
|
1316
|
+
* Disallow calling `connected_to` on subclasses of `ActiveRecord::Base`.
|
1095
1317
|
|
1096
|
-
|
1318
|
+
Behavior has not changed here but the previous API could be misleading to people who thought it would switch connections for only that class. `connected_to` switches the context from which we are getting connections, not the connections themselves.
|
1097
1319
|
|
1098
|
-
*
|
1320
|
+
*Eileen M. Uchitelle*, *John Crepezzi*
|
1099
1321
|
|
1100
|
-
|
1322
|
+
* Add support for horizontal sharding to `connects_to` and `connected_to`.
|
1101
1323
|
|
1102
|
-
|
1324
|
+
Applications can now connect to multiple shards and switch between their shards in an application. Note that the shard swapping is still a manual process as this change does not include an API for automatic shard swapping.
|
1103
1325
|
|
1104
|
-
|
1326
|
+
Usage:
|
1105
1327
|
|
1106
|
-
|
1107
|
-
if the attribute does not exist.
|
1328
|
+
Given the following configuration:
|
1108
1329
|
|
1109
|
-
|
1330
|
+
```yaml
|
1331
|
+
# config/database.yml
|
1332
|
+
production:
|
1333
|
+
primary:
|
1334
|
+
database: my_database
|
1335
|
+
primary_shard_one:
|
1336
|
+
database: my_database_shard_one
|
1337
|
+
```
|
1110
1338
|
|
1111
|
-
|
1339
|
+
Connect to multiple shards:
|
1112
1340
|
|
1113
|
-
|
1114
|
-
|
1115
|
-
|
1116
|
-
end
|
1341
|
+
```ruby
|
1342
|
+
class ApplicationRecord < ActiveRecord::Base
|
1343
|
+
self.abstract_class = true
|
1117
1344
|
|
1118
|
-
|
1119
|
-
|
1120
|
-
|
1121
|
-
|
1122
|
-
|
1345
|
+
connects_to shards: {
|
1346
|
+
default: { writing: :primary },
|
1347
|
+
shard_one: { writing: :primary_shard_one }
|
1348
|
+
}
|
1349
|
+
```
|
1123
1350
|
|
1124
|
-
|
1351
|
+
Swap between shards in your controller / model code:
|
1125
1352
|
|
1126
|
-
|
1353
|
+
```ruby
|
1354
|
+
ActiveRecord::Base.connected_to(shard: :shard_one) do
|
1355
|
+
# Read from shard one
|
1356
|
+
end
|
1357
|
+
```
|
1358
|
+
|
1359
|
+
The horizontal sharding API also supports read replicas. See guides for more details.
|
1127
1360
|
|
1128
|
-
|
1361
|
+
*Eileen M. Uchitelle*, *John Crepezzi*
|
1129
1362
|
|
1130
|
-
|
1363
|
+
* Deprecate `spec_name` in favor of `name` on database configurations.
|
1131
1364
|
|
1132
|
-
|
1365
|
+
The accessors for `spec_name` on `configs_for` and `DatabaseConfig` are deprecated. Please use `name` instead.
|
1133
1366
|
|
1134
|
-
|
1367
|
+
Deprecated behavior:
|
1135
1368
|
|
1136
|
-
|
1137
|
-
|
1369
|
+
```ruby
|
1370
|
+
db_config = ActiveRecord::Base.configurations.configs_for(env_name: "development", spec_name: "primary")
|
1371
|
+
db_config.spec_name
|
1372
|
+
```
|
1138
1373
|
|
1139
|
-
|
1374
|
+
New behavior:
|
1140
1375
|
|
1141
|
-
|
1376
|
+
```ruby
|
1377
|
+
db_config = ActiveRecord::Base.configurations.configs_for(env_name: "development", name: "primary")
|
1378
|
+
db_config.name
|
1379
|
+
```
|
1142
1380
|
|
1143
|
-
*
|
1381
|
+
*Eileen M. Uchitelle*
|
1144
1382
|
|
1145
|
-
|
1383
|
+
* Add additional database-specific rake tasks for multi-database users.
|
1146
1384
|
|
1147
|
-
|
1385
|
+
Previously, `rails db:create`, `rails db:drop`, and `rails db:migrate` were the only rails tasks that could operate on a single
|
1386
|
+
database. For example:
|
1148
1387
|
|
1149
|
-
|
1388
|
+
```
|
1389
|
+
rails db:create
|
1390
|
+
rails db:create:primary
|
1391
|
+
rails db:create:animals
|
1392
|
+
rails db:drop
|
1393
|
+
rails db:drop:primary
|
1394
|
+
rails db:drop:animals
|
1395
|
+
rails db:migrate
|
1396
|
+
rails db:migrate:primary
|
1397
|
+
rails db:migrate:animals
|
1398
|
+
```
|
1150
1399
|
|
1151
|
-
|
1400
|
+
With these changes, `rails db:schema:dump`, `rails db:schema:load`, `rails db:structure:dump`, `rails db:structure:load` and
|
1401
|
+
`rails db:test:prepare` can additionally operate on a single database. For example:
|
1152
1402
|
|
1153
1403
|
```
|
1154
|
-
|
1155
|
-
|
1404
|
+
rails db:schema:dump
|
1405
|
+
rails db:schema:dump:primary
|
1406
|
+
rails db:schema:dump:animals
|
1407
|
+
rails db:schema:load
|
1408
|
+
rails db:schema:load:primary
|
1409
|
+
rails db:schema:load:animals
|
1410
|
+
rails db:structure:dump
|
1411
|
+
rails db:structure:dump:primary
|
1412
|
+
rails db:structure:dump:animals
|
1413
|
+
rails db:structure:load
|
1414
|
+
rails db:structure:load:primary
|
1415
|
+
rails db:structure:load:animals
|
1416
|
+
rails db:test:prepare
|
1417
|
+
rails db:test:prepare:primary
|
1418
|
+
rails db:test:prepare:animals
|
1419
|
+
```
|
1156
1420
|
|
1157
|
-
|
1158
|
-
|
1421
|
+
*Kyle Thompson*
|
1422
|
+
|
1423
|
+
* Add support for `strict_loading` mode on association declarations.
|
1424
|
+
|
1425
|
+
Raise an error if attempting to load a record from an association that has been marked as `strict_loading` unless it was explicitly eager loaded.
|
1426
|
+
|
1427
|
+
Usage:
|
1159
1428
|
|
1160
|
-
|
1161
|
-
|
1429
|
+
```ruby
|
1430
|
+
class Developer < ApplicationRecord
|
1431
|
+
has_many :projects, strict_loading: true
|
1162
1432
|
end
|
1433
|
+
|
1434
|
+
dev = Developer.first
|
1435
|
+
dev.projects.first
|
1436
|
+
# => ActiveRecord::StrictLoadingViolationError: The projects association is marked as strict_loading and cannot be lazily loaded.
|
1163
1437
|
```
|
1164
1438
|
|
1165
|
-
|
1166
|
-
|
1167
|
-
|
1168
|
-
|
1439
|
+
*Kevin Deisz*
|
1440
|
+
|
1441
|
+
* Add support for `strict_loading` mode to prevent lazy loading of records.
|
1442
|
+
|
1443
|
+
Raise an error if a parent record is marked as `strict_loading` and attempts to lazily load its associations. This is useful for finding places you may want to preload an association and avoid additional queries.
|
1444
|
+
|
1445
|
+
Usage:
|
1169
1446
|
|
1447
|
+
```ruby
|
1448
|
+
dev = Developer.strict_loading.first
|
1449
|
+
dev.audit_logs.to_a
|
1450
|
+
# => ActiveRecord::StrictLoadingViolationError: Developer is marked as strict_loading and AuditLog cannot be lazily loaded.
|
1170
1451
|
```
|
1171
|
-
|
1172
|
-
|
1173
|
-
|
1452
|
+
|
1453
|
+
*Eileen M. Uchitelle*, *Aaron Patterson*
|
1454
|
+
|
1455
|
+
* Add support for PostgreSQL 11+ partitioned indexes when using `upsert_all`.
|
1456
|
+
|
1457
|
+
*Sebastián Palma*
|
1458
|
+
|
1459
|
+
* Adds support for `if_not_exists` to `add_column` and `if_exists` to `remove_column`.
|
1460
|
+
|
1461
|
+
Applications can set their migrations to ignore exceptions raised when adding a column that already exists or when removing a column that does not exist.
|
1462
|
+
|
1463
|
+
Example Usage:
|
1464
|
+
|
1465
|
+
```ruby
|
1466
|
+
class AddColumnTitle < ActiveRecord::Migration[6.1]
|
1467
|
+
def change
|
1468
|
+
add_column :posts, :title, :string, if_not_exists: true
|
1469
|
+
end
|
1174
1470
|
end
|
1175
1471
|
```
|
1176
1472
|
|
1177
|
-
```
|
1178
|
-
ActiveRecord::
|
1179
|
-
|
1473
|
+
```ruby
|
1474
|
+
class RemoveColumnTitle < ActiveRecord::Migration[6.1]
|
1475
|
+
def change
|
1476
|
+
remove_column :posts, :title, if_exists: true
|
1477
|
+
end
|
1180
1478
|
end
|
1181
1479
|
```
|
1182
1480
|
|
1183
1481
|
*Eileen M. Uchitelle*
|
1184
1482
|
|
1185
|
-
*
|
1483
|
+
* Regexp-escape table name for MS SQL Server.
|
1186
1484
|
|
1187
|
-
|
1188
|
-
commit checks that only valid definition values are provided, those can
|
1189
|
-
be a Hash, an array of Symbols or an array of Strings. Otherwise it
|
1190
|
-
raises an `ArgumentError`.
|
1485
|
+
Add `Regexp.escape` to one method in ActiveRecord, so that table names with regular expression characters in them work as expected. Since MS SQL Server uses "[" and "]" to quote table and column names, and those characters are regular expression characters, methods like `pluck` and `select` fail in certain cases when used with the MS SQL Server adapter.
|
1191
1486
|
|
1192
|
-
|
1487
|
+
*Larry Reid*
|
1193
1488
|
|
1194
|
-
|
1489
|
+
* Store advisory locks on their own named connection.
|
1195
1490
|
|
1196
|
-
|
1491
|
+
Previously advisory locks were taken out against a connection when a migration started. This works fine in single database applications but doesn't work well when migrations need to open new connections which results in the lock getting dropped.
|
1197
1492
|
|
1198
|
-
|
1199
|
-
|
1200
|
-
|
1201
|
-
|
1202
|
-
|
1203
|
-
end
|
1493
|
+
In order to fix this we are storing the advisory lock on a new connection with the connection specification name `AdvisoryLockBase`. The caveat is that we need to maintain at least 2 connections to a database while migrations are running in order to do this.
|
1494
|
+
|
1495
|
+
*Eileen M. Uchitelle*, *John Crepezzi*
|
1496
|
+
|
1497
|
+
* Allow schema cache path to be defined in the database configuration file.
|
1204
1498
|
|
1205
|
-
|
1206
|
-
|
1207
|
-
|
1208
|
-
|
1499
|
+
For example:
|
1500
|
+
|
1501
|
+
```yaml
|
1502
|
+
development:
|
1503
|
+
adapter: postgresql
|
1504
|
+
database: blog_development
|
1505
|
+
pool: 5
|
1506
|
+
schema_cache_path: tmp/schema/main.yml
|
1209
1507
|
```
|
1210
1508
|
|
1211
|
-
*
|
1509
|
+
*Katrina Owen*
|
1212
1510
|
|
1213
|
-
*
|
1214
|
-
With this change you can create indexes while adding new
|
1215
|
-
columns into the existing tables.
|
1511
|
+
* Deprecate `#remove_connection` in favor of `#remove_connection_pool` when called on the handler.
|
1216
1512
|
|
1217
|
-
|
1513
|
+
`#remove_connection` is deprecated in order to support returning a `DatabaseConfig` object instead of a `Hash`. Use `#remove_connection_pool`, `#remove_connection` will be removed in Rails 7.0.
|
1218
1514
|
|
1219
|
-
|
1220
|
-
|
1221
|
-
|
1515
|
+
*Eileen M. Uchitelle*, *John Crepezzi*
|
1516
|
+
|
1517
|
+
* Deprecate `#default_hash` and it's alias `#[]` on database configurations.
|
1222
1518
|
|
1223
|
-
|
1519
|
+
Applications should use `configs_for`. `#default_hash` and `#[]` will be removed in Rails 7.0.
|
1224
1520
|
|
1225
|
-
*
|
1521
|
+
*Eileen M. Uchitelle*, *John Crepezzi*
|
1226
1522
|
|
1227
|
-
|
1228
|
-
Now: This change fixes that by reverting commands inside `transaction` block.
|
1523
|
+
* Add scale support to `ActiveRecord::Validations::NumericalityValidator`.
|
1229
1524
|
|
1230
|
-
*
|
1525
|
+
*Gannon McGibbon*
|
1231
1526
|
|
1232
|
-
*
|
1527
|
+
* Find orphans by looking for missing relations through chaining `where.missing`:
|
1233
1528
|
|
1234
|
-
|
1529
|
+
Before:
|
1530
|
+
|
1531
|
+
```ruby
|
1532
|
+
Post.left_joins(:author).where(authors: { id: nil })
|
1533
|
+
```
|
1534
|
+
|
1535
|
+
After:
|
1536
|
+
|
1537
|
+
```ruby
|
1538
|
+
Post.where.missing(:author)
|
1539
|
+
```
|
1235
1540
|
|
1236
|
-
*
|
1541
|
+
*Tom Rossi*
|
1542
|
+
|
1543
|
+
* Ensure `:reading` connections always raise if a write is attempted.
|
1544
|
+
|
1545
|
+
Now Rails will raise an `ActiveRecord::ReadOnlyError` if any connection on the reading handler attempts to make a write. If your reading role needs to write you should name the role something other than `:reading`.
|
1546
|
+
|
1547
|
+
*Eileen M. Uchitelle*
|
1548
|
+
|
1549
|
+
* Deprecate `"primary"` as the `connection_specification_name` for `ActiveRecord::Base`.
|
1550
|
+
|
1551
|
+
`"primary"` has been deprecated as the `connection_specification_name` for `ActiveRecord::Base` in favor of using `"ActiveRecord::Base"`. This change affects calls to `ActiveRecord::Base.connection_handler.retrieve_connection` and `ActiveRecord::Base.connection_handler.remove_connection`. If you're calling these methods with `"primary"`, please switch to `"ActiveRecord::Base"`.
|
1552
|
+
|
1553
|
+
*Eileen M. Uchitelle*, *John Crepezzi*
|
1554
|
+
|
1555
|
+
* Add `ActiveRecord::Validations::NumericalityValidator` with
|
1556
|
+
support for casting floats using a database columns' precision value.
|
1237
1557
|
|
1238
1558
|
*Gannon McGibbon*
|
1239
1559
|
|
1240
|
-
*
|
1560
|
+
* Enforce fresh ETag header after a collection's contents change by adding
|
1561
|
+
ActiveRecord::Relation#cache_key_with_version. This method will be used by
|
1562
|
+
ActionController::ConditionalGet to ensure that when collection cache versioning
|
1563
|
+
is enabled, requests using ConditionalGet don't return the same ETag header
|
1564
|
+
after a collection is modified.
|
1241
1565
|
|
1242
|
-
Fixes #
|
1566
|
+
Fixes #38078.
|
1243
1567
|
|
1244
|
-
*
|
1568
|
+
*Aaron Lipman*
|
1569
|
+
|
1570
|
+
* Skip test database when running `db:create` or `db:drop` in development
|
1571
|
+
with `DATABASE_URL` set.
|
1572
|
+
|
1573
|
+
*Brian Buchalter*
|
1245
1574
|
|
1246
|
-
*
|
1575
|
+
* Don't allow mutations on the database configurations hash.
|
1247
1576
|
|
1248
|
-
|
1577
|
+
Freeze the configurations hash to disallow directly changing it. If applications need to change the hash, for example to create databases for parallelization, they should use the `DatabaseConfig` object directly.
|
1249
1578
|
|
1250
|
-
|
1579
|
+
Before:
|
1251
1580
|
|
1581
|
+
```ruby
|
1582
|
+
@db_config = ActiveRecord::Base.configurations.configs_for(env_name: "test", spec_name: "primary")
|
1583
|
+
@db_config.configuration_hash.merge!(idle_timeout: "0.02")
|
1252
1584
|
```
|
1253
|
-
create_table :users do |t|
|
1254
|
-
t.string :email
|
1255
|
-
end
|
1256
1585
|
|
1257
|
-
|
1586
|
+
After:
|
1587
|
+
|
1588
|
+
```ruby
|
1589
|
+
@db_config = ActiveRecord::Base.configurations.configs_for(env_name: "test", spec_name: "primary")
|
1590
|
+
config = @db_config.configuration_hash.merge(idle_timeout: "0.02")
|
1591
|
+
db_config = ActiveRecord::DatabaseConfigurations::HashConfig.new(@db_config.env_name, @db_config.spec_name, config)
|
1258
1592
|
```
|
1259
1593
|
|
1260
|
-
*
|
1594
|
+
*Eileen M. Uchitelle*, *John Crepezzi*
|
1261
1595
|
|
1262
|
-
*
|
1596
|
+
* Remove `:connection_id` from the `sql.active_record` notification.
|
1263
1597
|
|
1264
|
-
|
1598
|
+
*Aaron Patterson*, *Rafael Mendonça França*
|
1265
1599
|
|
1266
|
-
|
1600
|
+
* The `:name` key will no longer be returned as part of `DatabaseConfig#configuration_hash`. Please use `DatabaseConfig#owner_name` instead.
|
1267
1601
|
|
1268
|
-
*
|
1602
|
+
*Eileen M. Uchitelle*, *John Crepezzi*
|
1269
1603
|
|
1270
|
-
|
1604
|
+
* ActiveRecord's `belongs_to_required_by_default` flag can now be set per model.
|
1271
1605
|
|
1272
|
-
|
1606
|
+
You can now opt-out/opt-in specific models from having their associations required
|
1607
|
+
by default.
|
1273
1608
|
|
1274
|
-
|
1275
|
-
|
1609
|
+
This change is meant to ease the process of migrating all your models to have
|
1610
|
+
their association required.
|
1276
1611
|
|
1277
|
-
*
|
1612
|
+
*Edouard Chin*
|
1278
1613
|
|
1279
|
-
*
|
1614
|
+
* The `connection_config` method has been deprecated, please use `connection_db_config` instead which will return a `DatabaseConfigurations::DatabaseConfig` instead of a `Hash`.
|
1280
1615
|
|
1281
|
-
*
|
1616
|
+
*Eileen M. Uchitelle*, *John Crepezzi*
|
1282
1617
|
|
1283
|
-
*
|
1284
|
-
sensitive values of database columns when calling `#inspect`.
|
1285
|
-
We also added `ActiveRecord::Base::filter_attributes`/`=` in order to
|
1286
|
-
specify sensitive attributes to specific model.
|
1618
|
+
* Retain explicit selections on the base model after applying `includes` and `joins`.
|
1287
1619
|
|
1288
|
-
|
1289
|
-
Rails.application.config.filter_parameters += [:credit_card_number, /phone/]
|
1290
|
-
Account.last.inspect # => #<Account id: 123, name: "DHH", credit_card_number: [FILTERED], telephone_number: [FILTERED] ...>
|
1291
|
-
SecureAccount.filter_attributes += [:name]
|
1292
|
-
SecureAccount.last.inspect # => #<SecureAccount id: 42, name: [FILTERED], credit_card_number: [FILTERED] ...>
|
1293
|
-
```
|
1620
|
+
Resolves #34889.
|
1294
1621
|
|
1295
|
-
*
|
1622
|
+
*Patrick Rebsch*
|
1296
1623
|
|
1297
|
-
*
|
1298
|
-
`indexes_per_table`, `columns_per_multicolumn_index`, `sql_query_length`,
|
1299
|
-
and `joins_per_query` methods in `DatabaseLimits`.
|
1624
|
+
* The `database` kwarg is deprecated without replacement because it can't be used for sharding and creates an issue if it's used during a request. Applications that need to create new connections should use `connects_to` instead.
|
1300
1625
|
|
1301
|
-
*
|
1626
|
+
*Eileen M. Uchitelle*, *John Crepezzi*
|
1302
1627
|
|
1303
|
-
*
|
1628
|
+
* Allow attributes to be fetched from Arel node groupings.
|
1304
1629
|
|
1305
|
-
|
1306
|
-
is an inflexible data model. In order to improve multiple-database
|
1307
|
-
handling in Rails, we've changed this to return an object. Some methods
|
1308
|
-
are provided to make the object behave hash-like in order to ease the
|
1309
|
-
transition process. Since most applications don't manipulate the hash
|
1310
|
-
we've decided to add backwards-compatible functionality that will throw
|
1311
|
-
a deprecation warning if used, however calling `ActiveRecord::Base.configurations`
|
1312
|
-
will use the new version internally and externally.
|
1630
|
+
*Jeff Emminger*, *Gannon McGibbon*
|
1313
1631
|
|
1314
|
-
|
1632
|
+
* A database URL can now contain a querystring value that contains an equal sign. This is needed to support passing PostgreSQL `options`.
|
1315
1633
|
|
1316
|
-
|
1317
|
-
development:
|
1318
|
-
adapter: sqlite3
|
1319
|
-
database: db/development.sqlite3
|
1320
|
-
```
|
1634
|
+
*Joshua Flanagan*
|
1321
1635
|
|
1322
|
-
|
1636
|
+
* Calling methods like `establish_connection` with a `Hash` which is invalid (eg: no `adapter`) will now raise an error the same way as connections defined in `config/database.yml`.
|
1323
1637
|
|
1324
|
-
|
1325
|
-
{ "development" => { "adapter" => "sqlite3", "database" => "db/development.sqlite3" } }
|
1326
|
-
```
|
1638
|
+
*John Crepezzi*
|
1327
1639
|
|
1328
|
-
|
1640
|
+
* Specifying `implicit_order_column` now subsorts the records by primary key if available to ensure deterministic results.
|
1329
1641
|
|
1330
|
-
|
1331
|
-
#<ActiveRecord::DatabaseConfigurations:0x00007fd1acbdf800 @configurations=[
|
1332
|
-
#<ActiveRecord::DatabaseConfigurations::HashConfig:0x00007fd1acbded10 @env_name="development",
|
1333
|
-
@spec_name="primary", @config={"adapter"=>"sqlite3", "database"=>"db/development.sqlite3"}>
|
1334
|
-
]
|
1335
|
-
```
|
1642
|
+
*Paweł Urbanek*
|
1336
1643
|
|
1337
|
-
|
1338
|
-
calling hash methods on the `configurations` hash directly, a new method `configs_for` has
|
1339
|
-
been provided that allows you to select the correct configuration. `env_name` and
|
1340
|
-
`spec_name` arguments are optional. For example, these return an array of
|
1341
|
-
database config objects for the requested environment and a single database config object
|
1342
|
-
will be returned for the requested environment and specification name respectively.
|
1644
|
+
* `where(attr => [])` now loads an empty result without making a query.
|
1343
1645
|
|
1344
|
-
|
1345
|
-
ActiveRecord::Base.configurations.configs_for(env_name: "development")
|
1346
|
-
ActiveRecord::Base.configurations.configs_for(env_name: "development", spec_name: "primary")
|
1347
|
-
```
|
1646
|
+
*John Hawthorn*
|
1348
1647
|
|
1349
|
-
|
1648
|
+
* Fixed the performance regression for `primary_keys` introduced MySQL 8.0.
|
1649
|
+
|
1650
|
+
*Hiroyuki Ishii*
|
1651
|
+
|
1652
|
+
* Add support for `belongs_to` to `has_many` inversing.
|
1350
1653
|
|
1351
|
-
*
|
1654
|
+
*Gannon McGibbon*
|
1655
|
+
|
1656
|
+
* Allow length configuration for `has_secure_token` method. The minimum length
|
1657
|
+
is set at 24 characters.
|
1658
|
+
|
1659
|
+
Before:
|
1352
1660
|
|
1661
|
+
```ruby
|
1662
|
+
has_secure_token :auth_token
|
1353
1663
|
```
|
1354
|
-
|
1355
|
-
|
1356
|
-
|
1664
|
+
|
1665
|
+
After:
|
1666
|
+
|
1667
|
+
```ruby
|
1668
|
+
has_secure_token :default_token # 24 characters
|
1669
|
+
has_secure_token :auth_token, length: 36 # 36 characters
|
1670
|
+
has_secure_token :invalid_token, length: 12 # => ActiveRecord::SecureToken::MinimumLengthError
|
1357
1671
|
```
|
1358
1672
|
|
1359
|
-
*
|
1673
|
+
*Bernardo de Araujo*
|
1360
1674
|
|
1361
|
-
*
|
1675
|
+
* Deprecate `DatabaseConfigurations#to_h`. These connection hashes are still available via `ActiveRecord::Base.configurations.configs_for`.
|
1362
1676
|
|
1363
|
-
*
|
1677
|
+
*Eileen Uchitelle*, *John Crepezzi*
|
1364
1678
|
|
1365
|
-
*
|
1679
|
+
* Add `DatabaseConfig#configuration_hash` to return database configuration hashes with symbol keys, and use all symbol-key configuration hashes internally. Deprecate `DatabaseConfig#config` which returns a String-keyed `Hash` with the same values.
|
1366
1680
|
|
1367
|
-
|
1681
|
+
*John Crepezzi*, *Eileen Uchitelle*
|
1368
1682
|
|
1369
|
-
|
1683
|
+
* Allow column names to be passed to `remove_index` positionally along with other options.
|
1370
1684
|
|
1371
|
-
|
1685
|
+
Passing other options can be necessary to make `remove_index` correctly reversible.
|
1372
1686
|
|
1373
|
-
|
1374
|
-
|
1687
|
+
Before:
|
1688
|
+
|
1689
|
+
add_index :reports, :report_id # => works
|
1690
|
+
add_index :reports, :report_id, unique: true # => works
|
1691
|
+
remove_index :reports, :report_id # => works
|
1692
|
+
remove_index :reports, :report_id, unique: true # => ArgumentError
|
1375
1693
|
|
1376
|
-
|
1694
|
+
After:
|
1377
1695
|
|
1378
|
-
|
1696
|
+
remove_index :reports, :report_id, unique: true # => works
|
1379
1697
|
|
1380
|
-
*
|
1698
|
+
*Eugene Kenny*
|
1381
1699
|
|
1382
|
-
*
|
1700
|
+
* Allow bulk `ALTER` statements to drop and recreate indexes with the same name.
|
1701
|
+
|
1702
|
+
*Eugene Kenny*
|
1703
|
+
|
1704
|
+
* `insert`, `insert_all`, `upsert`, and `upsert_all` now clear the query cache.
|
1705
|
+
|
1706
|
+
*Eugene Kenny*
|
1707
|
+
|
1708
|
+
* Call `while_preventing_writes` directly from `connected_to`.
|
1709
|
+
|
1710
|
+
In some cases application authors want to use the database switching middleware and make explicit calls with `connected_to`. It's possible for an app to turn off writes and not turn them back on by the time we call `connected_to(role: :writing)`.
|
1711
|
+
|
1712
|
+
This change allows apps to fix this by assuming if a role is writing we want to allow writes, except in the case it's explicitly turned off.
|
1713
|
+
|
1714
|
+
*Eileen M. Uchitelle*
|
1715
|
+
|
1716
|
+
* Improve detection of ActiveRecord::StatementTimeout with mysql2 adapter in the edge case when the query is terminated during filesort.
|
1717
|
+
|
1718
|
+
*Kir Shatrov*
|
1719
|
+
|
1720
|
+
* Stop trying to read yaml file fixtures when loading Active Record fixtures.
|
1721
|
+
|
1722
|
+
*Gannon McGibbon*
|
1723
|
+
|
1724
|
+
* Deprecate `.reorder(nil)` with `.first` / `.first!` taking non-deterministic result.
|
1725
|
+
|
1726
|
+
To continue taking non-deterministic result, use `.take` / `.take!` instead.
|
1383
1727
|
|
1384
1728
|
*Ryuta Kamizono*
|
1385
1729
|
|
1386
|
-
*
|
1730
|
+
* Preserve user supplied joins order as much as possible.
|
1387
1731
|
|
1388
|
-
Fixes #
|
1732
|
+
Fixes #36761, #34328, #24281, #12953.
|
1389
1733
|
|
1390
|
-
*
|
1734
|
+
*Ryuta Kamizono*
|
1391
1735
|
|
1392
|
-
*
|
1736
|
+
* Allow `matches_regex` and `does_not_match_regexp` on the MySQL Arel visitor.
|
1393
1737
|
|
1394
|
-
*
|
1738
|
+
*James Pearson*
|
1395
1739
|
|
1396
|
-
*
|
1740
|
+
* Allow specifying fixtures to be ignored by setting `ignore` in YAML file's '_fixture' section.
|
1397
1741
|
|
1398
|
-
|
1742
|
+
*Tongfei Gao*
|
1399
1743
|
|
1400
|
-
|
1744
|
+
* Make the DATABASE_URL env variable only affect the primary connection. Add new env variables for multiple databases.
|
1401
1745
|
|
1402
|
-
*
|
1746
|
+
*John Crepezzi*, *Eileen Uchitelle*
|
1403
1747
|
|
1404
|
-
|
1748
|
+
* Add a warning for enum elements with 'not_' prefix.
|
1405
1749
|
|
1406
|
-
|
1407
|
-
|
1750
|
+
class Foo
|
1751
|
+
enum status: [:sent, :not_sent]
|
1752
|
+
end
|
1408
1753
|
|
1409
|
-
*
|
1754
|
+
*Edu Depetris*
|
1410
1755
|
|
1411
|
-
*
|
1756
|
+
* Make currency symbols optional for money column type in PostgreSQL.
|
1412
1757
|
|
1413
|
-
*
|
1758
|
+
*Joel Schneider*
|
1414
1759
|
|
1415
|
-
* Add
|
1760
|
+
* Add support for beginless ranges, introduced in Ruby 2.7.
|
1416
1761
|
|
1417
|
-
|
1762
|
+
*Josh Goodall*
|
1418
1763
|
|
1419
|
-
|
1764
|
+
* Add `database_exists?` method to connection adapters to check if a database exists.
|
1420
1765
|
|
1421
|
-
*
|
1766
|
+
*Guilherme Mansur*
|
1422
1767
|
|
1423
|
-
*
|
1768
|
+
* Loading the schema for a model that has no `table_name` raises a `TableNotSpecified` error.
|
1424
1769
|
|
1425
|
-
*
|
1770
|
+
*Guilherme Mansur*, *Eugene Kenny*
|
1426
1771
|
|
1427
|
-
*
|
1772
|
+
* PostgreSQL: Fix GROUP BY with ORDER BY virtual count attribute.
|
1428
1773
|
|
1429
|
-
|
1774
|
+
Fixes #36022.
|
1430
1775
|
|
1431
|
-
*
|
1776
|
+
*Ryuta Kamizono*
|
1432
1777
|
|
1433
|
-
|
1778
|
+
* Make ActiveRecord `ConnectionPool.connections` method thread-safe.
|
1434
1779
|
|
1435
|
-
|
1780
|
+
Fixes #36465.
|
1436
1781
|
|
1437
|
-
*
|
1782
|
+
*Jeff Doering*
|
1438
1783
|
|
1439
|
-
* Add
|
1440
|
-
`ActiveRecord::Base.find_or_create_by`/`!` by leaning on unique constraints in the database.
|
1784
|
+
* Add support for multiple databases to `rails db:abort_if_pending_migrations`.
|
1441
1785
|
|
1442
|
-
*
|
1786
|
+
*Mark Lee*
|
1443
1787
|
|
1444
|
-
*
|
1788
|
+
* Fix sqlite3 collation parsing when using decimal columns.
|
1445
1789
|
|
1446
|
-
*
|
1790
|
+
*Martin R. Schuster*
|
1791
|
+
|
1792
|
+
* Fix invalid schema when primary key column has a comment.
|
1793
|
+
|
1794
|
+
Fixes #29966.
|
1795
|
+
|
1796
|
+
*Guilherme Goettems Schneider*
|
1797
|
+
|
1798
|
+
* Fix table comment also being applied to the primary key column.
|
1799
|
+
|
1800
|
+
*Guilherme Goettems Schneider*
|
1801
|
+
|
1802
|
+
* Allow generated `create_table` migrations to include or skip timestamps.
|
1803
|
+
|
1804
|
+
*Michael Duchemin*
|
1447
1805
|
|
1448
1806
|
|
1449
|
-
Please check [
|
1807
|
+
Please check [6-0-stable](https://github.com/rails/rails/blob/6-0-stable/activerecord/CHANGELOG.md) for previous changes.
|