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.
Files changed (243) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +1146 -788
  3. data/MIT-LICENSE +1 -1
  4. data/README.rdoc +2 -2
  5. data/lib/active_record/aggregations.rb +5 -5
  6. data/lib/active_record/association_relation.rb +30 -12
  7. data/lib/active_record/associations/alias_tracker.rb +19 -15
  8. data/lib/active_record/associations/association.rb +49 -26
  9. data/lib/active_record/associations/association_scope.rb +18 -20
  10. data/lib/active_record/associations/belongs_to_association.rb +23 -10
  11. data/lib/active_record/associations/belongs_to_polymorphic_association.rb +8 -3
  12. data/lib/active_record/associations/builder/association.rb +32 -5
  13. data/lib/active_record/associations/builder/belongs_to.rb +10 -7
  14. data/lib/active_record/associations/builder/collection_association.rb +5 -4
  15. data/lib/active_record/associations/builder/has_and_belongs_to_many.rb +0 -1
  16. data/lib/active_record/associations/builder/has_many.rb +6 -2
  17. data/lib/active_record/associations/builder/has_one.rb +11 -14
  18. data/lib/active_record/associations/builder/singular_association.rb +1 -1
  19. data/lib/active_record/associations/collection_association.rb +32 -18
  20. data/lib/active_record/associations/collection_proxy.rb +12 -5
  21. data/lib/active_record/associations/foreign_association.rb +13 -0
  22. data/lib/active_record/associations/has_many_association.rb +24 -2
  23. data/lib/active_record/associations/has_many_through_association.rb +10 -4
  24. data/lib/active_record/associations/has_one_association.rb +15 -1
  25. data/lib/active_record/associations/join_dependency/join_association.rb +37 -21
  26. data/lib/active_record/associations/join_dependency/join_part.rb +1 -1
  27. data/lib/active_record/associations/join_dependency.rb +63 -49
  28. data/lib/active_record/associations/preloader/association.rb +14 -8
  29. data/lib/active_record/associations/preloader/through_association.rb +1 -1
  30. data/lib/active_record/associations/preloader.rb +5 -3
  31. data/lib/active_record/associations/singular_association.rb +1 -1
  32. data/lib/active_record/associations.rb +118 -11
  33. data/lib/active_record/attribute_assignment.rb +10 -8
  34. data/lib/active_record/attribute_methods/before_type_cast.rb +13 -9
  35. data/lib/active_record/attribute_methods/dirty.rb +1 -11
  36. data/lib/active_record/attribute_methods/primary_key.rb +6 -2
  37. data/lib/active_record/attribute_methods/query.rb +3 -6
  38. data/lib/active_record/attribute_methods/read.rb +8 -11
  39. data/lib/active_record/attribute_methods/serialization.rb +11 -5
  40. data/lib/active_record/attribute_methods/time_zone_conversion.rb +12 -13
  41. data/lib/active_record/attribute_methods/write.rb +12 -20
  42. data/lib/active_record/attribute_methods.rb +64 -54
  43. data/lib/active_record/attributes.rb +33 -8
  44. data/lib/active_record/autosave_association.rb +47 -30
  45. data/lib/active_record/base.rb +2 -14
  46. data/lib/active_record/callbacks.rb +152 -22
  47. data/lib/active_record/coders/yaml_column.rb +1 -1
  48. data/lib/active_record/connection_adapters/abstract/connection_pool.rb +185 -134
  49. data/lib/active_record/connection_adapters/abstract/database_limits.rb +2 -44
  50. data/lib/active_record/connection_adapters/abstract/database_statements.rb +66 -23
  51. data/lib/active_record/connection_adapters/abstract/query_cache.rb +3 -8
  52. data/lib/active_record/connection_adapters/abstract/quoting.rb +34 -34
  53. data/lib/active_record/connection_adapters/abstract/savepoints.rb +3 -3
  54. data/lib/active_record/connection_adapters/abstract/schema_creation.rb +153 -116
  55. data/lib/active_record/connection_adapters/abstract/schema_definitions.rb +114 -26
  56. data/lib/active_record/connection_adapters/abstract/schema_dumper.rb +3 -3
  57. data/lib/active_record/connection_adapters/abstract/schema_statements.rb +228 -83
  58. data/lib/active_record/connection_adapters/abstract/transaction.rb +92 -33
  59. data/lib/active_record/connection_adapters/abstract_adapter.rb +52 -76
  60. data/lib/active_record/connection_adapters/abstract_mysql_adapter.rb +123 -87
  61. data/lib/active_record/connection_adapters/column.rb +15 -1
  62. data/lib/active_record/connection_adapters/deduplicable.rb +29 -0
  63. data/lib/active_record/connection_adapters/legacy_pool_manager.rb +35 -0
  64. data/lib/active_record/connection_adapters/mysql/database_statements.rb +24 -24
  65. data/lib/active_record/connection_adapters/mysql/explain_pretty_printer.rb +1 -1
  66. data/lib/active_record/connection_adapters/mysql/quoting.rb +18 -3
  67. data/lib/active_record/connection_adapters/mysql/schema_creation.rb +32 -6
  68. data/lib/active_record/connection_adapters/mysql/schema_definitions.rb +8 -0
  69. data/lib/active_record/connection_adapters/mysql/schema_dumper.rb +5 -2
  70. data/lib/active_record/connection_adapters/mysql/schema_statements.rb +7 -4
  71. data/lib/active_record/connection_adapters/mysql/type_metadata.rb +10 -1
  72. data/lib/active_record/connection_adapters/mysql2_adapter.rb +31 -12
  73. data/lib/active_record/connection_adapters/pool_config.rb +73 -0
  74. data/lib/active_record/connection_adapters/pool_manager.rb +47 -0
  75. data/lib/active_record/connection_adapters/postgresql/column.rb +24 -1
  76. data/lib/active_record/connection_adapters/postgresql/database_statements.rb +14 -53
  77. data/lib/active_record/connection_adapters/postgresql/oid/cidr.rb +3 -5
  78. data/lib/active_record/connection_adapters/postgresql/oid/date.rb +2 -2
  79. data/lib/active_record/connection_adapters/postgresql/oid/date_time.rb +2 -2
  80. data/lib/active_record/connection_adapters/postgresql/oid/interval.rb +49 -0
  81. data/lib/active_record/connection_adapters/postgresql/oid/legacy_point.rb +2 -2
  82. data/lib/active_record/connection_adapters/postgresql/oid/macaddr.rb +25 -0
  83. data/lib/active_record/connection_adapters/postgresql/oid/point.rb +2 -2
  84. data/lib/active_record/connection_adapters/postgresql/oid/uuid.rb +11 -1
  85. data/lib/active_record/connection_adapters/postgresql/oid.rb +2 -0
  86. data/lib/active_record/connection_adapters/postgresql/quoting.rb +30 -4
  87. data/lib/active_record/connection_adapters/postgresql/referential_integrity.rb +1 -1
  88. data/lib/active_record/connection_adapters/postgresql/schema_creation.rb +5 -1
  89. data/lib/active_record/connection_adapters/postgresql/schema_statements.rb +61 -29
  90. data/lib/active_record/connection_adapters/postgresql/type_metadata.rb +8 -0
  91. data/lib/active_record/connection_adapters/postgresql_adapter.rb +75 -64
  92. data/lib/active_record/connection_adapters/schema_cache.rb +130 -15
  93. data/lib/active_record/connection_adapters/sql_type_metadata.rb +8 -0
  94. data/lib/active_record/connection_adapters/sqlite3/database_statements.rb +32 -5
  95. data/lib/active_record/connection_adapters/sqlite3/quoting.rb +1 -1
  96. data/lib/active_record/connection_adapters/sqlite3/schema_creation.rb +5 -1
  97. data/lib/active_record/connection_adapters/sqlite3/schema_statements.rb +36 -3
  98. data/lib/active_record/connection_adapters/sqlite3_adapter.rb +48 -50
  99. data/lib/active_record/connection_adapters.rb +52 -0
  100. data/lib/active_record/connection_handling.rb +218 -71
  101. data/lib/active_record/core.rb +264 -63
  102. data/lib/active_record/database_configurations/connection_url_resolver.rb +99 -0
  103. data/lib/active_record/database_configurations/database_config.rb +52 -9
  104. data/lib/active_record/database_configurations/hash_config.rb +54 -8
  105. data/lib/active_record/database_configurations/url_config.rb +15 -40
  106. data/lib/active_record/database_configurations.rb +125 -85
  107. data/lib/active_record/delegated_type.rb +209 -0
  108. data/lib/active_record/destroy_association_async_job.rb +36 -0
  109. data/lib/active_record/enum.rb +69 -34
  110. data/lib/active_record/errors.rb +47 -12
  111. data/lib/active_record/explain.rb +9 -4
  112. data/lib/active_record/explain_subscriber.rb +1 -1
  113. data/lib/active_record/fixture_set/file.rb +10 -17
  114. data/lib/active_record/fixture_set/model_metadata.rb +1 -2
  115. data/lib/active_record/fixture_set/render_context.rb +1 -1
  116. data/lib/active_record/fixture_set/table_row.rb +2 -2
  117. data/lib/active_record/fixtures.rb +58 -9
  118. data/lib/active_record/gem_version.rb +3 -3
  119. data/lib/active_record/inheritance.rb +40 -18
  120. data/lib/active_record/insert_all.rb +38 -5
  121. data/lib/active_record/integration.rb +3 -5
  122. data/lib/active_record/internal_metadata.rb +18 -7
  123. data/lib/active_record/legacy_yaml_adapter.rb +7 -3
  124. data/lib/active_record/locking/optimistic.rb +24 -17
  125. data/lib/active_record/locking/pessimistic.rb +6 -2
  126. data/lib/active_record/log_subscriber.rb +27 -8
  127. data/lib/active_record/middleware/database_selector/resolver/session.rb +3 -0
  128. data/lib/active_record/middleware/database_selector/resolver.rb +5 -0
  129. data/lib/active_record/middleware/database_selector.rb +4 -1
  130. data/lib/active_record/migration/command_recorder.rb +47 -27
  131. data/lib/active_record/migration/compatibility.rb +72 -18
  132. data/lib/active_record/migration.rb +114 -84
  133. data/lib/active_record/model_schema.rb +89 -14
  134. data/lib/active_record/nested_attributes.rb +2 -3
  135. data/lib/active_record/no_touching.rb +1 -1
  136. data/lib/active_record/persistence.rb +50 -45
  137. data/lib/active_record/query_cache.rb +15 -5
  138. data/lib/active_record/querying.rb +11 -6
  139. data/lib/active_record/railtie.rb +64 -44
  140. data/lib/active_record/railties/console_sandbox.rb +2 -4
  141. data/lib/active_record/railties/databases.rake +279 -101
  142. data/lib/active_record/readonly_attributes.rb +4 -0
  143. data/lib/active_record/reflection.rb +60 -44
  144. data/lib/active_record/relation/batches/batch_enumerator.rb +25 -9
  145. data/lib/active_record/relation/batches.rb +38 -31
  146. data/lib/active_record/relation/calculations.rb +104 -43
  147. data/lib/active_record/relation/finder_methods.rb +44 -14
  148. data/lib/active_record/relation/from_clause.rb +1 -1
  149. data/lib/active_record/relation/merger.rb +20 -23
  150. data/lib/active_record/relation/predicate_builder/array_handler.rb +8 -9
  151. data/lib/active_record/relation/predicate_builder/association_query_value.rb +4 -5
  152. data/lib/active_record/relation/predicate_builder/polymorphic_array_value.rb +10 -6
  153. data/lib/active_record/relation/predicate_builder/relation_handler.rb +1 -1
  154. data/lib/active_record/relation/predicate_builder.rb +61 -38
  155. data/lib/active_record/relation/query_methods.rb +322 -196
  156. data/lib/active_record/relation/record_fetch_warning.rb +3 -3
  157. data/lib/active_record/relation/spawn_methods.rb +8 -7
  158. data/lib/active_record/relation/where_clause.rb +111 -61
  159. data/lib/active_record/relation.rb +100 -81
  160. data/lib/active_record/result.rb +41 -33
  161. data/lib/active_record/runtime_registry.rb +2 -2
  162. data/lib/active_record/sanitization.rb +6 -17
  163. data/lib/active_record/schema_dumper.rb +34 -4
  164. data/lib/active_record/schema_migration.rb +2 -8
  165. data/lib/active_record/scoping/default.rb +1 -3
  166. data/lib/active_record/scoping/named.rb +1 -17
  167. data/lib/active_record/secure_token.rb +16 -8
  168. data/lib/active_record/serialization.rb +5 -3
  169. data/lib/active_record/signed_id.rb +116 -0
  170. data/lib/active_record/statement_cache.rb +20 -4
  171. data/lib/active_record/store.rb +8 -3
  172. data/lib/active_record/suppressor.rb +2 -2
  173. data/lib/active_record/table_metadata.rb +42 -51
  174. data/lib/active_record/tasks/database_tasks.rb +140 -113
  175. data/lib/active_record/tasks/mysql_database_tasks.rb +34 -35
  176. data/lib/active_record/tasks/postgresql_database_tasks.rb +24 -26
  177. data/lib/active_record/tasks/sqlite_database_tasks.rb +13 -9
  178. data/lib/active_record/test_databases.rb +5 -4
  179. data/lib/active_record/test_fixtures.rb +79 -31
  180. data/lib/active_record/timestamp.rb +4 -6
  181. data/lib/active_record/touch_later.rb +21 -21
  182. data/lib/active_record/transactions.rb +19 -66
  183. data/lib/active_record/type/serialized.rb +6 -2
  184. data/lib/active_record/type.rb +8 -1
  185. data/lib/active_record/type_caster/connection.rb +0 -1
  186. data/lib/active_record/type_caster/map.rb +8 -5
  187. data/lib/active_record/validations/associated.rb +1 -1
  188. data/lib/active_record/validations/numericality.rb +35 -0
  189. data/lib/active_record/validations/uniqueness.rb +24 -4
  190. data/lib/active_record/validations.rb +1 -0
  191. data/lib/active_record.rb +7 -14
  192. data/lib/arel/attributes/attribute.rb +4 -0
  193. data/lib/arel/collectors/bind.rb +5 -0
  194. data/lib/arel/collectors/composite.rb +8 -0
  195. data/lib/arel/collectors/sql_string.rb +7 -0
  196. data/lib/arel/collectors/substitute_binds.rb +7 -0
  197. data/lib/arel/nodes/binary.rb +82 -8
  198. data/lib/arel/nodes/bind_param.rb +8 -0
  199. data/lib/arel/nodes/casted.rb +21 -9
  200. data/lib/arel/nodes/equality.rb +6 -9
  201. data/lib/arel/nodes/grouping.rb +3 -0
  202. data/lib/arel/nodes/homogeneous_in.rb +76 -0
  203. data/lib/arel/nodes/in.rb +8 -1
  204. data/lib/arel/nodes/infix_operation.rb +13 -1
  205. data/lib/arel/nodes/join_source.rb +1 -1
  206. data/lib/arel/nodes/node.rb +7 -6
  207. data/lib/arel/nodes/ordering.rb +27 -0
  208. data/lib/arel/nodes/sql_literal.rb +3 -0
  209. data/lib/arel/nodes/table_alias.rb +7 -3
  210. data/lib/arel/nodes/unary.rb +0 -1
  211. data/lib/arel/nodes.rb +3 -1
  212. data/lib/arel/predications.rb +12 -18
  213. data/lib/arel/select_manager.rb +1 -2
  214. data/lib/arel/table.rb +13 -5
  215. data/lib/arel/visitors/dot.rb +14 -2
  216. data/lib/arel/visitors/mysql.rb +11 -1
  217. data/lib/arel/visitors/postgresql.rb +15 -4
  218. data/lib/arel/visitors/to_sql.rb +89 -78
  219. data/lib/arel/visitors.rb +0 -7
  220. data/lib/arel.rb +5 -13
  221. data/lib/rails/generators/active_record/migration/migration_generator.rb +1 -0
  222. data/lib/rails/generators/active_record/migration/templates/create_table_migration.rb.tt +2 -0
  223. data/lib/rails/generators/active_record/migration/templates/migration.rb.tt +3 -3
  224. data/lib/rails/generators/active_record/migration.rb +6 -1
  225. data/lib/rails/generators/active_record/model/model_generator.rb +39 -2
  226. data/lib/rails/generators/active_record/model/templates/abstract_base_class.rb.tt +7 -0
  227. metadata +24 -25
  228. data/lib/active_record/advisory_lock_base.rb +0 -18
  229. data/lib/active_record/attribute_decorators.rb +0 -88
  230. data/lib/active_record/connection_adapters/connection_specification.rb +0 -296
  231. data/lib/active_record/connection_adapters/determine_if_preparable_visitor.rb +0 -29
  232. data/lib/active_record/define_callbacks.rb +0 -22
  233. data/lib/active_record/railties/collection_cache_association_loading.rb +0 -34
  234. data/lib/active_record/relation/predicate_builder/base_handler.rb +0 -18
  235. data/lib/active_record/relation/where_clause_factory.rb +0 -33
  236. data/lib/arel/attributes.rb +0 -22
  237. data/lib/arel/visitors/depth_first.rb +0 -203
  238. data/lib/arel/visitors/ibm_db.rb +0 -34
  239. data/lib/arel/visitors/informix.rb +0 -62
  240. data/lib/arel/visitors/mssql.rb +0 -156
  241. data/lib/arel/visitors/oracle.rb +0 -158
  242. data/lib/arel/visitors/oracle12.rb +0 -65
  243. data/lib/arel/visitors/where_sql.rb +0 -22
