activerecord 8.0.5 → 8.1.0.beta1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/CHANGELOG.md +421 -652
- data/README.rdoc +1 -1
- data/lib/active_record/association_relation.rb +1 -1
- data/lib/active_record/associations/association.rb +1 -1
- data/lib/active_record/associations/belongs_to_association.rb +0 -2
- data/lib/active_record/associations/builder/association.rb +16 -5
- data/lib/active_record/associations/builder/belongs_to.rb +17 -4
- data/lib/active_record/associations/builder/collection_association.rb +7 -3
- data/lib/active_record/associations/builder/has_one.rb +1 -1
- data/lib/active_record/associations/builder/singular_association.rb +33 -5
- data/lib/active_record/associations/collection_proxy.rb +22 -4
- data/lib/active_record/associations/deprecation.rb +88 -0
- data/lib/active_record/associations/errors.rb +3 -0
- data/lib/active_record/associations/join_dependency.rb +4 -2
- data/lib/active_record/associations/preloader/batch.rb +1 -7
- data/lib/active_record/associations/preloader/branch.rb +1 -0
- data/lib/active_record/associations.rb +159 -21
- data/lib/active_record/attribute_methods/serialization.rb +16 -3
- data/lib/active_record/attribute_methods.rb +1 -1
- data/lib/active_record/attributes.rb +3 -0
- data/lib/active_record/autosave_association.rb +2 -2
- data/lib/active_record/base.rb +2 -3
- data/lib/active_record/coders/json.rb +14 -5
- data/lib/active_record/connection_adapters/abstract/connection_handler.rb +1 -3
- data/lib/active_record/connection_adapters/abstract/connection_pool/queue.rb +15 -0
- data/lib/active_record/connection_adapters/abstract/connection_pool/reaper.rb +51 -12
- data/lib/active_record/connection_adapters/abstract/connection_pool.rb +383 -52
- data/lib/active_record/connection_adapters/abstract/database_statements.rb +27 -31
- data/lib/active_record/connection_adapters/abstract/query_cache.rb +25 -18
- data/lib/active_record/connection_adapters/abstract/quoting.rb +15 -24
- data/lib/active_record/connection_adapters/abstract/schema_creation.rb +7 -2
- data/lib/active_record/connection_adapters/abstract/schema_definitions.rb +26 -34
- data/lib/active_record/connection_adapters/abstract/schema_dumper.rb +2 -1
- data/lib/active_record/connection_adapters/abstract/schema_statements.rb +88 -25
- data/lib/active_record/connection_adapters/abstract/transaction.rb +16 -3
- data/lib/active_record/connection_adapters/abstract_adapter.rb +96 -49
- data/lib/active_record/connection_adapters/abstract_mysql_adapter.rb +43 -11
- data/lib/active_record/connection_adapters/column.rb +17 -4
- data/lib/active_record/connection_adapters/mysql/database_statements.rb +4 -4
- data/lib/active_record/connection_adapters/mysql/schema_creation.rb +2 -0
- data/lib/active_record/connection_adapters/mysql/schema_definitions.rb +42 -5
- data/lib/active_record/connection_adapters/mysql/schema_statements.rb +26 -4
- data/lib/active_record/connection_adapters/mysql2/database_statements.rb +27 -22
- data/lib/active_record/connection_adapters/mysql2_adapter.rb +1 -0
- data/lib/active_record/connection_adapters/postgresql/column.rb +2 -4
- data/lib/active_record/connection_adapters/postgresql/database_statements.rb +18 -23
- data/lib/active_record/connection_adapters/postgresql/oid/array.rb +2 -2
- data/lib/active_record/connection_adapters/postgresql/oid/type_map_initializer.rb +1 -1
- data/lib/active_record/connection_adapters/postgresql/quoting.rb +21 -10
- data/lib/active_record/connection_adapters/postgresql/schema_creation.rb +1 -1
- data/lib/active_record/connection_adapters/postgresql/schema_definitions.rb +8 -21
- data/lib/active_record/connection_adapters/postgresql/schema_dumper.rb +65 -30
- data/lib/active_record/connection_adapters/postgresql/schema_statements.rb +74 -38
- data/lib/active_record/connection_adapters/postgresql_adapter.rb +10 -12
- data/lib/active_record/connection_adapters/schema_cache.rb +2 -2
- data/lib/active_record/connection_adapters/sqlite3/column.rb +2 -8
- data/lib/active_record/connection_adapters/sqlite3/database_statements.rb +37 -25
- data/lib/active_record/connection_adapters/sqlite3/quoting.rb +0 -8
- data/lib/active_record/connection_adapters/sqlite3/schema_dumper.rb +3 -15
- data/lib/active_record/connection_adapters/sqlite3/schema_statements.rb +4 -13
- data/lib/active_record/connection_adapters/sqlite3_adapter.rb +57 -33
- data/lib/active_record/connection_adapters/trilogy/database_statements.rb +4 -3
- data/lib/active_record/connection_adapters/trilogy_adapter.rb +1 -1
- data/lib/active_record/connection_adapters.rb +1 -0
- data/lib/active_record/connection_handling.rb +8 -12
- data/lib/active_record/core.rb +5 -4
- data/lib/active_record/counter_cache.rb +33 -8
- data/lib/active_record/database_configurations/database_config.rb +5 -1
- data/lib/active_record/database_configurations/hash_config.rb +50 -9
- data/lib/active_record/database_configurations/url_config.rb +13 -3
- data/lib/active_record/database_configurations.rb +7 -3
- data/lib/active_record/delegated_type.rb +1 -1
- data/lib/active_record/dynamic_matchers.rb +54 -69
- data/lib/active_record/encryption/encryptable_record.rb +4 -4
- data/lib/active_record/encryption/encrypted_attribute_type.rb +1 -1
- data/lib/active_record/encryption/scheme.rb +1 -1
- data/lib/active_record/enum.rb +24 -8
- data/lib/active_record/errors.rb +23 -7
- data/lib/active_record/explain_registry.rb +0 -1
- data/lib/active_record/filter_attribute_handler.rb +73 -0
- data/lib/active_record/fixtures.rb +2 -2
- data/lib/active_record/future_result.rb +0 -2
- data/lib/active_record/gem_version.rb +3 -3
- data/lib/active_record/inheritance.rb +1 -1
- data/lib/active_record/insert_all.rb +14 -9
- data/lib/active_record/locking/optimistic.rb +7 -0
- data/lib/active_record/locking/pessimistic.rb +5 -0
- data/lib/active_record/log_subscriber.rb +1 -5
- data/lib/active_record/middleware/shard_selector.rb +34 -17
- data/lib/active_record/migration/command_recorder.rb +15 -2
- data/lib/active_record/migration/compatibility.rb +34 -24
- data/lib/active_record/migration/default_schema_versions_formatter.rb +30 -0
- data/lib/active_record/migration.rb +26 -16
- data/lib/active_record/model_schema.rb +10 -7
- data/lib/active_record/nested_attributes.rb +2 -0
- data/lib/active_record/persistence.rb +34 -3
- data/lib/active_record/query_cache.rb +22 -15
- data/lib/active_record/query_logs.rb +3 -7
- data/lib/active_record/railtie.rb +32 -3
- data/lib/active_record/railties/databases.rake +16 -4
- data/lib/active_record/railties/job_checkpoints.rb +15 -0
- data/lib/active_record/railties/job_runtime.rb +10 -11
- data/lib/active_record/reflection.rb +42 -3
- data/lib/active_record/relation/batches.rb +26 -12
- data/lib/active_record/relation/calculations.rb +20 -9
- data/lib/active_record/relation/delegation.rb +0 -1
- data/lib/active_record/relation/finder_methods.rb +28 -12
- data/lib/active_record/relation/merger.rb +2 -2
- data/lib/active_record/relation/predicate_builder/array_handler.rb +1 -3
- data/lib/active_record/relation/predicate_builder.rb +2 -2
- data/lib/active_record/relation/query_attribute.rb +3 -1
- data/lib/active_record/relation/query_methods.rb +40 -31
- data/lib/active_record/relation/where_clause.rb +2 -11
- data/lib/active_record/relation.rb +26 -14
- data/lib/active_record/result.rb +44 -21
- data/lib/active_record/sanitization.rb +2 -0
- data/lib/active_record/schema_dumper.rb +12 -10
- data/lib/active_record/scoping.rb +0 -1
- data/lib/active_record/signed_id.rb +43 -15
- data/lib/active_record/statement_cache.rb +13 -9
- data/lib/active_record/store.rb +44 -19
- data/lib/active_record/tasks/abstract_tasks.rb +76 -0
- data/lib/active_record/tasks/database_tasks.rb +2 -21
- data/lib/active_record/tasks/mysql_database_tasks.rb +3 -40
- data/lib/active_record/tasks/postgresql_database_tasks.rb +5 -39
- data/lib/active_record/tasks/sqlite_database_tasks.rb +14 -26
- data/lib/active_record/test_databases.rb +10 -2
- data/lib/active_record/test_fixtures.rb +27 -2
- data/lib/active_record/testing/query_assertions.rb +8 -2
- data/lib/active_record/timestamp.rb +4 -2
- data/lib/active_record/transaction.rb +2 -5
- data/lib/active_record/transactions.rb +32 -10
- data/lib/active_record/type/hash_lookup_type_map.rb +2 -1
- data/lib/active_record/type/internal/timezone.rb +7 -0
- data/lib/active_record/type/json.rb +15 -2
- data/lib/active_record/type/serialized.rb +11 -9
- data/lib/active_record/type/type_map.rb +1 -1
- data/lib/active_record/type_caster/connection.rb +2 -1
- data/lib/active_record/validations/associated.rb +1 -1
- data/lib/active_record.rb +65 -3
- data/lib/arel/alias_predication.rb +2 -0
- data/lib/arel/crud.rb +6 -11
- data/lib/arel/nodes/count.rb +2 -2
- data/lib/arel/nodes/function.rb +4 -10
- data/lib/arel/nodes/named_function.rb +2 -2
- data/lib/arel/nodes/node.rb +1 -1
- data/lib/arel/nodes.rb +0 -2
- data/lib/arel/predications.rb +3 -1
- data/lib/arel/select_manager.rb +7 -2
- data/lib/arel/visitors/dot.rb +0 -3
- data/lib/arel/visitors/postgresql.rb +55 -0
- data/lib/arel/visitors/sqlite.rb +55 -8
- data/lib/arel/visitors/to_sql.rb +3 -21
- data/lib/arel.rb +3 -1
- metadata +14 -10
- data/lib/active_record/normalization.rb +0 -163
data/CHANGELOG.md
CHANGED
|
@@ -1,189 +1,79 @@
|
|
|
1
|
-
## Rails 8.0.
|
|
1
|
+
## Rails 8.1.0.beta1 (September 04, 2025) ##
|
|
2
2
|
|
|
3
|
-
*
|
|
3
|
+
* Remove deprecated `:unsigned_float` and `:unsigned_decimal` column methods for MySQL.
|
|
4
4
|
|
|
5
|
-
*
|
|
6
|
-
|
|
7
|
-
* Respect `ActiveRecord::SchemaDumper.ignore_tables` when dumping SQLite virtual tables.
|
|
8
|
-
|
|
9
|
-
*Hans Schnedlitz*
|
|
10
|
-
|
|
11
|
-
* Restore previous instrumenter after `execute_or_skip`
|
|
12
|
-
|
|
13
|
-
`FutureResult#execute_or_skip` replaces the thread's instrumenter with an
|
|
14
|
-
`EventBuffer` to collect events published during async query execution.
|
|
15
|
-
If the global async executor is saturated and the `caller_runs` fallback
|
|
16
|
-
executes the task on the calling thread, we need to make sure the previous
|
|
17
|
-
instrumenter is restored or the stale `EventBuffer` would stay in place and
|
|
18
|
-
permanently swallow all subsequent `sql.active_record` notifications on
|
|
19
|
-
that thread.
|
|
20
|
-
|
|
21
|
-
*Rosa Gutierrez*
|
|
22
|
-
|
|
23
|
-
* Fix Ruby 4.0 delegator warning when calling inspect on ActiveRecord::Type::Serialized.
|
|
24
|
-
|
|
25
|
-
*Hammad Khan*
|
|
26
|
-
|
|
27
|
-
* Fix support for table names containing hyphens.
|
|
28
|
-
|
|
29
|
-
*Evgeniy Demin*
|
|
30
|
-
|
|
31
|
-
* Fix column deduplication for SQLite3 and PostgreSQL virtual (generated) columns.
|
|
32
|
-
|
|
33
|
-
`Column#==` and `Column#hash` now account for `virtual?` so that the
|
|
34
|
-
`Deduplicable` registry does not treat a generated column and a regular
|
|
35
|
-
column with the same name and type as identical. Previously, if a
|
|
36
|
-
generated column was registered first, a regular column on a different
|
|
37
|
-
table could be deduplicated to the generated instance, silently
|
|
38
|
-
excluding it from INSERT/UPDATE statements.
|
|
39
|
-
|
|
40
|
-
*Jay Huber*
|
|
41
|
-
|
|
42
|
-
* Fix merging relations with arel equality predicates with null relations.
|
|
43
|
-
|
|
44
|
-
*fatkodima*
|
|
45
|
-
|
|
46
|
-
* Fix SQLite3 schema dump for non-autoincrement integer primary keys.
|
|
47
|
-
|
|
48
|
-
Previously, `schema.rb` should incorrectly restore that table with an auto incrementing
|
|
49
|
-
primary key.
|
|
50
|
-
|
|
51
|
-
*Chris Hasiński*
|
|
52
|
-
|
|
53
|
-
* Fix PostgreSQL `schema_search_path` not being reapplied after `reset!` or `reconnect!`.
|
|
54
|
-
|
|
55
|
-
The `schema_search_path` configured in `database.yml` is now correctly
|
|
56
|
-
reapplied instead of falling back to PostgreSQL defaults.
|
|
57
|
-
|
|
58
|
-
*Tobias Egli*
|
|
59
|
-
|
|
60
|
-
* Ensure batched preloaded associations accounts for klass when grouping to avoid issues with STI.
|
|
61
|
-
|
|
62
|
-
*zzak*, *Stjepan Hadjic*
|
|
63
|
-
|
|
64
|
-
* Fix `ActiveRecord::SoleRecordExceeded#record` to return the relation.
|
|
65
|
-
|
|
66
|
-
This was the case until Rails 7.2, but starting from 8.0 it
|
|
67
|
-
started mistakenly returning the model class.
|
|
68
|
-
|
|
69
|
-
*Jean Boussier*
|
|
70
|
-
|
|
71
|
-
* Improve PostgreSQLAdapter resilience to Timeout.timeout.
|
|
72
|
-
|
|
73
|
-
Better handle asynchronous exceptions being thrown inside
|
|
74
|
-
the `reconnect!` method.
|
|
75
|
-
|
|
76
|
-
This may fixes some deep errors such as:
|
|
77
|
-
|
|
78
|
-
```
|
|
79
|
-
undefined method `key?' for nil:NilClass (NoMethodError)
|
|
80
|
-
if !type_map.key?(oid)
|
|
81
|
-
```
|
|
82
|
-
|
|
83
|
-
*Jean Boussier*
|
|
84
|
-
|
|
85
|
-
* Fix `eager_load` when loading `has_many` assocations with composite primary keys.
|
|
86
|
-
|
|
87
|
-
This would result in some records being loaded multiple times.
|
|
88
|
-
|
|
89
|
-
*Martin-Alexander*
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
## Rails 8.0.4.1 (March 23, 2026) ##
|
|
93
|
-
|
|
94
|
-
* No changes.
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
## Rails 8.0.4 (October 28, 2025) ##
|
|
98
|
-
|
|
99
|
-
* Fix SQLite3 data loss during table alterations with CASCADE foreign keys.
|
|
100
|
-
|
|
101
|
-
When altering a table in SQLite3 that is referenced by child tables with
|
|
102
|
-
`ON DELETE CASCADE` foreign keys, ActiveRecord would silently delete all
|
|
103
|
-
data from the child tables. This occurred because SQLite requires table
|
|
104
|
-
recreation for schema changes, and during this process the original table
|
|
105
|
-
is temporarily dropped, triggering CASCADE deletes on child tables.
|
|
106
|
-
|
|
107
|
-
The root cause was incorrect ordering of operations. The original code
|
|
108
|
-
wrapped `disable_referential_integrity` inside a transaction, but
|
|
109
|
-
`PRAGMA foreign_keys` cannot be modified inside a transaction in SQLite -
|
|
110
|
-
attempting to do so simply has no effect. This meant foreign keys remained
|
|
111
|
-
enabled during table recreation, causing CASCADE deletes to fire.
|
|
112
|
-
|
|
113
|
-
The fix reverses the order to follow the official SQLite 12-step ALTER TABLE
|
|
114
|
-
procedure: `disable_referential_integrity` now wraps the transaction instead
|
|
115
|
-
of being wrapped by it. This ensures foreign keys are properly disabled
|
|
116
|
-
before the transaction starts and re-enabled after it commits, preventing
|
|
117
|
-
CASCADE deletes while maintaining data integrity through atomic transactions.
|
|
118
|
-
|
|
119
|
-
*Ruy Rocha*
|
|
120
|
-
|
|
121
|
-
* Add support for bound SQL literals in CTEs.
|
|
122
|
-
|
|
123
|
-
*Nicolas Bachschmidt*
|
|
124
|
-
|
|
125
|
-
* Fix `belongs_to` associations not to clear the entire composite primary key.
|
|
126
|
-
|
|
127
|
-
When clearing a `belongs_to` association that references a model with composite primary key,
|
|
128
|
-
only the optional part of the key should be cleared.
|
|
129
|
-
|
|
130
|
-
*zzak*
|
|
5
|
+
*Rafael Mendonça França*
|
|
131
6
|
|
|
132
|
-
*
|
|
7
|
+
* Remove deprecated `:retries` option for the SQLite3 adapter.
|
|
133
8
|
|
|
134
|
-
*
|
|
9
|
+
*Rafael Mendonça França*
|
|
135
10
|
|
|
11
|
+
* Introduce new database configuration options `keepalive`, `max_age`, and
|
|
12
|
+
`min_connections` -- and rename `pool` to `max_connections` to match.
|
|
136
13
|
|
|
137
|
-
|
|
14
|
+
There are no changes to default behavior, but these allow for more specific
|
|
15
|
+
control over pool behavior.
|
|
138
16
|
|
|
139
|
-
*
|
|
17
|
+
*Matthew Draper*, *Chris AtLee*, *Rachael Wright-Munn*
|
|
140
18
|
|
|
141
|
-
|
|
142
|
-
for each thread.
|
|
19
|
+
* Move `LIMIT` validation from query generation to when `limit()` is called.
|
|
143
20
|
|
|
144
|
-
|
|
21
|
+
*Hartley McGuire*, *Shuyang*
|
|
145
22
|
|
|
146
|
-
|
|
23
|
+
* Add `ActiveRecord::CheckViolation` error class for check constraint violations.
|
|
147
24
|
|
|
148
|
-
*
|
|
25
|
+
*Ryuta Kamizono*
|
|
149
26
|
|
|
150
|
-
|
|
27
|
+
* Add `ActiveRecord::ExclusionViolation` error class for exclusion constraint violations.
|
|
151
28
|
|
|
152
|
-
|
|
29
|
+
When an exclusion constraint is violated in PostgreSQL, the error will now be raised
|
|
30
|
+
as `ActiveRecord::ExclusionViolation` instead of the generic `ActiveRecord::StatementInvalid`,
|
|
31
|
+
making it easier to handle these specific constraint violations in application code.
|
|
153
32
|
|
|
154
|
-
|
|
155
|
-
|
|
33
|
+
This follows the same pattern as other constraint violation error classes like
|
|
34
|
+
`RecordNotUnique` for unique constraint violations and `InvalidForeignKey` for
|
|
35
|
+
foreign key constraint violations.
|
|
156
36
|
|
|
157
|
-
*
|
|
37
|
+
*Ryuta Kamizono*
|
|
158
38
|
|
|
159
|
-
*
|
|
160
|
-
|
|
161
|
-
Rollback still runs, but may take longer.
|
|
39
|
+
* Attributes filtered by `filter_attributes` will now also be filtered by `filter_parameters`
|
|
40
|
+
so sensitive information is not leaked.
|
|
162
41
|
|
|
163
|
-
*
|
|
42
|
+
*Jill Klang*
|
|
164
43
|
|
|
165
|
-
*
|
|
44
|
+
* Add `connection.current_transaction.isolation` API to check current transaction's isolation level.
|
|
166
45
|
|
|
167
|
-
|
|
46
|
+
Returns the isolation level if it was explicitly set via the `isolation:` parameter
|
|
47
|
+
or through `ActiveRecord.with_transaction_isolation_level`, otherwise returns `nil`.
|
|
48
|
+
Nested transactions return the parent transaction's isolation level.
|
|
168
49
|
|
|
169
|
-
|
|
50
|
+
```ruby
|
|
51
|
+
# Returns nil when no transaction
|
|
52
|
+
User.connection.current_transaction.isolation # => nil
|
|
170
53
|
|
|
171
|
-
|
|
54
|
+
# Returns explicitly set isolation level
|
|
55
|
+
User.transaction(isolation: :serializable) do
|
|
56
|
+
User.connection.current_transaction.isolation # => :serializable
|
|
57
|
+
end
|
|
172
58
|
|
|
173
|
-
|
|
59
|
+
# Returns nil when isolation not explicitly set
|
|
60
|
+
User.transaction do
|
|
61
|
+
User.connection.current_transaction.isolation # => nil
|
|
62
|
+
end
|
|
174
63
|
|
|
64
|
+
# Nested transactions inherit parent's isolation
|
|
65
|
+
User.transaction(isolation: :read_committed) do
|
|
66
|
+
User.transaction do
|
|
67
|
+
User.connection.current_transaction.isolation # => :read_committed
|
|
68
|
+
end
|
|
69
|
+
end
|
|
175
70
|
```
|
|
176
|
-
primary:
|
|
177
|
-
schema_format: ruby
|
|
178
|
-
```
|
|
179
|
-
|
|
180
|
-
Useful in multi-database setups to have different formats per-database.
|
|
181
71
|
|
|
182
|
-
*
|
|
72
|
+
*Kir Shatrov*
|
|
183
73
|
|
|
184
|
-
*
|
|
74
|
+
* Emit a warning for pg gem < 1.6.0 when using PostgreSQL 18+
|
|
185
75
|
|
|
186
|
-
*
|
|
76
|
+
*Yasuo Honda*
|
|
187
77
|
|
|
188
78
|
* Fix `#merge` with `#or` or `#and` and a mixture of attributes and SQL strings resulting in an incorrect query.
|
|
189
79
|
|
|
@@ -223,722 +113,601 @@
|
|
|
223
113
|
|
|
224
114
|
*Joshua Young*
|
|
225
115
|
|
|
226
|
-
*
|
|
227
|
-
|
|
228
|
-
*fatkodima*
|
|
229
|
-
|
|
230
|
-
* Fix migration log message for down operations.
|
|
231
|
-
|
|
232
|
-
*Bernardo Barreto*
|
|
233
|
-
|
|
234
|
-
* Prepend `extra_flags` in postgres' `structure_load`
|
|
235
|
-
|
|
236
|
-
When specifying `structure_load_flags` with a postgres adapter, the flags
|
|
237
|
-
were appended to the default flags, instead of prepended.
|
|
238
|
-
This caused issues with flags not being taken into account by postgres.
|
|
239
|
-
|
|
240
|
-
*Alice Loeser*
|
|
241
|
-
|
|
242
|
-
* Fix `annotate` comments to propagate to `update_all`/`delete_all`.
|
|
116
|
+
* Make schema dumper to account for `ActiveRecord.dump_schemas` when dumping in `:ruby` format.
|
|
243
117
|
|
|
244
118
|
*fatkodima*
|
|
245
119
|
|
|
246
|
-
*
|
|
247
|
-
loaded `has_and_belongs_to_many` association.
|
|
248
|
-
|
|
249
|
-
*Hartley McGuire*
|
|
250
|
-
|
|
251
|
-
* `create_or_find_by` will now correctly rollback a transaction.
|
|
252
|
-
|
|
253
|
-
When using `create_or_find_by`, raising a ActiveRecord::Rollback error
|
|
254
|
-
in a `after_save` callback had no effect, the transaction was committed
|
|
255
|
-
and a record created.
|
|
256
|
-
|
|
257
|
-
*Edouard Chin*
|
|
258
|
-
|
|
259
|
-
* Gracefully handle `Timeout.timeout` firing during connection configuration.
|
|
260
|
-
|
|
261
|
-
Use of `Timeout.timeout` could result in improperly initialized database connection.
|
|
262
|
-
|
|
263
|
-
This could lead to a partially configured connection being used, resulting in various exceptions,
|
|
264
|
-
the most common being with the PostgreSQLAdapter raising `undefined method 'key?' for nil`
|
|
265
|
-
or `TypeError: wrong argument type nil (expected PG::TypeMap)`.
|
|
266
|
-
|
|
267
|
-
*Jean Boussier*
|
|
268
|
-
|
|
269
|
-
* Fix stale state for composite foreign keys in belongs_to associations.
|
|
270
|
-
|
|
271
|
-
*Varun Sharma*
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
## Rails 8.0.2.1 (August 13, 2025) ##
|
|
275
|
-
|
|
276
|
-
* Call inspect on ids in RecordNotFound error
|
|
277
|
-
|
|
278
|
-
[CVE-2025-55193]
|
|
279
|
-
|
|
280
|
-
*Gannon McGibbon*, *John Hawthorn*
|
|
120
|
+
* Add `:touch` option to `update_column`/`update_columns` methods.
|
|
281
121
|
|
|
122
|
+
```ruby
|
|
123
|
+
# Will update :updated_at/:updated_on alongside :nice column.
|
|
124
|
+
user.update_column(:nice, true, touch: true)
|
|
282
125
|
|
|
283
|
-
|
|
126
|
+
# Will update :updated_at/:updated_on alongside :last_ip column
|
|
127
|
+
user.update_columns(last_ip: request.remote_ip, touch: true)
|
|
128
|
+
```
|
|
284
129
|
|
|
285
|
-
*
|
|
130
|
+
*Dmitrii Ivliev*
|
|
286
131
|
|
|
287
|
-
|
|
132
|
+
* Optimize Active Record batching further when using ranges.
|
|
288
133
|
|
|
289
|
-
|
|
134
|
+
Tested on a PostgreSQL table with 10M records and batches of 10k records, the generation
|
|
135
|
+
of relations for the 1000 batches was `4.8x` faster (`6.8s` vs. `1.4s`), used `900x`
|
|
136
|
+
less bandwidth (`180MB` vs. `0.2MB`) and allocated `45x` less memory (`490MB` vs. `11MB`).
|
|
290
137
|
|
|
291
|
-
*
|
|
138
|
+
*Maxime Réty*, *fatkodima*
|
|
292
139
|
|
|
293
|
-
*
|
|
140
|
+
* Include current character length in error messages for index and table name length validations.
|
|
294
141
|
|
|
295
|
-
*
|
|
142
|
+
*Joshua Young*
|
|
296
143
|
|
|
297
|
-
*
|
|
144
|
+
* Add `rename_schema` method for PostgreSQL.
|
|
298
145
|
|
|
299
|
-
*
|
|
300
|
-
|
|
301
|
-
* Fix `sum` with qualified name on loaded relation.
|
|
146
|
+
*T S Vallender*
|
|
302
147
|
|
|
303
|
-
|
|
148
|
+
* Implement support for deprecating associations:
|
|
304
149
|
|
|
305
|
-
|
|
150
|
+
```ruby
|
|
151
|
+
has_many :posts, deprecated: true
|
|
152
|
+
```
|
|
306
153
|
|
|
307
|
-
|
|
154
|
+
With that, Active Record will report any usage of the `posts` association.
|
|
308
155
|
|
|
309
|
-
|
|
156
|
+
Three reporting modes are supported (`:warn`, `:raise`, and `:notify`), and
|
|
157
|
+
backtraces can be enabled or disabled. Defaults are `:warn` mode and
|
|
158
|
+
disabled backtraces.
|
|
310
159
|
|
|
311
|
-
|
|
312
|
-
comparing it with the minimum required version for the adapter. This meant that the connection could
|
|
313
|
-
never be successfully configured on subsequent reconnection attempts.
|
|
160
|
+
Please, check the docs for further details.
|
|
314
161
|
|
|
315
|
-
|
|
316
|
-
and ensuring the version isn't cached, which allows the version to be retrieved on the next connection attempt.
|
|
162
|
+
*Xavier Noria*
|
|
317
163
|
|
|
318
|
-
|
|
164
|
+
* PostgreSQL adapter create DB now supports `locale_provider` and `locale`.
|
|
319
165
|
|
|
320
|
-
*
|
|
166
|
+
*Bengt-Ove Hollaender*
|
|
321
167
|
|
|
322
|
-
|
|
323
|
-
This could lead to a partially configured connection being used, resulting in various exceptions,
|
|
324
|
-
the most common being with the PostgreSQLAdapter raising `undefined method `key?' for nil`
|
|
325
|
-
or `TypeError: wrong argument type nil (expected PG::TypeMap)`.
|
|
168
|
+
* Use ntuples to populate row_count instead of count for Postgres
|
|
326
169
|
|
|
327
|
-
*
|
|
170
|
+
*Jonathan Calvert*
|
|
328
171
|
|
|
329
|
-
* Fix
|
|
172
|
+
* Fix checking whether an unpersisted record is `include?`d in a strictly
|
|
173
|
+
loaded `has_and_belongs_to_many` association.
|
|
330
174
|
|
|
331
175
|
*Hartley McGuire*
|
|
332
176
|
|
|
333
|
-
*
|
|
334
|
-
|
|
335
|
-
*zzak*
|
|
336
|
-
|
|
337
|
-
* PoolConfig no longer keeps a reference to the connection class.
|
|
177
|
+
* Add ability to change transaction isolation for all pools within a block.
|
|
338
178
|
|
|
339
|
-
|
|
340
|
-
|
|
179
|
+
This functionality is useful if your application needs to change the database
|
|
180
|
+
transaction isolation for a request or action.
|
|
341
181
|
|
|
342
|
-
|
|
182
|
+
Calling `ActiveRecord.with_transaction_isolation_level(level) {}` in an around filter or
|
|
183
|
+
middleware will set the transaction isolation for all pools accessed within the block,
|
|
184
|
+
but not for the pools that aren't.
|
|
343
185
|
|
|
344
|
-
|
|
186
|
+
This works with explicit and implicit transactions:
|
|
345
187
|
|
|
346
188
|
```ruby
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
189
|
+
ActiveRecord.with_transaction_isolation_level(:read_committed) do
|
|
190
|
+
Tag.transaction do # opens a transaction explicitly
|
|
191
|
+
Tag.create!
|
|
192
|
+
end
|
|
350
193
|
end
|
|
351
194
|
```
|
|
352
195
|
|
|
353
|
-
In rare circumstances and under the right race condition, Active Support notifications
|
|
354
|
-
would no longer be dispatched after using an asynchronous query.
|
|
355
|
-
This is now fixed.
|
|
356
|
-
|
|
357
|
-
*Edouard Chin*
|
|
358
|
-
|
|
359
|
-
* Fix support for PostgreSQL enum types with commas in their name.
|
|
360
|
-
|
|
361
|
-
*Arthur Hess*
|
|
362
|
-
|
|
363
|
-
* Fix inserts on MySQL with no RETURNING support for a table with multiple auto populated columns.
|
|
364
|
-
|
|
365
|
-
*Nikita Vasilevsky*
|
|
366
|
-
|
|
367
|
-
* Fix joining on a scoped association with string joins and bind parameters.
|
|
368
|
-
|
|
369
196
|
```ruby
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
end
|
|
373
|
-
|
|
374
|
-
class InstructorRole < ActiveRecord::Base
|
|
375
|
-
scope :active, -> {
|
|
376
|
-
joins("JOIN students ON instructor_roles.student_id = students.id")
|
|
377
|
-
.where(students { status: 1 })
|
|
378
|
-
}
|
|
197
|
+
ActiveRecord.with_transaction_isolation_level(:read_committed) do
|
|
198
|
+
Tag.create! # opens a transaction implicitly
|
|
379
199
|
end
|
|
380
|
-
|
|
381
|
-
Instructor.joins(:instructor_roles).first
|
|
382
200
|
```
|
|
383
201
|
|
|
384
|
-
|
|
385
|
-
`active` scope bind parameters would be lost.
|
|
386
|
-
|
|
387
|
-
*Jean Boussier*
|
|
388
|
-
|
|
389
|
-
* Fix a potential race condition with system tests and transactional fixtures.
|
|
390
|
-
|
|
391
|
-
*Sjoerd Lagarde*
|
|
202
|
+
*Eileen M. Uchitelle*
|
|
392
203
|
|
|
393
|
-
*
|
|
204
|
+
* Raise `ActiveRecord::MissingRequiredOrderError` when order dependent finder methods (e.g. `#first`, `#last`) are
|
|
205
|
+
called without `order` values on the relation, and the model does not have any order columns (`implicit_order_column`,
|
|
206
|
+
`query_constraints`, or `primary_key`) to fall back on.
|
|
394
207
|
|
|
395
|
-
|
|
396
|
-
|
|
208
|
+
This change will be introduced with a new framework default for Rails 8.1, and the current behavior of not raising
|
|
209
|
+
an error has been deprecated with the aim of removing the configuration option in Rails 8.2.
|
|
397
210
|
|
|
398
211
|
```ruby
|
|
399
|
-
|
|
212
|
+
config.active_record.raise_on_missing_required_finder_order_columns = true
|
|
400
213
|
```
|
|
401
214
|
|
|
402
|
-
*Jean Boussier*
|
|
403
|
-
|
|
404
|
-
* Remember when a database connection has recently been verified (for
|
|
405
|
-
two seconds, by default), to avoid repeated reverifications during a
|
|
406
|
-
single request.
|
|
407
|
-
|
|
408
|
-
This should recreate a similar rate of verification as in Rails 7.1,
|
|
409
|
-
where connections are leased for the duration of a request, and thus
|
|
410
|
-
only verified once.
|
|
411
|
-
|
|
412
|
-
*Matthew Draper*
|
|
413
|
-
|
|
414
|
-
|
|
415
|
-
## Rails 8.0.1 (December 13, 2024) ##
|
|
416
|
-
|
|
417
|
-
* Fix removing foreign keys with :restrict action for MySQL.
|
|
418
|
-
|
|
419
|
-
*fatkodima*
|
|
420
|
-
|
|
421
|
-
* Fix a race condition in `ActiveRecord::Base#method_missing` when lazily defining attributes.
|
|
422
|
-
|
|
423
|
-
If multiple thread were concurrently triggering attribute definition on the same model,
|
|
424
|
-
it could result in a `NoMethodError` being raised.
|
|
425
|
-
|
|
426
|
-
*Jean Boussier*
|
|
427
|
-
|
|
428
|
-
* Fix MySQL default functions getting dropped when changing a column's nullability.
|
|
429
|
-
|
|
430
|
-
*Bastian Bartmann*
|
|
431
|
-
|
|
432
|
-
* Fix `add_unique_constraint`/`add_check_constraint`/`add_foreign_key` to be revertible when given invalid options.
|
|
433
|
-
|
|
434
|
-
*fatkodima*
|
|
435
|
-
|
|
436
|
-
* Fix asynchronous destroying of polymorphic `belongs_to` associations.
|
|
437
|
-
|
|
438
|
-
*fatkodima*
|
|
439
|
-
|
|
440
|
-
* Fix `insert_all` to not update existing records.
|
|
441
|
-
|
|
442
|
-
*fatkodima*
|
|
443
|
-
|
|
444
|
-
* `NOT VALID` constraints should not dump in `create_table`.
|
|
445
|
-
|
|
446
|
-
*Ryuta Kamizono*
|
|
447
|
-
|
|
448
|
-
* Fix finding by nil composite primary key association.
|
|
449
|
-
|
|
450
|
-
*fatkodima*
|
|
451
|
-
|
|
452
|
-
* Properly reset composite primary key configuration when setting a primary key.
|
|
453
|
-
|
|
454
|
-
*fatkodima*
|
|
455
|
-
|
|
456
|
-
* Fix Mysql2Adapter support for prepared statements
|
|
457
|
-
|
|
458
|
-
Using prepared statements with MySQL could result in a `NoMethodError` exception.
|
|
459
|
-
|
|
460
|
-
*Jean Boussier*, *Leo Arnold*, *zzak*
|
|
461
|
-
|
|
462
|
-
* Fix parsing of SQLite foreign key names when they contain non-ASCII characters
|
|
463
|
-
|
|
464
|
-
*Zacharias Knudsen*
|
|
465
|
-
|
|
466
|
-
* Fix parsing of MySQL 8.0.16+ CHECK constraints when they contain new lines.
|
|
467
|
-
|
|
468
|
-
*Steve Hill*
|
|
469
|
-
|
|
470
|
-
* Ensure normalized attribute queries use `IS NULL` consistently for `nil` and normalized `nil` values.
|
|
471
|
-
|
|
472
215
|
*Joshua Young*
|
|
473
216
|
|
|
474
|
-
*
|
|
217
|
+
* `:class_name` is now invalid in polymorphic `belongs_to` associations.
|
|
475
218
|
|
|
476
|
-
`
|
|
219
|
+
Reason is `:class_name` does not make sense in those associations because
|
|
220
|
+
the class name of target records is dynamic and stored in the type column.
|
|
477
221
|
|
|
478
|
-
|
|
222
|
+
Existing polymorphic associations setting this option can just delete it.
|
|
223
|
+
While it did not raise, it had no effect anyway.
|
|
479
224
|
|
|
480
|
-
*
|
|
225
|
+
*Xavier Noria*
|
|
481
226
|
|
|
482
|
-
|
|
227
|
+
* Add support for multiple databases to `db:migrate:reset`.
|
|
483
228
|
|
|
229
|
+
*Joé Dupuis*
|
|
484
230
|
|
|
485
|
-
|
|
231
|
+
* Add `affected_rows` to `ActiveRecord::Result`.
|
|
486
232
|
|
|
487
|
-
*
|
|
233
|
+
*Jenny Shen*
|
|
488
234
|
|
|
235
|
+
* Enable passing retryable SqlLiterals to `#where`.
|
|
489
236
|
|
|
490
|
-
|
|
237
|
+
*Hartley McGuire*
|
|
491
238
|
|
|
492
|
-
*
|
|
239
|
+
* Set default for primary keys in `insert_all`/`upsert_all`.
|
|
493
240
|
|
|
494
|
-
|
|
241
|
+
Previously in Postgres, updating and inserting new records in one upsert wasn't possible
|
|
242
|
+
due to null primary key values. `nil` primary key values passed into `insert_all`/`upsert_all`
|
|
243
|
+
are now implicitly set to the default insert value specified by adapter.
|
|
495
244
|
|
|
496
|
-
*
|
|
245
|
+
*Jenny Shen*
|
|
497
246
|
|
|
247
|
+
* Add a load hook `active_record_database_configurations` for `ActiveRecord::DatabaseConfigurations`
|
|
498
248
|
|
|
499
|
-
|
|
249
|
+
*Mike Dalessio*
|
|
500
250
|
|
|
501
|
-
*
|
|
251
|
+
* Use `TRUE` and `FALSE` for SQLite queries with boolean columns.
|
|
502
252
|
|
|
503
|
-
*
|
|
253
|
+
*Hartley McGuire*
|
|
504
254
|
|
|
505
|
-
*
|
|
255
|
+
* Bump minimum supported SQLite to 3.23.0.
|
|
506
256
|
|
|
507
|
-
|
|
508
|
-
is created, leading to potential loss of data if a database is added to an
|
|
509
|
-
existing environment.
|
|
257
|
+
*Hartley McGuire*
|
|
510
258
|
|
|
511
|
-
|
|
512
|
-
are loaded during `db:prepare` which defaults to `true` for primary database
|
|
513
|
-
configs and `false` otherwise.
|
|
259
|
+
* Allow allocated Active Records to lookup associations.
|
|
514
260
|
|
|
515
|
-
|
|
261
|
+
Previously, the association cache isn't setup on allocated record objects, so association
|
|
262
|
+
lookups will crash. Test frameworks like mocha use allocate to check for stubbable instance
|
|
263
|
+
methods, which can trigger an association lookup.
|
|
516
264
|
|
|
517
|
-
*
|
|
265
|
+
*Gannon McGibbon*
|
|
518
266
|
|
|
519
|
-
*
|
|
267
|
+
* Encryption now supports `support_unencrypted_data: true` being set per-attribute.
|
|
520
268
|
|
|
521
|
-
|
|
269
|
+
Previously this only worked if `ActiveRecord::Encryption.config.support_unencrypted_data == true`.
|
|
270
|
+
Now, if the global config is turned off, you can still opt in for a specific attribute.
|
|
522
271
|
|
|
523
|
-
|
|
272
|
+
```ruby
|
|
273
|
+
# ActiveRecord::Encryption.config.support_unencrypted_data = true
|
|
274
|
+
class User < ActiveRecord::Base
|
|
275
|
+
encrypts :name, support_unencrypted_data: false # only supports encrypted data
|
|
276
|
+
encrypts :email # supports encrypted or unencrypted data
|
|
277
|
+
end
|
|
278
|
+
```
|
|
524
279
|
|
|
525
|
-
|
|
280
|
+
```ruby
|
|
281
|
+
# ActiveRecord::Encryption.config.support_unencrypted_data = false
|
|
282
|
+
class User < ActiveRecord::Base
|
|
283
|
+
encrypts :name, support_unencrypted_data: true # supports encrypted or unencrypted data
|
|
284
|
+
encrypts :email # only supports encrypted data
|
|
285
|
+
end
|
|
286
|
+
```
|
|
526
287
|
|
|
527
|
-
*
|
|
288
|
+
*Alex Ghiculescu*
|
|
528
289
|
|
|
529
|
-
|
|
290
|
+
* Model generator no longer needs a database connection to validate column types.
|
|
530
291
|
|
|
292
|
+
*Mike Dalessio*
|
|
531
293
|
|
|
532
|
-
|
|
294
|
+
* Allow signed ID verifiers to be configurable via `Rails.application.message_verifiers`
|
|
533
295
|
|
|
534
|
-
|
|
296
|
+
Prior to this change, the primary way to configure signed ID verifiers was
|
|
297
|
+
to set `signed_id_verifier` on each model class:
|
|
535
298
|
|
|
536
|
-
|
|
299
|
+
```ruby
|
|
300
|
+
Post.signed_id_verifier = ActiveSupport::MessageVerifier.new(...)
|
|
301
|
+
Comment.signed_id_verifier = ActiveSupport::MessageVerifier.new(...)
|
|
302
|
+
```
|
|
537
303
|
|
|
538
|
-
|
|
304
|
+
And if the developer did not set `signed_id_verifier`, a verifier would be
|
|
305
|
+
instantiated with a secret derived from `secret_key_base` and the following
|
|
306
|
+
options:
|
|
539
307
|
|
|
540
|
-
|
|
308
|
+
```ruby
|
|
309
|
+
{ digest: "SHA256", serializer: JSON, url_safe: true }
|
|
310
|
+
```
|
|
541
311
|
|
|
542
|
-
|
|
312
|
+
Thus it was cumbersome to rotate configuration for all verifiers.
|
|
543
313
|
|
|
544
|
-
|
|
314
|
+
This change defines a new Rails config: [`config.active_record.use_legacy_signed_id_verifier`][].
|
|
315
|
+
The default value is `:generate_and_verify`, which preserves the previous
|
|
316
|
+
behavior. However, when set to `:verify`, signed ID verifiers will use
|
|
317
|
+
configuration from `Rails.application.message_verifiers` (specifically,
|
|
318
|
+
`Rails.application.message_verifiers["active_record/signed_id"]`) to
|
|
319
|
+
generate and verify signed IDs, but will also verify signed IDs using the
|
|
320
|
+
older configuration.
|
|
545
321
|
|
|
546
|
-
|
|
322
|
+
To avoid complication, the new behavior only applies when `signed_id_verifier_secret`
|
|
323
|
+
is not set on a model class or any of its ancestors. Additionally,
|
|
324
|
+
`signed_id_verifier_secret` is now deprecated. If you are currently setting
|
|
325
|
+
`signed_id_verifier_secret` on a model class, you can set `signed_id_verifier`
|
|
326
|
+
instead:
|
|
547
327
|
|
|
548
|
-
|
|
328
|
+
```ruby
|
|
329
|
+
# BEFORE
|
|
330
|
+
Post.signed_id_verifier_secret = "my secret"
|
|
549
331
|
|
|
550
|
-
|
|
332
|
+
# AFTER
|
|
333
|
+
Post.signed_id_verifier = ActiveSupport::MessageVerifier.new("my secret", digest: "SHA256", serializer: JSON, url_safe: true)
|
|
334
|
+
```
|
|
551
335
|
|
|
552
|
-
|
|
336
|
+
To ease migration, `signed_id_verifier` has also been changed to behave as a
|
|
337
|
+
`class_attribute` (i.e. inheritable), but _only when `signed_id_verifier_secret`
|
|
338
|
+
is not set_:
|
|
553
339
|
|
|
554
|
-
|
|
340
|
+
```ruby
|
|
341
|
+
# BEFORE
|
|
342
|
+
ActiveRecord::Base.signed_id_verifier = ActiveSupport::MessageVerifier.new(...)
|
|
343
|
+
Post.signed_id_verifier == ActiveRecord::Base.signed_id_verifier # => false
|
|
555
344
|
|
|
556
|
-
|
|
345
|
+
# AFTER
|
|
346
|
+
ActiveRecord::Base.signed_id_verifier = ActiveSupport::MessageVerifier.new(...)
|
|
347
|
+
Post.signed_id_verifier == ActiveRecord::Base.signed_id_verifier # => true
|
|
557
348
|
|
|
558
|
-
|
|
349
|
+
Post.signed_id_verifier_secret = "my secret" # => deprecation warning
|
|
350
|
+
Post.signed_id_verifier == ActiveRecord::Base.signed_id_verifier # => false
|
|
351
|
+
```
|
|
559
352
|
|
|
560
|
-
|
|
353
|
+
Note, however, that it is recommended to eventually migrate from
|
|
354
|
+
model-specific verifiers to a unified configuration managed by
|
|
355
|
+
`Rails.application.message_verifiers`. `ActiveSupport::MessageVerifier#rotate`
|
|
356
|
+
can facilitate that transition. For example:
|
|
561
357
|
|
|
562
|
-
|
|
358
|
+
```ruby
|
|
359
|
+
# BEFORE
|
|
360
|
+
# Generate and verify signed Post IDs using Post-specific configuration
|
|
361
|
+
Post.signed_id_verifier = ActiveSupport::MessageVerifier.new("post secret", ...)
|
|
563
362
|
|
|
564
|
-
|
|
363
|
+
# AFTER
|
|
364
|
+
# Generate and verify signed Post IDs using the unified configuration
|
|
365
|
+
Post.signed_id_verifier = Post.signed_id_verifier.dup
|
|
366
|
+
# Fall back to Post-specific configuration when verifying signed IDs
|
|
367
|
+
Post.signed_id_verifier.rotate("post secret", ...)
|
|
368
|
+
```
|
|
565
369
|
|
|
566
|
-
|
|
370
|
+
[`config.active_record.use_legacy_signed_id_verifier`]: https://guides.rubyonrails.org/v8.1/configuring.html#config-active-record-use-legacy-signed-id-verifier
|
|
567
371
|
|
|
568
|
-
*
|
|
372
|
+
*Ali Sepehri*, *Jonathan Hefner*
|
|
569
373
|
|
|
570
|
-
*
|
|
374
|
+
* Prepend `extra_flags` in postgres' `structure_load`
|
|
571
375
|
|
|
572
|
-
|
|
376
|
+
When specifying `structure_load_flags` with a postgres adapter, the flags
|
|
377
|
+
were appended to the default flags, instead of prepended.
|
|
378
|
+
This caused issues with flags not being taken into account by postgres.
|
|
573
379
|
|
|
574
|
-
*
|
|
575
|
-
specified.
|
|
380
|
+
*Alice Loeser*
|
|
576
381
|
|
|
577
|
-
|
|
382
|
+
* Allow bypassing primary key/constraint addition in `implicit_order_column`
|
|
578
383
|
|
|
579
|
-
|
|
384
|
+
When specifying multiple columns in an array for `implicit_order_column`, adding
|
|
385
|
+
`nil` as the last element will prevent appending the primary key to order
|
|
386
|
+
conditions. This allows more precise control of indexes used by
|
|
387
|
+
generated queries. It should be noted that this feature does introduce the risk
|
|
388
|
+
of API misbehavior if the specified columns are not fully unique.
|
|
580
389
|
|
|
581
|
-
*
|
|
390
|
+
*Issy Long*
|
|
582
391
|
|
|
583
|
-
* Allow `
|
|
392
|
+
* Allow setting the `schema_format` via database configuration.
|
|
584
393
|
|
|
585
|
-
```
|
|
586
|
-
|
|
587
|
-
|
|
394
|
+
```
|
|
395
|
+
primary:
|
|
396
|
+
schema_format: ruby
|
|
588
397
|
```
|
|
589
398
|
|
|
590
|
-
|
|
591
|
-
|
|
592
|
-
* Make Float distinguish between `float4` and `float8` in PostgreSQL.
|
|
593
|
-
|
|
594
|
-
Fixes #52742
|
|
399
|
+
Useful for multi-database setups when apps require different formats per-database.
|
|
595
400
|
|
|
596
|
-
*
|
|
401
|
+
*T S Vallender*
|
|
597
402
|
|
|
403
|
+
* Support disabling indexes for MySQL v8.0.0+ and MariaDB v10.6.0+
|
|
598
404
|
|
|
599
|
-
|
|
405
|
+
MySQL 8.0.0 added an option to disable indexes from being used by the query
|
|
406
|
+
optimizer by making them "invisible". This allows the index to still be maintained
|
|
407
|
+
and updated but no queries will be permitted to use it. This can be useful for adding
|
|
408
|
+
new invisible indexes or making existing indexes invisible before dropping them
|
|
409
|
+
to ensure queries are not negatively affected.
|
|
410
|
+
See https://dev.mysql.com/blog-archive/mysql-8-0-invisible-indexes/ for more details.
|
|
600
411
|
|
|
601
|
-
|
|
412
|
+
MariaDB 10.6.0 also added support for this feature by allowing indexes to be "ignored"
|
|
413
|
+
in queries. See https://mariadb.com/kb/en/ignored-indexes/ for more details.
|
|
602
414
|
|
|
603
|
-
|
|
415
|
+
Active Record now supports this option for MySQL 8.0.0+ and MariaDB 10.6.0+ for
|
|
416
|
+
index creation and alteration where the new index option `enabled: true/false` can be
|
|
417
|
+
passed to column and index methods as below:
|
|
604
418
|
|
|
605
419
|
```ruby
|
|
606
|
-
|
|
420
|
+
add_index :users, :email, enabled: false
|
|
421
|
+
enable_index :users, :email
|
|
422
|
+
add_column :users, :dob, :string, index: { enabled: false }
|
|
423
|
+
|
|
424
|
+
change_table :users do |t|
|
|
425
|
+
t.index :name, enabled: false
|
|
426
|
+
t.index :dob
|
|
427
|
+
t.disable_index :dob
|
|
428
|
+
t.column :username, :string, index: { enabled: false }
|
|
429
|
+
t.references :account, index: { enabled: false }
|
|
430
|
+
end
|
|
431
|
+
|
|
432
|
+
create_table :users do |t|
|
|
433
|
+
t.string :name, index: { enabled: false }
|
|
434
|
+
t.string :email
|
|
435
|
+
t.index :email, enabled: false
|
|
436
|
+
end
|
|
607
437
|
```
|
|
608
438
|
|
|
609
|
-
*
|
|
439
|
+
*Merve Taner*
|
|
610
440
|
|
|
611
|
-
*
|
|
612
|
-
on the `add_enum_value` method.
|
|
441
|
+
* Respect `implicit_order_column` in `ActiveRecord::Relation#reverse_order`.
|
|
613
442
|
|
|
614
|
-
*
|
|
443
|
+
*Joshua Young*
|
|
615
444
|
|
|
616
|
-
*
|
|
445
|
+
* Add column types to `ActiveRecord::Result` for SQLite3.
|
|
617
446
|
|
|
618
|
-
*Andrew
|
|
447
|
+
*Andrew Kane*
|
|
619
448
|
|
|
620
|
-
*
|
|
621
|
-
the same child association but different parents does not join all parents.
|
|
449
|
+
* Raise `ActiveRecord::ReadOnlyError` when pessimistically locking with a readonly role.
|
|
622
450
|
|
|
623
|
-
|
|
451
|
+
*Joshua Young*
|
|
624
452
|
|
|
625
|
-
|
|
453
|
+
* Fix using the `SQLite3Adapter`'s `dbconsole` method outside of a Rails application.
|
|
626
454
|
|
|
627
|
-
|
|
455
|
+
*Hartley McGuire*
|
|
628
456
|
|
|
629
|
-
|
|
457
|
+
* Fix migrating multiple databases with `ActiveRecord::PendingMigration` action.
|
|
630
458
|
|
|
631
|
-
*
|
|
459
|
+
*Gannon McGibbon*
|
|
632
460
|
|
|
633
|
-
|
|
634
|
-
|
|
461
|
+
* Enable automatically retrying idempotent association queries on connection
|
|
462
|
+
errors.
|
|
635
463
|
|
|
636
|
-
|
|
464
|
+
*Hartley McGuire*
|
|
637
465
|
|
|
638
|
-
|
|
466
|
+
* Add `allow_retry` to `sql.active_record` instrumentation.
|
|
639
467
|
|
|
640
|
-
|
|
468
|
+
This enables identifying queries which queries are automatically retryable on connection errors.
|
|
641
469
|
|
|
642
|
-
|
|
643
|
-
which we have supported in the core. Now we support MySQL 5.6.4 or later, which
|
|
644
|
-
is the first version to support datetime with precision.
|
|
470
|
+
*Hartley McGuire*
|
|
645
471
|
|
|
646
|
-
|
|
472
|
+
* Better support UPDATE with JOIN for Postgresql and SQLite3
|
|
647
473
|
|
|
648
|
-
|
|
474
|
+
Previously when generating update queries with one or more JOIN clauses,
|
|
475
|
+
Active Record would use a sub query which would prevent to reference the joined
|
|
476
|
+
tables in the `SET` clause, for instance:
|
|
649
477
|
|
|
650
|
-
|
|
651
|
-
|
|
478
|
+
```ruby
|
|
479
|
+
Comment.joins(:post).update_all("title = posts.title")
|
|
480
|
+
```
|
|
652
481
|
|
|
653
|
-
|
|
654
|
-
|
|
482
|
+
This is now supported as long as the relation doesn't also use a `LIMIT`, `ORDER` or
|
|
483
|
+
`GROUP BY` clause. This was supported by the MySQL adapter for a long time.
|
|
655
484
|
|
|
656
485
|
*Jean Boussier*
|
|
657
486
|
|
|
658
|
-
*
|
|
659
|
-
|
|
660
|
-
This ensures that we call `PG::Connection.unescape_bytea` on PostgreSQL before decryption.
|
|
661
|
-
|
|
662
|
-
*Donal McBreen*
|
|
663
|
-
|
|
664
|
-
* Ensure `ActiveRecord::Encryption.config` is always ready before access.
|
|
665
|
-
|
|
666
|
-
Previously, `ActiveRecord::Encryption` configuration was deferred until `ActiveRecord::Base`
|
|
667
|
-
was loaded. Therefore, accessing `ActiveRecord::Encryption.config` properties before
|
|
668
|
-
`ActiveRecord::Base` was loaded would give incorrect results.
|
|
669
|
-
|
|
670
|
-
`ActiveRecord::Encryption` now has its own loading hook so that its configuration is set as
|
|
671
|
-
soon as needed.
|
|
487
|
+
* Introduce a before-fork hook in `ActiveSupport::Testing::Parallelization` to clear existing
|
|
488
|
+
connections, to avoid fork-safety issues with the mysql2 adapter.
|
|
672
489
|
|
|
673
|
-
|
|
674
|
-
`ActiveRecord::Encryption`, thus preserving the original behavior of having its config ready
|
|
675
|
-
before any use of `ActiveRecord::Base`.
|
|
490
|
+
Fixes #41776
|
|
676
491
|
|
|
677
|
-
*
|
|
492
|
+
*Mike Dalessio*, *Donal McBreen*
|
|
678
493
|
|
|
679
|
-
*
|
|
680
|
-
their type, scale, limit & precision.
|
|
681
|
-
|
|
682
|
-
Address #52699.
|
|
683
|
-
|
|
684
|
-
*Ruy Rocha*
|
|
685
|
-
|
|
686
|
-
* Add support for SQLite3 full-text-search and other virtual tables.
|
|
687
|
-
|
|
688
|
-
Previously, adding sqlite3 virtual tables messed up `schema.rb`.
|
|
494
|
+
* PoolConfig no longer keeps a reference to the connection class.
|
|
689
495
|
|
|
690
|
-
|
|
496
|
+
Keeping a reference to the class caused subtle issues when combined with reloading in
|
|
497
|
+
development. Fixes #54343.
|
|
691
498
|
|
|
692
|
-
*
|
|
499
|
+
*Mike Dalessio*
|
|
693
500
|
|
|
694
|
-
*
|
|
501
|
+
* Fix SQL notifications sometimes not sent when using async queries.
|
|
695
502
|
|
|
696
503
|
```ruby
|
|
697
|
-
|
|
698
|
-
|
|
504
|
+
Post.async_count
|
|
505
|
+
ActiveSupport::Notifications.subscribed(->(*) { "Will never reach here" }) do
|
|
506
|
+
Post.count
|
|
699
507
|
end
|
|
700
508
|
```
|
|
701
509
|
|
|
702
|
-
|
|
510
|
+
In rare circumstances and under the right race condition, Active Support notifications
|
|
511
|
+
would no longer be dispatched after using an asynchronous query.
|
|
512
|
+
This is now fixed.
|
|
703
513
|
|
|
704
|
-
*
|
|
514
|
+
*Edouard Chin*
|
|
705
515
|
|
|
706
|
-
|
|
516
|
+
* Eliminate queries loading dumped schema cache on Postgres
|
|
707
517
|
|
|
708
|
-
|
|
518
|
+
Improve resiliency by avoiding needing to open a database connection to load the
|
|
519
|
+
type map while defining attribute methods at boot when a schema cache file is
|
|
520
|
+
configured on PostgreSQL databases.
|
|
709
521
|
|
|
710
|
-
|
|
711
|
-
with `:x` and `:y` keys of numeric values, mirroring the functionality of
|
|
712
|
-
existing casts for string and array values. Both string and symbol keys are
|
|
713
|
-
supported.
|
|
522
|
+
*James Coleman*
|
|
714
523
|
|
|
715
|
-
|
|
716
|
-
class PostgresqlPoint < ActiveRecord::Base
|
|
717
|
-
attribute :x, :point
|
|
718
|
-
attribute :y, :point
|
|
719
|
-
attribute :z, :point
|
|
720
|
-
end
|
|
524
|
+
* `ActiveRecord::Coder::JSON` can be instantiated
|
|
721
525
|
|
|
722
|
-
|
|
723
|
-
|
|
724
|
-
|
|
725
|
-
z: {x: '12.34', y: -43.21}
|
|
726
|
-
})
|
|
727
|
-
ActiveRecord::Point.new(12.32, -43.21) == val.x == val.y == val.z
|
|
526
|
+
Options can now be passed to `ActiveRecord::Coder::JSON` when instantiating the coder. This allows:
|
|
527
|
+
```ruby
|
|
528
|
+
serialize :config, coder: ActiveRecord::Coder::JSON.new(symbolize_names: true)
|
|
728
529
|
```
|
|
530
|
+
*matthaigh27*
|
|
729
531
|
|
|
730
|
-
|
|
532
|
+
* Deprecate using `insert_all`/`upsert_all` with unpersisted records in associations.
|
|
731
533
|
|
|
732
|
-
|
|
534
|
+
Using these methods on associations containing unpersisted records will now
|
|
535
|
+
show a deprecation warning, as the unpersisted records will be lost after
|
|
536
|
+
the operation.
|
|
733
537
|
|
|
734
|
-
|
|
538
|
+
*Nick Schwaderer*
|
|
735
539
|
|
|
736
|
-
|
|
540
|
+
* Make column name optional for `index_exists?`.
|
|
737
541
|
|
|
738
|
-
|
|
542
|
+
This aligns well with `remove_index` signature as well, where
|
|
543
|
+
index name doesn't need to be derived from the column names.
|
|
739
544
|
|
|
740
|
-
*
|
|
545
|
+
*Ali Ismayiliov*
|
|
741
546
|
|
|
742
|
-
*
|
|
547
|
+
* Change the payload name of `sql.active_record` notification for eager
|
|
548
|
+
loading from "SQL" to "#{model.name} Eager Load".
|
|
743
549
|
|
|
744
|
-
|
|
745
|
-
`enable_extension` statements if they differ from the current schema.
|
|
550
|
+
*zzak*
|
|
746
551
|
|
|
747
|
-
|
|
552
|
+
* Enable automatically retrying idempotent `#exists?` queries on connection
|
|
553
|
+
errors.
|
|
748
554
|
|
|
749
|
-
|
|
750
|
-
enable_extension "heroku_ext.pgcrypto"
|
|
751
|
-
enable_extension "pg_stat_statements"
|
|
752
|
-
```
|
|
555
|
+
*Hartley McGuire*, *classidied*
|
|
753
556
|
|
|
754
|
-
|
|
557
|
+
* Deprecate usage of unsupported methods in conjunction with `update_all`:
|
|
755
558
|
|
|
756
|
-
|
|
757
|
-
|
|
758
|
-
|
|
759
|
-
```
|
|
559
|
+
`update_all` will now print a deprecation message if a query includes either `WITH`,
|
|
560
|
+
`WITH RECURSIVE` or `DISTINCT` statements. Those were never supported and were ignored
|
|
561
|
+
when generating the SQL query.
|
|
760
562
|
|
|
761
|
-
|
|
563
|
+
An error will be raised in a future Rails release. This behavior will be consistent
|
|
564
|
+
with `delete_all` which currently raises an error for unsupported statements.
|
|
762
565
|
|
|
763
|
-
*
|
|
764
|
-
actual cast type.
|
|
566
|
+
*Edouard Chin*
|
|
765
567
|
|
|
766
|
-
|
|
568
|
+
* The table columns inside `schema.rb` are now sorted alphabetically.
|
|
767
569
|
|
|
768
|
-
|
|
570
|
+
Previously they'd be sorted by creation order, which can cause merge conflicts when two
|
|
571
|
+
branches modify the same table concurrently.
|
|
769
572
|
|
|
770
|
-
|
|
771
|
-
aggregated in a single bulk insert command.
|
|
573
|
+
*John Duff*
|
|
772
574
|
|
|
773
|
-
|
|
575
|
+
* Introduce versions formatter for the schema dumper.
|
|
774
576
|
|
|
775
|
-
|
|
577
|
+
It is now possible to override how schema dumper formats versions information inside the
|
|
578
|
+
`structure.sql` file. Currently, the versions are simply sorted in the decreasing order.
|
|
579
|
+
Within large teams, this can potentially cause many merge conflicts near the top of the list.
|
|
776
580
|
|
|
777
|
-
|
|
778
|
-
|
|
779
|
-
actually take a schema name (unlike `CREATE EXTENSION`), so the resulting SQL statement will only name
|
|
780
|
-
the extension, e.g. `DROP EXTENSION IF EXISTS "pgcrypto"`.
|
|
581
|
+
Now, the custom formatter can be provided with a custom sorting logic (e.g. by hash values
|
|
582
|
+
of the versions), which can greatly reduce the number of conflicts.
|
|
781
583
|
|
|
782
|
-
*
|
|
584
|
+
*fatkodima*
|
|
783
585
|
|
|
784
|
-
*
|
|
586
|
+
* Serialized attributes can now be marked as comparable.
|
|
785
587
|
|
|
786
|
-
|
|
588
|
+
A not rare issue when working with serialized attributes is that the serialized representation of an object
|
|
589
|
+
can change over time. Either because you are migrating from one serializer to the other (e.g. YAML to JSON or to msgpack),
|
|
590
|
+
or because the serializer used subtly changed its output.
|
|
787
591
|
|
|
788
|
-
|
|
592
|
+
One example is libyaml that used to have some extra trailing whitespaces, and recently fixed that.
|
|
593
|
+
When this sorts of thing happen, you end up with lots of records that report being changed even though
|
|
594
|
+
they aren't, which in the best case leads to a lot more writes to the database and in the worst case lead to nasty bugs.
|
|
789
595
|
|
|
790
|
-
|
|
596
|
+
The solution is to instead compare the deserialized representation of the object, however Active Record
|
|
597
|
+
can't assume the deserialized object has a working `==` method. Hence why this new functionality is opt-in.
|
|
791
598
|
|
|
792
599
|
```ruby
|
|
793
|
-
|
|
794
|
-
# do something with relation
|
|
795
|
-
end
|
|
600
|
+
serialize :config, type: Hash, coder: JSON, comparable: true
|
|
796
601
|
```
|
|
797
602
|
|
|
798
|
-
*
|
|
799
|
-
|
|
800
|
-
* Use SQLite `IMMEDIATE` transactions when possible.
|
|
801
|
-
|
|
802
|
-
Transactions run against the SQLite3 adapter default to IMMEDIATE mode to improve concurrency support and avoid busy exceptions.
|
|
803
|
-
|
|
804
|
-
*Stephen Margheim*
|
|
805
|
-
|
|
806
|
-
* Raise specific exception when a connection is not defined.
|
|
807
|
-
|
|
808
|
-
The new `ConnectionNotDefined` exception provides connection name, shard and role accessors indicating the details of the connection that was requested.
|
|
603
|
+
*Jean Boussier*
|
|
809
604
|
|
|
810
|
-
|
|
605
|
+
* Fix MySQL default functions getting dropped when changing a column's nullability.
|
|
811
606
|
|
|
812
|
-
*
|
|
607
|
+
*Bastian Bartmann*
|
|
813
608
|
|
|
814
|
-
|
|
609
|
+
* SQLite extensions can be configured in `config/database.yml`.
|
|
815
610
|
|
|
816
|
-
|
|
611
|
+
The database configuration option `extensions:` allows an application to load SQLite extensions
|
|
612
|
+
when using `sqlite3` >= v2.4.0. The array members may be filesystem paths or the names of
|
|
613
|
+
modules that respond to `.to_path`:
|
|
817
614
|
|
|
818
|
-
|
|
819
|
-
|
|
615
|
+
``` yaml
|
|
616
|
+
development:
|
|
617
|
+
adapter: sqlite3
|
|
618
|
+
extensions:
|
|
619
|
+
- SQLean::UUID # module name responding to `.to_path`
|
|
620
|
+
- .sqlpkg/nalgeon/crypto/crypto.so # or a filesystem path
|
|
621
|
+
- <%= AppExtensions.location %> # or ruby code returning a path
|
|
622
|
+
```
|
|
820
623
|
|
|
821
|
-
|
|
624
|
+
*Mike Dalessio*
|
|
822
625
|
|
|
823
|
-
|
|
626
|
+
* `ActiveRecord::Middleware::ShardSelector` supports granular database connection switching.
|
|
824
627
|
|
|
825
|
-
|
|
628
|
+
A new configuration option, `class_name:`, is introduced to
|
|
629
|
+
`config.active_record.shard_selector` to allow an application to specify the abstract connection
|
|
630
|
+
class to be switched by the shard selection middleware. The default class is
|
|
631
|
+
`ActiveRecord::Base`.
|
|
826
632
|
|
|
827
|
-
|
|
828
|
-
|
|
829
|
-
def self.deflate(data)
|
|
830
|
-
Zstd.compress(data)
|
|
831
|
-
end
|
|
633
|
+
For example, this configuration tells `ShardSelector` to switch shards using
|
|
634
|
+
`AnimalsRecord.connected_to`:
|
|
832
635
|
|
|
833
|
-
def self.inflate(data)
|
|
834
|
-
Zstd.decompress(data)
|
|
835
|
-
end
|
|
836
|
-
end
|
|
837
|
-
|
|
838
|
-
class User
|
|
839
|
-
encrypts :name, compressor: ZstdCompressor
|
|
840
|
-
end
|
|
841
636
|
```
|
|
842
|
-
|
|
843
|
-
You disable compression by passing `compress: false`.
|
|
844
|
-
|
|
845
|
-
```ruby
|
|
846
|
-
class User
|
|
847
|
-
encrypts :name, compress: false
|
|
848
|
-
end
|
|
637
|
+
config.active_record.shard_selector = { class_name: "AnimalsRecord" }
|
|
849
638
|
```
|
|
850
639
|
|
|
851
|
-
*
|
|
852
|
-
|
|
853
|
-
* Add condensed `#inspect` for `ConnectionPool`, `AbstractAdapter`, and
|
|
854
|
-
`DatabaseConfig`.
|
|
855
|
-
|
|
856
|
-
*Hartley McGuire*
|
|
857
|
-
|
|
858
|
-
* Add `.shard_keys`, `.sharded?`, & `.connected_to_all_shards` methods.
|
|
859
|
-
|
|
860
|
-
```ruby
|
|
861
|
-
class ShardedBase < ActiveRecord::Base
|
|
862
|
-
self.abstract_class = true
|
|
863
|
-
|
|
864
|
-
connects_to shards: {
|
|
865
|
-
shard_one: { writing: :shard_one },
|
|
866
|
-
shard_two: { writing: :shard_two }
|
|
867
|
-
}
|
|
868
|
-
end
|
|
640
|
+
*Mike Dalessio*
|
|
869
641
|
|
|
870
|
-
|
|
871
|
-
end
|
|
642
|
+
* Reset relations after `insert_all`/`upsert_all`.
|
|
872
643
|
|
|
873
|
-
|
|
874
|
-
ShardedModel.sharded? => true
|
|
875
|
-
ShardedBase.connected_to_all_shards { ShardedModel.current_shard } => [:shard_one, :shard_two]
|
|
876
|
-
```
|
|
644
|
+
Bulk insert/upsert methods will now call `reset` if used on a relation, matching the behavior of `update_all`.
|
|
877
645
|
|
|
878
|
-
*
|
|
646
|
+
*Milo Winningham*
|
|
879
647
|
|
|
880
|
-
*
|
|
881
|
-
by these values.
|
|
648
|
+
* Use `_N` as a parallel tests databases suffixes
|
|
882
649
|
|
|
883
|
-
|
|
650
|
+
Peviously, `-N` was used as a suffix. This can cause problems for RDBMSes
|
|
651
|
+
which do not support dashes in database names.
|
|
884
652
|
|
|
885
|
-
*
|
|
886
|
-
for preloaded associations in models using composite primary keys.
|
|
887
|
-
|
|
888
|
-
*Jay Ang*
|
|
653
|
+
*fatkodima*
|
|
889
654
|
|
|
890
|
-
*
|
|
655
|
+
* Remember when a database connection has recently been verified (for
|
|
656
|
+
two seconds, by default), to avoid repeated reverifications during a
|
|
657
|
+
single request.
|
|
891
658
|
|
|
892
|
-
|
|
659
|
+
This should recreate a similar rate of verification as in Rails 7.1,
|
|
660
|
+
where connections are leased for the duration of a request, and thus
|
|
661
|
+
only verified once.
|
|
893
662
|
|
|
894
|
-
*
|
|
663
|
+
*Matthew Draper*
|
|
895
664
|
|
|
896
|
-
*
|
|
665
|
+
* Allow to reset cache counters for multiple records.
|
|
897
666
|
|
|
898
|
-
|
|
667
|
+
```
|
|
668
|
+
Aircraft.reset_counters([1, 2, 3], :wheels_count)
|
|
669
|
+
```
|
|
899
670
|
|
|
900
|
-
|
|
671
|
+
It produces much fewer queries compared to the custom implementation using looping over ids.
|
|
672
|
+
Previously: `O(ids.size * counters.size)` queries, now: `O(ids.size + counters.size)` queries.
|
|
901
673
|
|
|
902
|
-
*
|
|
903
|
-
structured (e.g., PostgreSQL +hstore+/+json+, or MySQL +json+) or declared serializable via
|
|
904
|
-
`ActiveRecord.store`.
|
|
674
|
+
*fatkodima*
|
|
905
675
|
|
|
906
|
-
|
|
676
|
+
* Add `affected_rows` to `sql.active_record` Notification.
|
|
907
677
|
|
|
908
|
-
|
|
678
|
+
*Hartley McGuire*
|
|
909
679
|
|
|
910
|
-
|
|
680
|
+
* Fix `sum` when performing a grouped calculation.
|
|
911
681
|
|
|
912
|
-
|
|
913
|
-
Please make sure the column is declared serializable via 'ActiveRecord.store' or, if your
|
|
914
|
-
database supports it, use a structured column type like hstore or json.
|
|
682
|
+
`User.group(:friendly).sum` no longer worked. This is fixed.
|
|
915
683
|
|
|
916
|
-
*
|
|
684
|
+
*Edouard Chin*
|
|
917
685
|
|
|
918
|
-
*
|
|
686
|
+
* Add support for enabling or disabling transactional tests per database.
|
|
919
687
|
|
|
920
|
-
|
|
688
|
+
A test class can now override the default `use_transactional_tests` setting
|
|
689
|
+
for individual databases, which can be useful if some databases need their
|
|
690
|
+
current state to be accessible to an external process while tests are running.
|
|
921
691
|
|
|
922
692
|
```ruby
|
|
923
|
-
class
|
|
924
|
-
|
|
693
|
+
class MostlyTransactionalTest < ActiveSupport::TestCase
|
|
694
|
+
self.use_transactional_tests = true
|
|
695
|
+
skip_transactional_tests_for_database :shared
|
|
925
696
|
end
|
|
926
697
|
```
|
|
927
698
|
|
|
928
|
-
|
|
699
|
+
*Matthew Cheetham*, *Morgan Mareve*
|
|
929
700
|
|
|
930
|
-
|
|
701
|
+
* Cast `query_cache` value when using URL configuration.
|
|
931
702
|
|
|
932
|
-
*
|
|
703
|
+
*zzak*
|
|
933
704
|
|
|
934
|
-
|
|
705
|
+
* NULLS NOT DISTINCT works with UNIQUE CONSTRAINT as well as UNIQUE INDEX.
|
|
935
706
|
|
|
936
|
-
|
|
937
|
-
ActiveRecord.schema_cache_ignored_tables = ["developers"]
|
|
938
|
-
ActiveRecord.schema_cache_ignored_table?("developers")
|
|
939
|
-
=> true
|
|
940
|
-
```
|
|
707
|
+
*Ryuta Kamizono*
|
|
941
708
|
|
|
942
|
-
|
|
709
|
+
* `PG::UnableToSend: no connection to the server` is now retryable as a connection-related exception
|
|
710
|
+
|
|
711
|
+
*Kazuma Watanabe*
|
|
943
712
|
|
|
944
|
-
Please check [
|
|
713
|
+
Please check [8-0-stable](https://github.com/rails/rails/blob/8-0-stable/activerecord/CHANGELOG.md) for previous changes.
|