File: 4.39.0.txt

package info (click to toggle)
ruby-sequel 5.63.0-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 10,408 kB
  • sloc: ruby: 113,747; makefile: 3
file content (127 lines) | stat: -rw-r--r-- 4,696 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
= New Features

* Sequel.[] has been added as an alias to Sequel.expr. This makes it
  a little easier to get Sequel-specific objects:

    Sequel[:table].*                  # "table".*
    Sequel[:table__column].as(:alias) # "table"."column" AS "alias"
    Sequel[:column] + 1               # ("column" + 1)

* The timestamps plugin now supports an :allow_manual_update option.
  If this option is used, the timestamps plugin will not override the 
  update timestamp when saving if the user has modified it since
  retrieving the object.

* The touch plugin now also touches associations on create in addition
  to update and delete.

* The IntegerMigrator now supports a :relative option, which will
  migrate that many migrations up (for positive numbers) or down (for
  negative numbers).

* Database#rollback_checker has been added, which returns a callable
  that can be called later to determine whether the transaction ended
  up committing or rolling back.  So if you may need to check
  transaction status at some future point, and don't need immediate
  action on rollback/commit, it is better to use a rollback checker
  than to add an after commit/rollback hook.

    rbc = nil
    DB.transaction do
      rbc = DB.rollback_checker
      rbc.call #=> nil
    end
    rbc.call # => false

    DB.transaction(:rollback=>:always) do
      rbc = DB.rollback_checker
    end
    rbc.call # => true

* The add_column schema method now supports an :if_not_exists option
  on PostgreSQL 9.6+, which will only add the column if it does not
  already exist:

    DB.add_column :t, :c, Integer, :if_not_exists=>true
    # ALTER TABLE "t" ADD COLUMN IF NOT EXISTS "c" integer

* The add_column schema method now supports an :after and :first
  option on MySQL to add the column after an existing column or as
  the first column:

    DB.add_column :t, :c, Integer, :first=>true
    # ALTER TABLE `t` ADD COLUMN `c` integer FIRST
    DB.add_column :t, :c1, Integer, :after=>:c2
    # ALTER TABLE `t` ADD COLUMN `c1` integer AFTER `c2`

* JSONBOp#insert has been added to the pg_json_ops extension, which
  supports the new jsonb_insert function added in PostgreSQL 9.6+:

    Sequel.pg_jsonb_op(:c).insert(%w'0 a', 'a'=>1)
    # jsonb_insert("c", ARRAY['0','a'], '{"a":1}'::jsonb, false)

* Dataset#full_text_search on PostgreSQL now supports a
  :to_tsquery=>:phrase option, to enable the native phrase searching
  added in PostgreSQL 9.6+:

    DB[:t].full_text_search(:c, 'foo bar', :to_tsquery=>:phrase)
    # SELECT * FROM "t"
    # WHERE
    #   (to_tsvector(CAST('simple' AS regconfig), (COALESCE("c", '')))
    #   @@ phraseto_tsquery(CAST('simple' AS regconfig), 'foo bar'))

* Sequel::Database.set_shared_adapter_scheme has been added, allowing
  external adapters to add support for Sequel's mock adapter.
  External adapters should have a shared adapter requirable at
  sequel/adapters/shared/adapter_name, that uses the following
  format:

    # in sequel/adapters/shared/mydb
    module Sequel::MyDB
      Sequel::Database.set_shared_adapter_scheme :mydb, self

      def self.mock_adapter_setup(db)
        # Any mock-adapter specific setup to perform on the
        # given Database instance
      end

      module DatabaseMethods
        # methods for all Database objects using this adapter
      end

      module DatasetMethods
        # methods for all Dataset objects using this adapter
      end
    end


= Other Improvements

* The hook_class_methods plugin only adds a Database transaction
  hook if one of the after commit/rollback hook class methods is
  actually used.  This means that loading the plugin no longer
  keeps all saved/deleted objects in memory until transaction
  commit.

* The active_model plugin now uses a rollback checker instead of
  an after_rollback hook, so models that use the active_model plugin
  no longer store all saved model instances in memory until
  transaction commit.

* When using the IntegerMigrator, attempting to migrate to a
  migration number above the maximum will now migrate to the lastest
  version, and attempting to migrate to a migration number below 0
  will now migrate all the way down.

* The pg_interval extension now supports ActiveSupport::Duration
  objects that use week and hour parts (new in ActiveSupport 5).

= Backwards Compatibility

* The change to the touch plugin to touch associations on create could
  possibly affect existing behavior, so if you are using this plugin,
  you should test that this does not cause any problems.

* External adapters that tried to add support for the mock adapter
  now need to update their code to use the new
  Sequel::Database.set_shared_adapter_scheme method.