data/CHANGELOG.md CHANGED
@@ -1,6 +1,16 @@
1
- ## Rails 6.0.6.1 (January 17, 2023) ##
1
+ ## Rails 6.1.7.3 (March 13, 2023) ##
2
2
 
3
- * Make `sanitize_as_sql_comment` more strict
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
- ## Rails 6.0.6 (September 09, 2022) ##
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.0.5.1 (July 12, 2022) ##
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.0.5 (May 09, 2022) ##
88
+ ## Rails 6.1.6 (May 09, 2022) ##
56
89
 
57
90
  * No changes.
58
91
 
59
92
 
60
- ## Rails 6.0.4.8 (April 26, 2022) ##
93
+ ## Rails 6.1.5.1 (April 26, 2022) ##
61
94
 
62
95
  * No changes.
63
96
 
64
97
 
65
- ## Rails 6.0.4.7 (March 08, 2022) ##
98
+ ## Rails 6.1.5 (March 09, 2022) ##
66
99
 
67
- * No changes.
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
- ## Rails 6.0.4.6 (February 11, 2022) ##
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
- * No changes.
112
+ Fixes #43056
73
113
 
114
+ *Eric O'Hanlon*
74
115
 
75
- ## Rails 6.0.4.5 (February 11, 2022) ##
116
+ * Fix migration compatibility to create SQLite references/belongs_to column as integer when
117
+ migration version is 6.0.
76
118
 
77
- * No changes.
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
- ## Rails 6.0.4.4 (December 15, 2021) ##
124
+ * Fix dbconsole for 3-tier config.
81
125
 
82
- * No changes.
126
+ *Eileen M. Uchitelle*
83
127
 
128
+ * Better handle SQL queries with invalid encoding.
84
129
 
85
- ## Rails 6.0.4.3 (December 14, 2021) ##
130
+ ```ruby
131
+ Post.create(name: "broken \xC8 UTF-8")
132
+ ```
86
133
 
87
- * No changes.
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
- ## Rails 6.0.4.2 (December 14, 2021) ##
140
+ *Jean Boussier*
91
141
 
92
- * No changes.
142
+ * Ignore persisted in-memory records when merging target lists.
93
143
 
144
+ *Kevin Sjöberg*
94
145
 
95
- ## Rails 6.0.4.1 (August 19, 2021) ##
146
+ * Fix regression bug that caused ignoring additional conditions for preloading
147
+ `has_many` through relations.
96
148
 
97
- * No changes.
149
+ Fixes #43132
98
150
 
151
+ *Alexander Pauly*
99
152
 
100
- ## Rails 6.0.4 (June 15, 2021) ##
153
+ * Fix `ActiveRecord::InternalMetadata` to not be broken by
154
+ `config.active_record.record_timestamps = false`
101
155
 
102
- * Only warn about negative enums if a positive form that would cause conflicts exists.
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 #39065.
159
+ Fixes #42983
105
160
 
