File: 4.32.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 (132 lines) | stat: -rw-r--r-- 4,815 bytes parent folder | download | duplicates (5)
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
128
129
130
131
132
= New Features

* A no_auto_literal_strings extension has been added, which removes the
  automatic usage of strings in filter arguments as literal SQL code.
  By default, if you do:

    DB[:albums].where("name > 'N'")

  By default Sequel will treat "name > 'N'" as SQL code.  However,
  this makes it much easier to introduce SQL injection:

    # SQL Injection vulnerability in default Sequel
    DB[:albums].where("name > 'params[:letter]'")

  Sequel does support using placeholders when using literal strings:

    # Safe in default Sequel
    DB[:albums].where("name > ?", params[:letter])

  However, if you forget to use placeholders, you can end up with SQL
  injection.  Accidental usage of filter strings derived from user
  input as literal SQL code is probably the most common SQL injection
  vector in applications using Sequel.

  With the no_auto_literal_strings extension, passing a plain string
  as the first or only argument to a filter method raises an
  exception.  If you want to use literal SQL code, you have to do so
  explicitly:

    DB[:albums].where(Sequel.lit("name > 'N'"))

  You can also specify placeholders when using Sequel.lit:

    DB[:albums].where(Sequel.lit("name > ?", params[:letter]))

  Note that in many cases, you can avoid using literal SQL strings
  completely:

    DB[:albums].where{|v| v.name > params[:letter]}

* one_through_one associations now support a setter method:

    Foo.one_through_one :bar

    foo = Foo[1]
    foo.bar = Bar[2]
    foo.bar = nil

  This will check the current entry in the join table, and based on
  the argument and the current entry, run a DELETE, INSERT, or UPDATE
  query, or take no action if the join table is already in the
  correct state.

* Model.default_association_options has been added, which supports
  default options for all future associations.  You can use this to
  do:

    Model.default_association_options = {:read_only=>true}

  Which makes associations not create modification methods by default.
  You could still create the modification methods by passing
  :read_only=>true when creating association.

* The tactical_eager_loading plugin now supports two additional
  options when calling an association method: :eager and
  :eager_reload. Example:

    artist = Artist.all.first

    # Loads all albums for all of the artists,
    # and all tracks for all of those albums
    artist.albums(:eager=>:tracks)

    # Reload the artists association for all artists
    artist.albums(:eager_reload=>true)

  You can also use the :eager option for an eager loading callback:

    # Eagerly load the albums with names starting with A-M
    artist.albums(:eager=>proc{|ds| ds.where(:name > 'N')})

* The association_pks plugin now supports an :association_pks_nil
  association option in the association_pks setter, for determining
  how nil values should be handled.

  In Sequel <4.31.0, if you provided nil, it would either raise an
  exception immediately if :delay_pks was not set, or on saving if
  :delay_pks was set.

  In Sequel 4.31.0, if :delay_pks was not set, it would remove all
  associated rows.  If :delay_pks was set, it would do nothing.

  You can now set :association_pks_nil=>:remove to remove all
  associated values on nil, or :association_pks_nil=>:ignore to ignore
  a nil value passed to the method.  Without :association_pks_nil set,
  an exception will be raised.

* Dataset#delete_from has been added on MySQL, allowing deletions from
  multiple tables in a single query:

    DB[:a].join(:b, :a_id=>:id).delete_from(:a, :b).delete
    # DELETE a, b FROM a INNER JOIN b ON (b.a_id = a.id)

* The JDBC schema parser now includes a :remarks entry for each
  column, which contains comments on the column.

= Other Improvements

* The setter method added by the association_pks plugin now handles
  the empty array correctly when :delay_pks is set.  Previously, if
  the empty array was passed, Sequel made no modifications in this
  case.  Sequel now correctly removes all associated values if an
  empty array is passed.

* The eager_each plugin now handles eager loading when using
  Dataset#first and related methods.  Previously, the behavior was
  unspecified. In Sequel <4.27.0 Dataset#first did eager loading
  correctly in the eager case, but incorrectly in the eager_graph
  case.  In Sequel 4.27.0-4.31.0, it did not do eager loading in
  either case.

* The tactical_eager_loading plugin will not automatically eager load
  if passing a proc or block to an association method, since the proc
  or block could be specific to the receiver.

* Sequel now uses a mutex to synchronize access to the association
  cache on MRI, as it does on other ruby implementations.

= Backwards Compatibility

* See above for changes in eager_each and association_pks plugin
  behavior.