CHANGELOG.md 6.4 KB
Newer Older
1 2 3 4 5 6 7 8 9
*   ActiveRecord's `belongs_to_required_by_default` flag can now be set per model.

    You can now opt-out/opt-in specific models from having their associations required
    by default.
    This change is meant to ease the process of migrating all your models to have
    their association required.

    *Edouard Chin*

J
John Crepezzi 已提交
10 11 12 13
*   The `connection_config` method has been deprecated, please use `connection_db_config` instead which will return a `DatabaseConfigurations::DatabaseConfig` instead of a `Hash`.

    *Eileen M. Uchitelle*, *John Crepezzi*

14 15 16 17 18 19
*   Retain explicit selections on the base model after applying `includes` and `joins`.

    Resolves #34889.

    *Patrick Rebsch*

20 21 22 23
*   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.

    *Eileen M. Uchitelle*, *John Crepezzi*

G
Gannon McGibbon 已提交
24 25 26 27
*   Allow attributes to be fetched from Arel node groupings.

    *Jeff Emminger*, *Gannon McGibbon*

28 29 30 31
*   A database URL can now contain a querystring value that contains an equal sign. This is needed to support passing PostgresSQL `options`.

    *Joshua Flanagan*

32 33 34 35
*   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`.

    *John Crepezzi*

36 37 38 39
*   Specifying `implicit_order_column` now subsorts the records by primary key if available to ensure deterministic results.

    *Paweł Urbanek*

J
John Hawthorn 已提交
40 41 42 43
*   `where(attr => [])` now loads an empty result without making a query.

    *John Hawthorn*

44 45 46 47
*   Fixed the performance regression for `primary_keys` introduced MySQL 8.0.

    *Hiroyuki Ishii*

48 49 50 51
*   Add support for `belongs_to` to `has_many` inversing.

    *Gannon McGibbon*

52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70
*   Allow length configuration for `has_secure_token` method. The minimum length
    is set at 24 characters.

    Before:

    ```ruby
    has_secure_token :auth_token
    ```

    After:

    ```ruby
    has_secure_token :default_token             # 24 characters
    has_secure_token :auth_token, length: 36    # 36 characters
    has_secure_token :invalid_token, length: 12 # => ActiveRecord::SecureToken::MinimumLengthError
    ```

    *Bernardo de Araujo*

71 72 73 74
*   Deprecate `DatabaseConfigurations#to_h`. These connection hashes are still available via `ActiveRecord::Base.configurations.configs_for`.

    *Eileen Uchitelle*, *John Crepezzi*

75 76 77 78
*   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.

    *John Crepezzi*, *Eileen Uchitelle*

79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95
*   Allow column names to be passed to `remove_index` positionally along with other options.

    Passing other options can be necessary to make `remove_index` correctly reversible.

    Before:

        add_index    :reports, :report_id               # => works
        add_index    :reports, :report_id, unique: true # => works
        remove_index :reports, :report_id               # => works
        remove_index :reports, :report_id, unique: true # => ArgumentError

    After:

        remove_index :reports, :report_id, unique: true # => works

    *Eugene Kenny*

96 97 98 99
*   Allow bulk `ALTER` statements to drop and recreate indexes with the same name.

    *Eugene Kenny*

100 101 102 103
*   `insert`, `insert_all`, `upsert`, and `upsert_all` now clear the query cache.

    *Eugene Kenny*

104
*   Call `while_preventing_writes` directly from `connected_to`.
105

106
    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)`.
107 108 109 110 111

    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.

    *Eileen M. Uchitelle*

112 113 114 115
*   Improve detection of ActiveRecord::StatementTimeout with mysql2 adapter in the edge case when the query is terminated during filesort.

    *Kir Shatrov*

116 117 118 119
*   Stop trying to read yaml file fixtures when loading Active Record fixtures.

    *Gannon McGibbon*

120 121 122 123 124 125
*   Deprecate `.reorder(nil)` with `.first` / `.first!` taking non-deterministic result.

    To continue taking non-deterministic result, use `.take` / `.take!` instead.

    *Ryuta Kamizono*

126 127 128 129
*   Ensure custom PK types are casted in through reflection queries.

    *Gannon McGibbon*

130 131 132 133 134 135
*   Preserve user supplied joins order as much as possible.

    Fixes #36761, #34328, #24281, #12953.

    *Ryuta Kamizono*

136
*   Allow `matches_regex` and `does_not_match_regexp` on the MySQL Arel visitor.
J
James Pearson 已提交
137 138

    *James Pearson*
139

140 141 142 143
*   Allow specifying fixtures to be ignored by setting `ignore` in YAML file's '_fixture' section.

    *Tongfei Gao*

144 145 146 147
*   Make the DATABASE_URL env variable only affect the primary connection. Add new env variables for multiple databases.

    *John Crepezzi*, *Eileen Uchitelle*

148 149 150 151 152 153 154 155
*   Add a warning for enum elements with 'not_' prefix.

        class Foo
          enum status: [:sent, :not_sent]
        end

    *Edu Depetris*

R
Ryuta Kamizono 已提交
156
*   Make currency symbols optional for money column type in PostgreSQL.
157 158 159

    *Joel Schneider*

160 161 162 163
*   Add support for beginless ranges, introduced in Ruby 2.7.

    *Josh Goodall*

164 165
*   Add database_exists? method to connection adapters to check if a database exists.

R
Roberto Miranda 已提交
166
    *Guilherme Mansur*
167

168 169 170 171
*   Loading the schema for a model that has no `table_name` raises a `TableNotSpecified` error.

    *Guilherme Mansur*, *Eugene Kenny*

172 173 174 175 176 177
*   PostgreSQL: Fix GROUP BY with ORDER BY virtual count attribute.

    Fixes #36022.

    *Ryuta Kamizono*

178 179 180 181 182 183
*   Make ActiveRecord `ConnectionPool.connections` method thread-safe.

    Fixes #36465.

    *Jeff Doering*

184 185 186 187
*   Add support for multiple databases to `rails db:abort_if_pending_migrations`.

    *Mark Lee*

188 189 190 191
*   Fix sqlite3 collation parsing when using decimal columns.

    *Martin R. Schuster*

192
*   Fix invalid schema when primary key column has a comment.
193

194
    Fixes #29966.
195 196 197

    *Guilherme Goettems Schneider*

198
*   Fix table comment also being applied to the primary key column.
199 200 201

    *Guilherme Goettems Schneider*

202
*   Allow generated `create_table` migrations to include or skip timestamps.
203

204 205
    *Michael Duchemin*

206

207
Please check [6-0-stable](https://github.com/rails/rails/blob/6-0-stable/activerecord/CHANGELOG.md) for previous changes.