106
- *Alex Ghiculescu*
161
+ *Jean Boussier*
107
162
 
108
- * Allow the inverse of a `has_one` association that was previously autosaved to be loaded.
163
+ * Fix duplicate active record objects on `inverse_of`.
109
164
 
110
- Fixes #34255.
165
+ *Justin Carvalho*
111
166
 
112
- *Steven Weber*
167
+ * Fix duplicate objects stored in has many association after save.
113
168
 
114
- * Reset statement cache for association if `table_name` is changed.
169
+ Fixes #42549.
115
170
 
116
- Fixes #36453.
171
+ *Alex Ghiculescu*
117
172
 
118
- *Ryuta Kamizono*
173
+ * Fix performance regression in `CollectionAssocation#build`.
119
174
 
120
- * Type cast extra select for eager loading.
175
+ *Alex Ghiculescu*
121
176
 
122
- *Ryuta Kamizono*
177
+ * Fix retrieving default value for text column for MariaDB.
123
178
 
124
- * Prevent collection associations from being autosaved multiple times.
179
+ *fatkodima*
125
180
 
126
- Fixes #39173.
127
181
 
128
- *Eugene Kenny*
182
+ ## Rails 6.1.4.7 (March 08, 2022) ##
129
183
 
130
- * Resolve issue with insert_all unique_by option when used with expression index.
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
- Usage:
187
+ ## Rails 6.1.4.6 (February 11, 2022) ##
137
188
 
138
- ```ruby
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
- Fixes #39516.
192
+ ## Rails 6.1.4.5 (February 11, 2022) ##
148
193
 
149
- *Austen Madden*
194
+ * No changes.
150
195
 
151
- * Fix preloading for polymorphic association with custom scope.
152
196
 
153
- *Ryuta Kamizono*
197
+ ## Rails 6.1.4.4 (December 15, 2021) ##
154
198
 
155
- * Allow relations with different SQL comments in the `or` method.
199
+ * No changes.
156
200
 
157
- *Takumi Shotoku*
158
201
 
159
- * Resolve conflict between counter cache and optimistic locking.
202
+ ## Rails 6.1.4.3 (December 14, 2021) ##
160
203
 
161
- Bump an Active Record instance's lock version after updating its counter
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
- *Aaron Lipman*
207
+ ## Rails 6.1.4.2 (December 14, 2021) ##
169
208
 
170
- * Fix through association with source/through scope which has joins.
209
+ * No changes.
171
210
 
172
- *Ryuta Kamizono*
173
211
 
174
- * Fix through association to respect source scope for includes/preload.
212
+ ## Rails 6.1.4.1 (August 19, 2021) ##
175
213
 
176
- *Ryuta Kamizono*
214
+ * No changes.
177
215
 
178
- * Fix eager load with Arel joins to maintain the original joins order.
179
216
 
180
- *Ryuta Kamizono*
217
+ ## Rails 6.1.4 (June 24, 2021) ##
181
218
 
182
- * Fix group by count with eager loading + order + limit/offset.
219
+ * Do not try to rollback transactions that failed due to a `ActiveRecord::TransactionRollbackError`.
183
220
 
184
- *Ryuta Kamizono*
221
+ *Jamie McCarthy*
185
222
 
186
- * Fix left joins order when merging multiple left joins from different associations.
223
+ * Raise an error if `pool_config` is `nil` in `set_pool_config`.
187
224
 
188
- *Ryuta Kamizono*
225
+ *Eileen M. Uchitelle*
189
226
 
190
- * Fix index creation to preserve index comment in bulk change table on MySQL.
227
+ * Fix compatibility with `psych >= 4`.
191
228
 
192
- *Ryuta Kamizono*
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
- * Change `remove_foreign_key` to not check `:validate` option if database
195
- doesn't support the feature.
232
+ *Jean Boussier*
196
233
 
197
- *Ryuta Kamizono*
234
+ * Support using replicas when using `rails dbconsole`.
198
235
 
199
- * Fix the result of aggregations to maintain duplicated "group by" fields.
236
+ *Christopher Thornton*
200
237
 
201
- *Ryuta Kamizono*
238
+ * Restore connection pools after transactional tests.
202
239
 
203
- * Do not return duplicated records when using preload.
240
+ *Eugene Kenny*
204
241
 
205
- *Bogdan Gusiev*
242
+ * Change `upsert_all` to fails cleanly for MySQL when `:unique_by` is used.
206
243
 
244
+ *Bastian Bartmann*
207
245
 
208
- ## Rails 6.0.3.7 (May 05, 2021) ##
246
+ * Fix user-defined `self.default_scope` to respect table alias.
209
247
 
210
- * No changes.
248
+ *Ryuta Kamizono*
211
249
 
250
+ * Clear `@cache_keys` cache after `update_all`, `delete_all`, `destroy_all`.
212
251
 
213
- ## Rails 6.0.3.6 (March 26, 2021) ##
252
+ *Ryuta Kamizono*
214
253
 
215
- * No changes.
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
- ## Rails 6.0.3.5 (February 10, 2021) ##
259
+ * Fix `merge` when the `where` clauses have string contents.
219
260
 
220
- * Fix possible DoS vector in PostgreSQL money type
261
+ *Ryuta Kamizono*
221
262
 
222
- Carefully crafted input can cause a DoS via the regular expressions used
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
- Thanks to @dee-see from Hackerone for this patch!
265
+ *Jacopo Beschi*
227
266
 
228
- [CVE-2021-22880]
267
+ * Fix binds logging for `"WHERE ... IN ..."` statements.
229
268
 
230
- *Aaron Patterson*
269
+ *Ricardo Díaz*
231
270
 
271
+ * Handle `false` in relation strict loading checks.
232
272
 
233
- ## Rails 6.0.3.4 (October 07, 2020) ##
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
- * No changes.
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
- ## Rails 6.0.3.3 (September 09, 2020) ##
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
- * No changes.
292
+ *Eileen M. Uchitelle*, *Radamés Roriz*
241
293
 
294
+ * Fix numericality validator without precision.
242
295
 
243
- ## Rails 6.0.3.2 (June 17, 2020) ##
296
+ *Ryuta Kamizono*
244
297
 
245
- * No changes.
298
+ * Fix aggregate attribute on Enum types.
246
299
 
300
+ *Ryuta Kamizono*
247
301
 
248
- ## Rails 6.0.3.1 (May 18, 2020) ##
302
+ * Fix `CREATE INDEX` statement generation for PostgreSQL.
249
303
 
250
- * No changes.
304
+ *eltongo*
251
305
 
306
+ * Fix where clause on enum attribute when providing array of strings.
252
307
 
253
- ## Rails 6.0.3 (May 06, 2020) ##
308
+ *Ryuta Kamizono*
254
309
 
255
- * Recommend applications don't use the `database` kwarg in `connected_to`
310
+ * Fix `unprepared_statement` to work it when nesting.
256
311
 
257
- The database kwarg in `connected_to` was meant to be used for one-off scripts but is often used in requests. This is really dangerous because it re-establishes a connection every time. It's deprecated in 6.1 and will be removed in 6.2 without replacement. This change soft deprecates it in 6.0 by removing documentation.
312
+ *Ryuta Kamizono*
258
313
 
259
- *Eileen M. Uchitelle*
260
314
 
261
- * Fix support for PostgreSQL 11+ partitioned indexes.
315
+ ## Rails 6.1.3.2 (May 05, 2021) ##
262
316
 
263
- *Sebastián Palma*
317
+ * No changes.
264
318
 
265
- * Add support for beginless ranges, introduced in Ruby 2.7.
266
319
 
267
- *Josh Goodall*
320
+ ## Rails 6.1.3.1 (March 26, 2021) ##
268
321
 
269
- * Fix insert_all with enum values
322
+ * No changes.
270
323
 
271
- Fixes #38716.
272
324
 
273
- *Joel Blum*
325
+ ## Rails 6.1.3 (February 17, 2021) ##
274
326
 
275
- * Regexp-escape table name for MS SQL
327
+ * Fix the MySQL adapter to always set the right collation and charset
328
+ to the connection session.
276
329
 
277
- 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.
330
+ *Rafael Mendonça França*
278
331
 
279
- *Larry Reid*
332
+ * Fix MySQL adapter handling of time objects when prepared statements
333
+ are enabled.
280
334
 
281
- * Store advisory locks on their own named connection.
335
+ *Rafael Mendonça França*
282
336
 
283
- 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.
337
+ * Fix scoping in enum fields using conditions that would generate
338
+ an `IN` clause.
284
339
 
285
- In order to fix this we are storing the advisory lock on a new connection with the connection specification name `AdisoryLockBase`. The caveat is that we need to maintain at least 2 connections to a database while migrations are running in order to do this.
340
+ *Ryuta Kamizono*
286
341
 
287
- *Eileen M. Uchitelle*, *John Crepezzi*
342
+ * Skip optimised #exist? query when #include? is called on a relation
343
+ with a having clause
288
344
 
289
- * Ensure `:reading` connections always raise if a write is attempted.
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
- 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`.
355
+ An sample query affected by this problem:
292
356
 
293
- *Eileen M. Uchitelle*
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
- * Enforce fresh ETag header after a collection's contents change by adding
296
- ActiveRecord::Relation#cache_key_with_version. This method will be used by
297
- ActionController::ConditionalGet to ensure that when collection cache versioning
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
- *Aaron Lipman*
369
+ Fixes #41417
302
370
 
303
- * A database URL can now contain a querystring value that contains an equal sign. This is needed to support passing PostgresSQL `options`.
371
+ *Michael Smart*
304
372
 
305
- *Joshua Flanagan*
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
- * Retain explicit selections on the base model after applying `includes` and `joins`.
377
+ *wbharding*, *Martin Tepper*
308
378
 
309
- Resolves #34889.
310
379
 
311
- *Patrick Rebsch*
380
+ ## Rails 6.1.2.1 (February 10, 2021) ##
312
381
 
382
+ * Fix possible DoS vector in PostgreSQL money type
313
383
 
314
- ## Rails 6.0.2.2 (March 19, 2020) ##
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
- * No changes.
388
+ Thanks to @dee-see from Hackerone for this patch!
317
389
 
390
+ [CVE-2021-22880]
318
391
 
319
- ## Rails 6.0.2.1 (December 18, 2019) ##
392
+ *Aaron Patterson*
320
393
 
321
- * No changes.
322
394
 
395
+ ## Rails 6.1.2 (February 09, 2021) ##
323
396
 
324
- ## Rails 6.0.2 (December 13, 2019) ##
397
+ * Fix timestamp type for sqlite3.
325
398
 
326
- * Share the same connection pool for primary and replica databases in the
327
- transactional tests for the same database.
399
+ *Eileen M. Uchitelle*
328
400
 
329
- *Edouard Chin*
401
+ * Make destroy async transactional.
330
402
 
331
- * Fix the preloader when one record is fetched using `after_initialize`
332
- but not the entire collection.
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
- *Bradley Price*
407
+ Now the jobs are only enqueued until after the db transaction has been committed.
335
408
 
336
- * Fix collection callbacks not terminating when `:abort` is thrown.
409
+ *Cory Gwin*
337
410
 
338
- *Edouard Chin*, *Ryuta Kamizono*
411
+ * Fix malformed packet error in MySQL statement for connection configuration.
339
412
 
340
- * Correctly deprecate `where.not` working as NOR for relations.
413
+ *robinroestenburg*
341
414
 
342
- 12a9664 deprecated where.not working as NOR, however
343
- doing a relation query like `where.not(relation: { ... })`
344
- wouldn't be properly deprecated and `where.not` would work as
345
- NAND instead.
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
- *Edouard Chin*
420
+ Fixes #41137.
348
421
 
349
- * Fix `db:migrate` task with multiple databases to restore the connection
350
- to the previous database.
422
+ *Jonathan Bracy*
351
423
 
352
- The migrate task iterates and establish a connection over each db
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
- *Edouard Chin*
426
+ *Eileen M. Uchitelle*
358
427
 
359
- * Fix multi-threaded issue for `AcceptanceValidator`.
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
- ## Rails 6.0.1 (November 5, 2019) ##
365
-
366
- * Common Table Expressions are allowed on read-only connections.
434
+ *alpaca-tc*
367
435
 
368
- *Chris Morris*
436
+ * Fix `where` on polymorphic association with empty array.
369
437
 
370
- * New record instantiation respects `unscope`.
371
-
372
- *Ryuta Kamizono*
438
+ *Ryuta Kamizono*
373
439
 
374
- * Fixed a case where `find_in_batches` could halt too early.
440
+ * Fix preventing writes for `ApplicationRecord`.
375
441
 
376
- *Takayuki Nakata*
442
+ *Eileen M. Uchitelle*
377
443
 
378
- * Autosaved associations always perform validations when a custom validation
379
- context is used.
380
444
 
381
- *Tekin Suleyman*
445
+ ## Rails 6.1.1 (January 07, 2021) ##
382
446
 
383
- * `sql.active_record` notifications now include the `:connection` in
384
- their payloads.
447
+ * Fix fixtures loading when strict loading is enabled for the association.
385
448
 
386
- *Eugene Kenny*
449
+ *Alex Ghiculescu*
387
450
 
388
- * A rollback encountered in an `after_commit` callback does not reset
389
- previously-committed record state.
451
+ * Fix `where` with custom primary key for belongs_to association.
390
452
 
391
- *Ryuta Kamizono*
453
+ *Ryuta Kamizono*
392
454
 
393
- * Fixed that join order was lost when eager-loading.
455
+ * Fix `where` with aliased associations.
394
456
 
395
- *Ryuta Kamizono*
457
+ *Ryuta Kamizono*
396
458
 
397
- * `DESCRIBE` queries are allowed on read-only connections.
459
+ * Fix `composed_of` with symbol mapping.
398
460
 
399
- *Dylan Thacker-Smith*
461
+ *Ryuta Kamizono*
400
462
 
401
- * Fixed that records that had been `inspect`ed could not be marshaled.
463
+ * Don't skip money's type cast for pluck and calculations.
402
464
 
403
- *Eugene Kenny*
465
+ *Ryuta Kamizono*
404
466
 
405
- * The connection pool reaper thread is respawned in forked processes. This
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
- *John Hawthorn*
469
+ *Ryuta Kamizono*
409
470
 
410
- * The memoized result of `ActiveRecord::Relation#take` is properly cleared
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
- *Anmol Arora*
473
+ *Rafael Mendonça França*
415
474
 
416
- * Fixed the performance regression for `primary_keys` introduced MySQL 8.0.
475
+ * Fix complicated `has_many :through` with nested where condition.
417
476
 
418
- *Hiroyuki Ishii*
477
+ *Ryuta Kamizono*
419
478
 
420
- * `insert`, `insert_all`, `upsert`, and `upsert_all` now clear the query cache.
479
+ * Handle STI models for `has_many dependent: :destroy_async`.
421
480
 
422
- *Eugene Kenny*
481
+ *Muhammad Usman*
423
482
 
424
- * Call `while_preventing_writes` directly from `connected_to`.
483
+ * Restore possibility of passing `false` to :polymorphic option of `belongs_to`.
425
484
 
426
- 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)`.
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
- 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.
488
+ *glaszig*
429
489
 
430
- *Eileen M. Uchitelle*
490
+ * Allow adding nonnamed expression indexes to be revertible.
431
491
 
432
- * Improve detection of ActiveRecord::StatementTimeout with mysql2 adapter in the edge case when the query is terminated during filesort.
492
+ Fixes #40732.
433
493
 
434
- *Kir Shatrov*
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
- ## Rails 6.0.0 (August 16, 2019) ##
502
+ *fatkodima*
438
503
 
439
- * Preserve user supplied joins order as much as possible.
440
504
 
441
- Fixes #36761, #34328, #24281, #12953.
505
+ ## Rails 6.1.0 (December 09, 2020) ##
442
506
 
443
- *Ryuta Kamizono*
507
+ * Only warn about negative enums if a positive form that would cause conflicts exists.
444
508
 
445
- * Make the DATABASE_URL env variable only affect the primary connection. Add new env variables for multiple databases.
509
+ Fixes #39065.
446
510
 
447
- *John Crepezzi*, *Eileen Uchitelle*
511
+ *Alex Ghiculescu*
448
512
 
449
- * Add a warning for enum elements with 'not_' prefix.
513
+ * Change `attribute_for_inspect` to take `filter_attributes` in consideration.
450
514
 
451
- class Foo
452
- enum status: [:sent, :not_sent]
453
- end
515
+ *Rafael Mendonça França*
454
516
 
455
- *Edu Depetris*
517
+ * Fix odd behavior of inverse_of with multiple belongs_to to same class.
456
518
 
457
- * Make currency symbols optional for money column type in PostgreSQL
519
+ Fixes #35204.
458
520
 
459
- *Joel Schneider*
521
+ *Tomoyuki Kai*
460
522
 
523
+ * Build predicate conditions with objects that delegate `#id` and primary key:
461
524
 
462
- ## Rails 6.0.0.rc2 (July 22, 2019) ##
525
+ ```ruby
526
+ class AdminAuthor
527
+ delegate_missing_to :@author
463
528
 
464
- * Add database_exists? method to connection adapters to check if a database exists.
529
+ def initialize(author)
530
+ @author = author
531
+ end
532
+ end
465
533
 
466
- *Guilherme Mansur*
534
+ Post.where(author: AdminAuthor.new(author))
535
+ ```
467
536
 
468
- * PostgreSQL: Fix GROUP BY with ORDER BY virtual count attribute.
537
+ *Sean Doyle*
469
538
 
470
- Fixes #36022.
539
+ * Add `connected_to_many` API.
471
540
 
472
- *Ryuta Kamizono*
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
- * Make ActiveRecord `ConnectionPool.connections` method thread-safe.
543
+ Before:
475
544
 
476
- Fixes #36465.
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
- *Jeff Doering*
553
+ After:
479
554
 
480
- * Fix sqlite3 collation parsing when using decimal columns.
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
- *Martin R. Schuster*
561
+ *Eileen M. Uchitelle*, *John Crepezzi*
483
562
 
484
- * Fix invalid schema when primary key column has a comment.
563
+ * Add option to raise or log for `ActiveRecord::StrictLoadingViolationError`.
485
564
 
486
- Fixes #29966.
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
- *Guilherme Goettems Schneider*
567
+ Set `config.active_record.action_on_strict_loading_violation` to `:log` errors instead of raising.
489
568
 
490
- * Fix table comment also being applied to the primary key column.
569
+ *Eileen M. Uchitelle*
491
570
 
492
- *Guilherme Goettems Schneider*
571
+ * Allow the inverse of a `has_one` association that was previously autosaved to be loaded.
493
572
 
494
- * Fix merging left_joins to maintain its own `join_type` context.
573
+ Fixes #34255.
495
574
 
496
- Fixes #36103.
575
+ *Steven Weber*
497
576
 
498
- *Ryuta Kamizono*
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
- ## Rails 6.0.0.rc1 (April 24, 2019) ##
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
- * Add `touch` option to `has_one` association.
583
+ Fixes #38655.
504
584
 
505
- *Abhay Nikam*
585
+ *Luke Redpath*
506
586
 
507
- * Deprecate `where.not` working as NOR and will be changed to NAND in Rails 6.1.
587
+ * MySQL: Uniqueness validator now respects default database collation,
588
+ no longer enforce case sensitive comparison by default.
508
589
 
509
- ```ruby
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
- In Rails 6.0:
592
+ * Remove deprecated methods from `ActiveRecord::ConnectionAdapters::DatabaseLimits`.
515
593
 
516
- ```ruby
517
- sapphire = treasures(:sapphire)
518
-
519
- nor = all.reject { |e|
520
- e.estimate_of_type == sapphire.class.polymorphic_name
521
- }.reject { |e|
522
- e.estimate_of_id == sapphire.id
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
- In Rails 6.1:
602
+ *Rafael Mendonça França*
533
603
 
534
- ```ruby
535
- sapphire = treasures(:sapphire)
604
+ * Remove deprecated `ActiveRecord::ConnectionAdapters::AbstractAdapter#supports_multi_insert?`.
536
605
 
537
- nand = all - [sapphire]
538
- assert_equal [treasures(:diamond), cars(:honda)], nand
606
+ *Rafael Mendonça França*
539
607
 
540
- without_sapphire = PriceEstimate.where.not(
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
- *Ryuta Kamizono*
610
+ *Rafael Mendonça França*
547
611
 
548
- * Fix dirty tracking after rollback.
612
+ * Remove deprecated `ActiveRecord::ConnectionAdapters::PostgreSQLAdapter#supports_ranges?`.
549
613
 
550
- Fixes #15018, #30167, #33868.
614
+ *Rafael Mendonça França*
551
615
 
552
- *Ryuta Kamizono*
616
+ * Remove deprecated `ActiveRecord::Base#update_attributes` and `ActiveRecord::Base#update_attributes!`.
553
617
 
554
- * Add `ActiveRecord::Relation#cache_version` to support recyclable cache keys via
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
- NOTE: This feature is turned off by default, and `cache_key` will still return
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
- *Lachlan Sylvester*
622
+ *Rafael Mendonça França*
564
623
 
565
- * Fix dirty tracking for `touch` to track saved changes.
624
+ * Remove deprecated `config.active_record.sqlite3.represent_boolean_as_integer`.
566
625
 
567
- Fixes #33429.
626
+ *Rafael Mendonça França*
568
627
 
569
- *Ryuta Kamzono*
628
+ * `relation.create` does no longer leak scope to class level querying methods
629
+ in initialization block and callbacks.
570
630
 
571
- * `change_column_comment` and `change_table_comment` are invertible only if
572
- `to` and `from` options are specified.
631
+ Before:
573
632
 
574
- *Yoshiyuki Kinjo*
633
+ User.where(name: "John").create do |john|
634
+ User.find_by(name: "David") # => nil
635
+ end
575
636
 
576
- * Don't call commit/rollback callbacks when a record isn't saved.
637
+ After:
577
638
 
578
- Fixes #29747.
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
- * Fix circular `autosave: true` causes invalid records to be saved.
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
- * Raise `ArgumentError` for invalid `:limit` and `:precision` like as other options.
647
+ class User < ActiveRecord::Base
648
+ scope :david, -> { User.where(name: "David") }
649
+ end
597
650
 
598
651
  Before:
599
652
 
600
- ```ruby
601
- add_column :items, :attr1, :binary, size: 10 # => ArgumentError
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
- ```ruby
610
- add_column :items, :attr1, :binary, size: 10 # => ArgumentError
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
- * Association loading isn't to be affected by scoping consistently
619
- whether preloaded / eager loaded or not, with the exception of `unscoped`.
663
+ * Remove deprecated methods from `ActiveRecord::DatabaseConfigurations`.
620
664
 
621
- Before:
665
+ `fetch`
666
+ `each`
667
+ `first`
668
+ `values`
669
+ `[]=`
622
670
 
623
- ```ruby
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
- After:
673
+ * `where.not` now generates NAND predicates instead of NOR.
632
674
 
633
- ```ruby
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
- Fixes #34638, #35398.
677
+ User.where.not(name: "Jon", role: "admin")
678
+ # SELECT * FROM users WHERE name != 'Jon' AND role != 'admin'
642
679
 
643
- *Ryuta Kamizono*
680
+ After:
644
681
 
645
- * Add `rails db:prepare` to migrate or setup a database.
682
+ User.where.not(name: "Jon", role: "admin")
683
+ # SELECT * FROM users WHERE NOT (name == 'Jon' AND role == 'admin')
646
684
 
647
- Runs `db:migrate` if the database exists or `db:setup` if it doesn't.
685
+ *Rafael Mendonça França*
648
686
 
649
- *Roberto Miranda*
687
+ * Remove deprecated `ActiveRecord::Result#to_hash` method.
650
688
 
651
- * Add `after_save_commit` callback as shortcut for `after_commit :hook, on: [ :create, :update ]`.
689
+ *Rafael Mendonça França*
652
690
 
653
- *DHH*
691
+ * Deprecate `ActiveRecord::Base.allow_unsafe_raw_sql`.
654
692
 
655
- * Assign all attributes before calling `build` to ensure the child record is visible in
656
- `before_add` and `after_add` callbacks for `has_many :through` associations.
693
+ *Rafael Mendonça França*
657
694
 
658
- Fixes #33249.
695
+ * Remove deprecated support for using unsafe raw SQL in `ActiveRecord::Relation` methods.
659
696
 
660
- *Ryan H. Kerr*
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
- * Add `ActiveRecord::Relation#extract_associated` for extracting associated records from a relation.
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
- account.memberships.extract_associated(:user)
666
- # => Returns collection of User records
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
- *DHH*
748
+ Similar to `Hash#values_at` but on an Active Record instance.
670
749
 
671
- * Add `ActiveRecord::Relation#annotate` for adding SQL comments to its queries.
750
+ *Guillaume Briday*
672
751
 
673
- For example:
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
- Post.where(id: 123).annotate("this is a comment").to_sql
677
- # SELECT "posts".* FROM "posts" WHERE "posts"."id" = 123 /* this is a comment */
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
- This can be useful in instrumentation or other analysis of issued queries.
777
+ Fixes #40287.
681
778
 
682
- *Matt Yoho*
779
+ *Eugene Kenny*
683
780
 
684
- * Support Optimizer Hints.
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
- In most databases, a way to control the optimizer is by using optimizer hints,
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
- Example (for MySQL):
789
+ attribute :duration, :interval
690
790
 
691
- Topic.optimizer_hints("MAX_EXECUTION_TIME(50000)", "NO_INDEX_MERGE(topics)")
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
- Example (for PostgreSQL with pg_hint_plan):
793
+ attribute :duration, :string
695
794
 
696
- Topic.optimizer_hints("SeqScan(topics)", "Parallel(topics 8)")
697
- # SELECT /*+ SeqScan(topics) Parallel(topics 8) */ "topics".* FROM "topics"
795
+ Example:
698
796
 
699
- See also:
797
+ create_table :events do |t|
798
+ t.string :name
799
+ t.interval :duration
800
+ end
700
801
 
701
- * https://dev.mysql.com/doc/refman/8.0/en/optimizer-hints.html
702
- * https://pghintplan.osdn.jp/pg_hint_plan.html
703
- * https://docs.oracle.com/en/database/oracle/oracle-database/12.2/tgsql/influencing-the-optimizer.html
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
- *Ryuta Kamizono*
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
- * Fix query attribute method on user-defined attribute to be aware of typecasted value.
812
+ *Andrey Novikov*
710
813
 
711
- For example, the following code no longer return false as casted non-empty string:
814
+ * Allow associations supporting the `dependent:` key to take `dependent: :destroy_async`.
712
815
 
713
- ```
714
- class Post < ActiveRecord::Base
715
- attribute :user_defined_text, :text
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
- *Yuji Kamijima*
822
+ `:destroy_async` will enqueue a job to destroy associated records in the background.
722
823
 
723
- * Quote empty ranges like other empty enumerables.
824
+ *DHH*, *George Claghorn*, *Cory Gwin*, *Rafael Mendonça França*, *Adrianna Chang*
724
825
 
725
- *Patrick Rebsch*
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
- * Add `insert_all`/`insert_all!`/`upsert_all` methods to `ActiveRecord::Persistence`,
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
- Supports skipping or upserting duplicates through the `ON CONFLICT` syntax
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
- *Bob Lail*
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
- * Add `rails db:seed:replant` that truncates tables of each database
738
- for current environment and loads the seeds.
834
+ *Eileen M. Uchitelle*, *John Crepezzi*
739
835
 
740
- *bogdanvlviv*, *DHH*
836
+ * All connection adapters `execute` now raises `ActiveRecord::ConnectionNotEstablished` rather than
837
+ `ActiveRecord::StatementInvalid` when they encounter a connection error.
741
838
 
742
- * Add `ActiveRecord::Base.connection.truncate` for SQLite3 adapter.
839
+ *Jean Boussier*
743
840
 
744
- *bogdanvlviv*
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
- * Deprecate mismatched collation comparison for uniqueness validator.
844
+ *Jean Boussier*
747
845
 
748
- Uniqueness validator will no longer enforce case sensitive comparison in Rails 6.1.
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
- *Ryuta Kamizono*
848
+ *Alex Robbin*
753
849
 
754
- * Add `reselect` method. This is a short-hand for `unscope(:select).select(fields)`.
850
+ * Ensure the default configuration is considered primary or first for an environment
755
851
 
756
- Fixes #27340.
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
- *Willian Gustavo Veiga*
854
+ *Eileen M. Uchitelle*
759
855
 
760
- * Add negative scopes for all enum values.
856
+ * Allow `where` references association names as joined table name aliases.
761
857
 
762
- Example:
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
- class Post < ActiveRecord::Base
765
- enum status: %i[ drafted active trashed ]
766
- end
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
- Post.not_drafted # => where.not(status: :drafted)
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
- *DHH*
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
- * Fix different `count` calculation when using `size` with manual `select` with DISTINCT.
875
+ Now `store_full_class_name` class attribute can handle both STI and polymorphic types.
775
876
 
776
- Fixes #35214.
877
+ *Ryuta Kamizono*
777
878
 
778
- *Juani Villarejo*
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
- ## Rails 6.0.0.beta3 (March 11, 2019) ##
885
+ * Respect the `select` values for eager loading.
782
886
 
783
- * No changes.
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
- ## Rails 6.0.0.beta2 (February 25, 2019) ##
905
+ * Allow attribute's default to be configured but keeping its own type.
787
906
 
788
- * Fix prepared statements caching to be enabled even when query caching is enabled.
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
- * Ensure `update_all` series cares about optimistic locking.
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
- * Don't allow `where` with non numeric string matches to 0 values.
933
+ * Deprecate YAML loading from legacy format older than Rails 5.0.
797
934
 
798
935
  *Ryuta Kamizono*
799
936
 
800
- * Introduce `ActiveRecord::Relation#destroy_by` and `ActiveRecord::Relation#delete_by`.
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
- `destroy_by` allows relation to find all the records matching the condition and perform
803
- `destroy_all` on the matched records.
942
+ *Sean Griffin*, *Ryuta Kamizono*
804
943
 
805
- Example:
944
+ * Deprecate `map!` and `collect!` on `ActiveRecord::Result`.
806
945
 
807
- Person.destroy_by(name: 'David')
808
- Person.destroy_by(name: 'David', rating: 4)
946
+ *Ryuta Kamizono*
809
947
 
810
- david = Person.find_by(name: 'David')
811
- david.posts.destroy_by(id: [1, 2, 3])
948
+ * Support `relation.and` for intersection as Set theory.
812
949
 
813
- `delete_by` allows relation to find all the records matching the condition and perform
814
- `delete_all` on the matched records.
950
+ ```ruby
951
+ david_and_mary = Author.where(id: [david, mary])
952
+ mary_and_bob = Author.where(id: [mary, bob])
815
953
 
816
- Example:
954
+ david_and_mary.merge(mary_and_bob) # => [mary, bob]
817
955
 
818
- Person.delete_by(name: 'David')
819
- Person.delete_by(name: 'David', rating: 4)
956
+ david_and_mary.and(mary_and_bob) # => [mary]
957
+ david_and_mary.or(mary_and_bob) # => [david, mary, bob]
958
+ ```
820
959
 
821
- david = Person.find_by(name: 'David')
822
- david.posts.delete_by(id: [1, 2, 3])
960
+ *Ryuta Kamizono*
823
961
 
824
- *Abhay Nikam*
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
- * Don't allow `where` with invalid value matches to nil values.
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
- Fixes #33624.
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
- *Ryuta Kamizono*
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
- * SQLite3: Implement `add_foreign_key` and `remove_foreign_key`.
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
- * Deprecate using class level querying methods if the receiver scope
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
- *Ryuta Kamizono*
985
+ *Peter Fry*
840
986
 
841
- * Allow applications to automatically switch connections.
987
+ * Resolve issue with insert_all unique_by option when used with expression index.
842
988
 
843
- Adds a middleware and configuration options that can be used in your
844
- application to automatically switch between the writing and reading
845
- database connections.
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
- `GET` and `HEAD` requests will read from the replica unless there was
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
- To use the middleware in your application you can use the following
855
- configuration options:
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
- config.active_record.database_selector = { delay: 2.seconds }
859
- config.active_record.database_resolver = ActiveRecord::Middleware::DatabaseSelector::Resolver
860
- config.active_record.database_resolver_context = ActiveRecord::Middleware::DatabaseSelector::Resolver::Session
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
- To change the database selection strategy, pass a custom class to the
864
- configuration options:
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
- config.active_record.database_selector = { delay: 10.seconds }
868
- config.active_record.database_resolver = MyResolver
869
- config.active_record.database_resolver_context = MyResolver::MyCookies
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
- *Eileen M. Uchitelle*
1052
+ After:
873
1053
 
874
- * MySQL: Support `:size` option to change text and blob size.
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
- * Make `t.timestamps` with precision by default.
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
- ## Rails 6.0.0.beta1 (January 18, 2019) ##
1092
+ To migrate to Rails 7.0's behavior, use `uniq!(:annotate)` to deduplicate query annotations.
884
1093
 
885
- * Remove deprecated `#set_state` from the transaction object.
1094
+ ```ruby
1095
+ accounts = Account.where(id: [1, 2]).annotate("david and mary")
886
1096
 
887
- *Rafael Mendonça França*
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
- * Remove deprecated `#supports_statement_cache?` from the database adapters.
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
- *Rafael Mendonça França*
1106
+ *Ryuta Kamizono*
892
1107
 
893
- * Remove deprecated `#insert_fixtures` from the database adapters.
1108
+ * Resolve conflict between counter cache and optimistic locking.
894
1109
 
895
- *Rafael Mendonça França*
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
- * Remove deprecated `ActiveRecord::ConnectionAdapters::SQLite3Adapter#valid_alter_table_type?`.
1115
+ Fixes #16449.
898
1116
 
899
- *Rafael Mendonça França*
1117
+ *Aaron Lipman*
900
1118
 
901
- * Do not allow passing the column name to `sum` when a block is passed.
1119
+ * Support merging option `:rewhere` to allow mergee side condition to be replaced exactly.
902
1120
 
903
- *Rafael Mendonça França*
1121
+ ```ruby
1122
+ david_and_mary = Author.where(id: david.id..mary.id)
904
1123
 
905
- * Do not allow passing the column name to `count` when a block is passed.
1124
+ # both conflict conditions exists
1125
+ david_and_mary.merge(Author.where(id: bob)) # => []
906
1126
 
907
- *Rafael Mendonça França*
1127
+ # mergee side condition is replaced by rewhere
1128
+ david_and_mary.merge(Author.rewhere(id: bob)) # => [bob]
908
1129
 
909
- * Remove delegation of missing methods in a relation to arel.
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
- *Rafael Mendonça França*
1134
+ *Ryuta Kamizono*
912
1135
 
913
- * Remove delegation of missing methods in a relation to private methods of the class.
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
- *Rafael Mendonça França*
1141
+ ```ruby
1142
+ signed_id = User.first.signed_id expires_in: 15.minutes, purpose: :password_reset
916
1143
 
917
- * Deprecate `config.active_record.sqlite3.represent_boolean_as_integer`.
1144
+ User.find_signed signed_id # => nil, since the purpose does not match
918
1145
 
919
- *Rafael Mendonça França*
1146
+ travel 16.minutes
1147
+ User.find_signed signed_id, purpose: :password_reset # => nil, since the signed id has expired
920
1148
 
921
- * Change `SQLite3Adapter` to always represent boolean values as integers.
1149
+ travel_back
1150
+ User.find_signed signed_id, purpose: :password_reset # => User.first
922
1151
 
923
- *Rafael Mendonça França*
1152
+ User.find_signed! "bad data" # => ActiveSupport::MessageVerifier::InvalidSignature
1153
+ ```
924
1154
 
925
- * Remove ability to specify a timestamp name for `#cache_key`.
1155
+ *DHH*
926
1156
 
927
- *Rafael Mendonça França*
1157
+ * Support `ALGORITHM = INSTANT` DDL option for index operations on MySQL.
928
1158
 
929
- * Remove deprecated `ActiveRecord::Migrator.migrations_path=`.
1159
+ *Ryuta Kamizono*
930
1160
 
931
- *Rafael Mendonça França*
1161
+ * Fix index creation to preserve index comment in bulk change table on MySQL.
932
1162
 
933
- * Remove deprecated `expand_hash_conditions_for_aggregates`.
1163
+ *Ryuta Kamizono*
934
1164
 
935
- *Rafael Mendonça França*
1165
+ * Allow `unscope` to be aware of table name qualified values.
936
1166
 
937
- * Set polymorphic type column to NULL on `dependent: :nullify` strategy.
1167
+ It is possible to unscope only the column in the specified table.
938
1168
 
939
- On polymorphic associations both the foreign key and the foreign type columns will be set to NULL.
1169
+ ```ruby
1170
+ posts = Post.joins(:comments).group(:"posts.hidden")
1171
+ posts = posts.where("posts.hidden": false, "comments.hidden": false)
940
1172
 
941
- *Laerti Papa*
1173
+ posts.count
1174
+ # => { false => 10 }
942
1175
 
943
- * Allow permitted instance of `ActionController::Parameters` as argument of `ActiveRecord::Relation#exists?`.
1176
+ # unscope both hidden columns
1177
+ posts.unscope(where: :hidden).count
1178
+ # => { false => 11, true => 1 }
944
1179
 
945
- *Gannon McGibbon*
1180
+ # unscope only comments.hidden column
1181
+ posts.unscope(where: :"comments.hidden").count
1182
+ # => { false => 11 }
1183
+ ```
946
1184
 
947
- * Add support for endless ranges introduces in Ruby 2.6.
1185
+ *Ryuta Kamizono*, *Slava Korolev*
948
1186
 
949
- *Greg Navis*
1187
+ * Fix `rewhere` to truly overwrite collided where clause by new where clause.
950
1188
 
951
- * Deprecate passing `migrations_paths` to `connection.assume_migrated_upto_version`.
1189
+ ```ruby
1190
+ steve = Person.find_by(name: "Steve")
1191
+ david = Author.find_by(name: "David")
952
1192
 
953
- *Ryuta Kamizono*
1193
+ relation = Essay.where(writer: steve)
954
1194
 
955
- * MySQL: `ROW_FORMAT=DYNAMIC` create table option by default.
1195
+ # Before
1196
+ relation.rewhere(writer: david).to_a # => []
956
1197
 
957
- Since MySQL 5.7.9, the `innodb_default_row_format` option defines the default row
958
- format for InnoDB tables. The default setting is `DYNAMIC`.
959
- The row format is required for indexing on `varchar(255)` with `utf8mb4` columns.
1198
+ # After
1199
+ relation.rewhere(writer: david).to_a # => [david]
1200
+ ```
960
1201
 
961
1202
  *Ryuta Kamizono*
962
1203
 
963
- * Fix join table column quoting with SQLite.
1204
+ * Inspect time attributes with subsec and time zone offset.
964
1205
 
965
- *Gannon McGibbon*
1206
+ ```ruby
1207
+ p Knot.create
1208
+ => #<Knot id: 1, created_at: "2016-05-05 01:29:47.116928000 +0000">
1209
+ ```
966
1210
 
967
- * Allow disabling scopes generated by `ActiveRecord.enum`.
1211
+ *akinomaeni*, *Jonathan Hefner*
968
1212
 
969
- *Alfred Dominic*
1213
+ * Deprecate passing a column to `type_cast`.
1214
+
1215
+ *Ryuta Kamizono*
970
1216
 
971
- * Ensure that `delete_all` on collection proxy returns affected count.
1217
+ * Deprecate `in_clause_length` and `allowed_index_name_length` in `DatabaseLimits`.
972
1218
 
973
1219
  *Ryuta Kamizono*
974
1220
 
975
- * Reset scope after delete on collection association to clear stale offsets of removed records.
1221
+ * Support bulk insert/upsert on relation to preserve scope values.
976
1222
 
977
- *Gannon McGibbon*
1223
+ *Josef Šimánek*, *Ryuta Kamizono*
978
1224
 
979
- * Add the ability to prevent writes to a database for the duration of a block.
1225
+ * Preserve column comment value on changing column name on MySQL.
980
1226
 
981
- Allows the application to prevent writes to a database. This can be useful when
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
- If `while_preventing_writes` is called and the query is considered a write
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
- This is not meant to be a catch-all for write queries but rather a way to enforce
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
- * Allow aliased attributes to be used in `#update_columns` and `#update`.
1235
+ * Remove ibm_db, informix, mssql, oracle, and oracle12 Arel visitors which are not used in the code base.
996
1236
 
997
- *Gannon McGibbon*
1237
+ *Ryuta Kamizono*
998
1238
 
999
- * Allow spaces in postgres table names.
1239
+ * Prevent `build_association` from `touching` a parent record if the record isn't persisted for `has_one` associations.
1000
1240
 
1001
- Fixes issue where "user post" is misinterpreted as "\"user\".\"post\"" when quoting table names with the postgres adapter.
1241
+ Fixes #38219.
1002
1242
 
1003
- *Gannon McGibbon*
1243
+ *Josh Brody*
1244
+
1245
+ * Add support for `if_not_exists` option for adding index.
1004
1246
 
1005
- * Cached `columns_hash` fields should be excluded from `ResultSet#column_types`.
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
- PR #34528 addresses the inconsistent behaviour when attribute is defined for an ignored column. The following test
1008
- was passing for SQLite and MySQL, but failed for PostgreSQL:
1250
+ Usage:
1009
1251
 
1010
1252
  ```ruby
1011
- class DeveloperName < ActiveRecord::Type::String
1012
- def deserialize(value)
1013
- "Developer: #{value}"
1014
- end
1015
- end
1253
+ add_index :users, :account_id, if_not_exists: true
1254
+ ```
1016
1255
 
1017
- class AttributedDeveloper < ActiveRecord::Base
1018
- self.table_name = "developers"
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
- attribute :name, DeveloperName.new
1260
+ *Prathamesh Sonpatki*
1021
1261
 
1022
- self.ignored_columns += ["name"]
1023
- end
1262
+ * Add `ActiveRecord::Base#previously_new_record?` to show if a record was new before the last save.
1024
1263
 
1025
- developer = AttributedDeveloper.create
1026
- developer.update_column :name, "name"
1264
+ *Tom Ward*
1027
1265
 
1028
- loaded_developer = AttributedDeveloper.where(id: developer.id).select("*").first
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
- *Dmitry Tsepelev*
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
- * Make the implicit order column configurable.
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
- When calling ordered finder methods such as `first` or `last` without an
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
- Example:
1274
+ ```ruby
1275
+ Person.find_each(order: :desc) do |person|
1276
+ person.party_all_night!
1277
+ end
1278
+ ```
1044
1279
 
1045
- class Project < ActiveRecord::Base
1046
- self.implicit_order_column = "created_at"
1047
- end
1280
+ *Alexey Vasiliev*
1048
1281
 
1049
- *Tekin Suleyman*
1282
+ * Fix `insert_all` with enum values.
1050
1283
 
1051
- * Bump minimum PostgreSQL version to 9.3.
1284
+ Fixes #38716.
1052
1285
 
1053
- *Yasuo Honda*
1286
+ *Joel Blum*
1054
1287
 
1055
- * Values of enum are frozen, raising an error when attempting to modify them.
1288
+ * Add support for `db:rollback:name` for multiple database applications.
1056
1289
 
1057
- *Emmanuel Byrd*
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
- * Move `ActiveRecord::StatementInvalid` SQL to error property and include binds as separate error property.
1292
+ *Eileen M. Uchitelle*
1060
1293
 
1061
- `ActiveRecord::ConnectionAdapters::AbstractAdapter#translate_exception_class` now requires `binds` to be passed as the last argument.
1294
+ * `Relation#pick` now uses already loaded results instead of making another query.
1062
1295
 
1063
- `ActiveRecord::ConnectionAdapters::AbstractAdapter#translate_exception` now requires `message`, `sql`, and `binds` to be passed as keyword arguments.
1296
+ *Eugene Kenny*
1064
1297
 
1065
- Subclasses of `ActiveRecord::StatementInvalid` must now provide `sql:` and `binds:` arguments to `super`.
1298
+ * Deprecate using `return`, `break` or `throw` to exit a transaction block after writes.
1066
1299
 
1067
- Example:
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
- *Gannon McGibbon*
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
- * Add an `:if_not_exists` option to `create_table`.
1306
+ Going forward, calls to `rails db:migrate:name` will dump the schema (or structure) of the database being migrated.
1080
1307
 
1081
- Example:
1308
+ *Kyle Thompson*
1082
1309
 
1083
- create_table :posts, if_not_exists: true do |t|
1084
- t.string :title
1085
- end
1310
+ * Reset the `ActiveRecord::Base` connection after `rails db:migrate:name`.
1086
1311
 
1087
- That would execute:
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
- CREATE TABLE IF NOT EXISTS posts (
1090
- ...
1091
- )
1314
+ *Kyle Thompson*
1092
1315
 
1093
- If the table already exists, `if_not_exists: false` (the default) raises an
1094
- exception whereas `if_not_exists: true` does nothing.
1316
+ * Disallow calling `connected_to` on subclasses of `ActiveRecord::Base`.
1095
1317
 
1096
- *fatkodima*, *Stefan Kanev*
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
- * Defining an Enum as a Hash with blank key, or as an Array with a blank value, now raises an `ArgumentError`.
1320
+ *Eileen M. Uchitelle*, *John Crepezzi*
1099
1321
 
1100
- *Christophe Maximin*
1322
+ * Add support for horizontal sharding to `connects_to` and `connected_to`.
1101
1323
 
1102
- * Adds support for multiple databases to `rails db:schema:cache:dump` and `rails db:schema:cache:clear`.
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
- *Gannon McGibbon*
1326
+ Usage:
1105
1327
 
1106
- * `update_columns` now correctly raises `ActiveModel::MissingAttributeError`
1107
- if the attribute does not exist.
1328
+ Given the following configuration:
1108
1329
 
1109
- *Sean Griffin*
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
- * Add support for hash and URL configs in database hash of `ActiveRecord::Base.connected_to`.
1339
+ Connect to multiple shards:
1112
1340
 
1113
- ````
1114
- User.connected_to(database: { writing: "postgres://foo" }) do
1115
- User.create!(name: "Gannon")
1116
- end
1341
+ ```ruby
1342
+ class ApplicationRecord < ActiveRecord::Base
1343
+ self.abstract_class = true
1117
1344
 
1118
- config = { "adapter" => "sqlite3", "database" => "db/readonly.sqlite3" }
1119
- User.connected_to(database: { reading: config }) do
1120
- User.count
1121
- end
1122
- ````
1345
+ connects_to shards: {
1346
+ default: { writing: :primary },
1347
+ shard_one: { writing: :primary_shard_one }
1348
+ }
1349
+ ```
1123
1350
 
1124
- *Gannon McGibbon*
1351
+ Swap between shards in your controller / model code:
1125
1352
 
1126
- * Support default expression for MySQL.
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
- MySQL 8.0.13 and higher supports default value to be a function or expression.
1361
+ *Eileen M. Uchitelle*, *John Crepezzi*
1129
1362
 
1130
- https://dev.mysql.com/doc/refman/8.0/en/create-table.html
1363
+ * Deprecate `spec_name` in favor of `name` on database configurations.
1131
1364
 
1132
- *Ryuta Kamizono*
1365
+ The accessors for `spec_name` on `configs_for` and `DatabaseConfig` are deprecated. Please use `name` instead.
1133
1366
 
1134
- * Support expression indexes for MySQL.
1367
+ Deprecated behavior:
1135
1368
 
1136
- MySQL 8.0.13 and higher supports functional key parts that index
1137
- expression values rather than column or column prefix values.
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
- https://dev.mysql.com/doc/refman/8.0/en/create-index.html
1374
+ New behavior:
1140
1375
 
1141
- *Ryuta Kamizono*
1376
+ ```ruby
1377
+ db_config = ActiveRecord::Base.configurations.configs_for(env_name: "development", name: "primary")
1378
+ db_config.name
1379
+ ```
1142
1380
 
1143
- * Fix collection cache key with limit and custom select to avoid ambiguous timestamp column error.
1381
+ *Eileen M. Uchitelle*
1144
1382
 
1145
- Fixes #33056.
1383
+ * Add additional database-specific rake tasks for multi-database users.
1146
1384
 
1147
- *Federico Martinez*
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
- * Add basic API for connection switching to support multiple databases.
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
- 1) Adds a `connects_to` method for models to connect to multiple databases. Example:
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
- class AnimalsModel < ApplicationRecord
1155
- self.abstract_class = true
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
- connects_to database: { writing: :animals_primary, reading: :animals_replica }
1158
- end
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
- class Dog < AnimalsModel
1161
- # connected to both the animals_primary db for writing and the animals_replica for reading
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
- 2) Adds a `connected_to` block method for switching connection roles or connecting to
1166
- a database that the model didn't connect to. Connecting to the database in this block is
1167
- useful when you have another defined connection, for example `slow_replica` that you don't
1168
- want to connect to by default but need in the console, or a specific code block.
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
- ActiveRecord::Base.connected_to(role: :reading) do
1172
- Dog.first # finds dog from replica connected to AnimalsBase
1173
- Book.first # doesn't have a reading connection, will raise an error
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::Base.connected_to(database: :slow_replica) do
1179
- SlowReplicaModel.first # if the db config has a slow_replica configuration this will be used to do the lookup, otherwise this will throw an exception
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
- * Enum raises on invalid definition values
1483
+ * Regexp-escape table name for MS SQL Server.
1186
1484
 
1187
- When defining a Hash enum it can be easy to use `[]` instead of `{}`. This
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
- Fixes #33961
1487
+ *Larry Reid*
1193
1488
 
1194
- *Alberto Almagro*
1489
+ * Store advisory locks on their own named connection.
1195
1490
 
1196
- * Reloading associations now clears the Query Cache like `Persistence#reload` does.
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
- class Post < ActiveRecord::Base
1200
- has_one :category
1201
- belongs_to :author
1202
- has_many :comments
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
- # Each of the following will now clear the query cache.
1206
- post.reload_category
1207
- post.reload_author
1208
- post.comments.reload
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
- *Christophe Maximin*
1509
+ *Katrina Owen*
1212
1510
 
1213
- * Added `index` option for `change_table` migration helpers.
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
- Example:
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
- change_table(:languages) do |t|
1220
- t.string :country_code, index: true
1221
- end
1515
+ *Eileen M. Uchitelle*, *John Crepezzi*
1516
+
1517
+ * Deprecate `#default_hash` and it's alias `#[]` on database configurations.
1222
1518
 
1223
- *Mehmet Emin İNAÇ*
1519
+ Applications should use `configs_for`. `#default_hash` and `#[]` will be removed in Rails 7.0.
1224
1520
 
1225
- * Fix `transaction` reverting for migrations.
1521
+ *Eileen M. Uchitelle*, *John Crepezzi*
1226
1522
 
1227
- Before: Commands inside a `transaction` in a reverted migration ran uninverted.
1228
- Now: This change fixes that by reverting commands inside `transaction` block.
1523
+ * Add scale support to `ActiveRecord::Validations::NumericalityValidator`.
1229
1524
 
1230
- *fatkodima*, *David Verhasselt*
1525
+ *Gannon McGibbon*
1231
1526
 
1232
- * Raise an error instead of scanning the filesystem root when `fixture_path` is blank.
1527
+ * Find orphans by looking for missing relations through chaining `where.missing`:
1233
1528
 
1234
- *Gannon McGibbon*, *Max Albrecht*
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
- * Allow `ActiveRecord::Base.configurations=` to be set with a symbolized hash.
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
- * Don't update counter cache unless the record is actually saved.
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 #31493, #33113, #33117.
1566
+ Fixes #38078.
1243
1567
 
1244
- *Ryuta Kamizono*
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
- * Deprecate `ActiveRecord::Result#to_hash` in favor of `ActiveRecord::Result#to_a`.
1575
+ * Don't allow mutations on the database configurations hash.
1247
1576
 
1248
- *Gannon McGibbon*, *Kevin Cheng*
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
- * SQLite3 adapter supports expression indexes.
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
- add_index :users, 'lower(email)', name: 'index_users_on_email', unique: true
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
- *Gray Kemmey*
1594
+ *Eileen M. Uchitelle*, *John Crepezzi*
1261
1595
 
1262
- * Allow subclasses to redefine autosave callbacks for associated records.
1596
+ * Remove `:connection_id` from the `sql.active_record` notification.
1263
1597
 
1264
- Fixes #33305.
1598
+ *Aaron Patterson*, *Rafael Mendonça França*
1265
1599
 
1266
- *Andrey Subbota*
1600
+ * The `:name` key will no longer be returned as part of `DatabaseConfig#configuration_hash`. Please use `DatabaseConfig#owner_name` instead.
1267
1601
 
1268
- * Bump minimum MySQL version to 5.5.8.
1602
+ *Eileen M. Uchitelle*, *John Crepezzi*
1269
1603
 
1270
- *Yasuo Honda*
1604
+ * ActiveRecord's `belongs_to_required_by_default` flag can now be set per model.
1271
1605
 
1272
- * Use MySQL utf8mb4 character set by default.
1606
+ You can now opt-out/opt-in specific models from having their associations required
1607
+ by default.
1273
1608
 
1274
- `utf8mb4` character set with 4-Byte encoding supports supplementary characters including emoji.
1275
- The previous default 3-Byte encoding character set `utf8` is not enough to support them.
1609
+ This change is meant to ease the process of migrating all your models to have
1610
+ their association required.
1276
1611
 
1277
- *Yasuo Honda*
1612
+ *Edouard Chin*
1278
1613
 
1279
- * Fix duplicated record creation when using nested attributes with `create_with`.
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
- *Darwin Wu*
1616
+ *Eileen M. Uchitelle*, *John Crepezzi*
1282
1617
 
1283
- * Configuration item `config.filter_parameters` could also filter out
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
- *Zhang Kang*, *Yoshiyuki Kinjo*
1622
+ *Patrick Rebsch*
1296
1623
 
1297
- * Deprecate `column_name_length`, `table_name_length`, `columns_per_table`,
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
- *Ryuta Kamizono*
1626
+ *Eileen M. Uchitelle*, *John Crepezzi*
1302
1627
 
1303
- * `ActiveRecord::Base.configurations` now returns an object.
1628
+ * Allow attributes to be fetched from Arel node groupings.
1304
1629
 
1305
- `ActiveRecord::Base.configurations` used to return a hash, but this
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
- For example, the following `database.yml`:
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
- Used to become a hash:
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
- Is now converted into the following object:
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
- Iterating over the database configurations has also changed. Instead of
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
- *Eileen M. Uchitelle*, *Aaron Patterson*
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
- * Add database configuration to disable advisory locks.
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
- production:
1355
- adapter: postgresql
1356
- advisory_locks: false
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
- *Guo Xiang*
1673
+ *Bernardo de Araujo*
1360
1674
 
1361
- * SQLite3 adapter `alter_table` method restores foreign keys.
1675
+ * Deprecate `DatabaseConfigurations#to_h`. These connection hashes are still available via `ActiveRecord::Base.configurations.configs_for`.
1362
1676
 
1363
- *Yasuo Honda*
1677
+ *Eileen Uchitelle*, *John Crepezzi*
1364
1678
 
1365
- * Allow `:to_table` option to `invert_remove_foreign_key`.
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
- Example:
1681
+ *John Crepezzi*, *Eileen Uchitelle*
1368
1682
 
1369
- remove_foreign_key :accounts, to_table: :owners
1683
+ * Allow column names to be passed to `remove_index` positionally along with other options.
1370
1684
 
1371
- *Nikolay Epifanov*, *Rich Chen*
1685
+ Passing other options can be necessary to make `remove_index` correctly reversible.
1372
1686
 
1373
- * Add environment & load_config dependency to `bin/rake db:seed` to enable
1374
- seed load in environments without Rails and custom DB configuration
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
- *Tobias Bielohlawek*
1694
+ After:
1377
1695
 
1378
- * Fix default value for mysql time types with specified precision.
1696
+ remove_index :reports, :report_id, unique: true # => works
1379
1697
 
1380
- *Nikolay Kondratyev*
1698
+ *Eugene Kenny*
1381
1699
 
1382
- * Fix `touch` option to behave consistently with `Persistence#touch` method.
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
- * Migrations raise when duplicate column definition.
1730
+ * Preserve user supplied joins order as much as possible.
1387
1731
 
1388
- Fixes #33024.
1732
+ Fixes #36761, #34328, #24281, #12953.
1389
1733
 
1390
- *Federico Martinez*
1734
+ *Ryuta Kamizono*
1391
1735
 
1392
- * Bump minimum SQLite version to 3.8
1736
+ * Allow `matches_regex` and `does_not_match_regexp` on the MySQL Arel visitor.
1393
1737
 
1394
- *Yasuo Honda*
1738
+ *James Pearson*
1395
1739
 
1396
- * Fix parent record should not get saved with duplicate children records.
1740
+ * Allow specifying fixtures to be ignored by setting `ignore` in YAML file's '_fixture' section.
1397
1741
 
1398
- Fixes #32940.
1742
+ *Tongfei Gao*
1399
1743
 
1400
- *Santosh Wadghule*
1744
+ * Make the DATABASE_URL env variable only affect the primary connection. Add new env variables for multiple databases.
1401
1745
 
1402
- * Fix logic on disabling commit callbacks so they are not called unexpectedly when errors occur.
1746
+ *John Crepezzi*, *Eileen Uchitelle*
1403
1747
 
1404
- *Brian Durand*
1748
+ * Add a warning for enum elements with 'not_' prefix.
1405
1749
 
1406
- * Ensure `Associations::CollectionAssociation#size` and `Associations::CollectionAssociation#empty?`
1407
- use loaded association ids if present.
1750
+ class Foo
1751
+ enum status: [:sent, :not_sent]
1752
+ end
1408
1753
 
1409
- *Graham Turner*
1754
+ *Edu Depetris*
1410
1755
 
1411
- * Add support to preload associations of polymorphic associations when not all the records have the requested associations.
1756
+ * Make currency symbols optional for money column type in PostgreSQL.
1412
1757
 
1413
- *Dana Sherson*
1758
+ *Joel Schneider*
1414
1759
 
1415
- * Add `touch_all` method to `ActiveRecord::Relation`.
1760
+ * Add support for beginless ranges, introduced in Ruby 2.7.
1416
1761
 
1417
- Example:
1762
+ *Josh Goodall*
1418
1763
 
1419
- Person.where(name: "David").touch_all(time: Time.new(2020, 5, 16, 0, 0, 0))
1764
+ * Add `database_exists?` method to connection adapters to check if a database exists.
1420
1765
 
1421
- *fatkodima*, *duggiefresh*
1766
+ *Guilherme Mansur*
1422
1767
 
1423
- * Add `ActiveRecord::Base.base_class?` predicate.
1768
+ * Loading the schema for a model that has no `table_name` raises a `TableNotSpecified` error.
1424
1769
 
1425
- *Bogdan Gusiev*
1770
+ *Guilherme Mansur*, *Eugene Kenny*
1426
1771
 
1427
- * Add custom prefix/suffix options to `ActiveRecord::Store.store_accessor`.
1772
+ * PostgreSQL: Fix GROUP BY with ORDER BY virtual count attribute.
1428
1773
 
1429
- *Tan Huynh*, *Yukio Mizuta*
1774
+ Fixes #36022.
1430
1775
 
1431
- * Rails 6 requires Ruby 2.5.0 or newer.
1776
+ *Ryuta Kamizono*
1432
1777
 
1433
- *Jeremy Daer*, *Kasper Timm Hansen*
1778
+ * Make ActiveRecord `ConnectionPool.connections` method thread-safe.
1434
1779
 
1435
- * Deprecate `update_attributes`/`!` in favor of `update`/`!`.
1780
+ Fixes #36465.
1436
1781
 
1437
- *Eddie Lebow*
1782
+ *Jeff Doering*
1438
1783
 
1439
- * Add `ActiveRecord::Base.create_or_find_by`/`!` to deal with the SELECT/INSERT race condition in
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
- *DHH*
1786
+ *Mark Lee*
1443
1787
 
1444
- * Add `Relation#pick` as short-hand for single-value plucks.
1788
+ * Fix sqlite3 collation parsing when using decimal columns.
1445
1789
 
1446
- *DHH*
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 [5-2-stable](https://github.com/rails/rails/blob/5-2-stable/activerecord/CHANGELOG.md) for previous changes.
1807
+ Please check [6-0-stable](https://github.com/rails/rails/blob/6-0-stable/activerecord/CHANGELOG.md) for previous changes.