Release 1.59
[dbsrgits/SQL-Abstract.git] / Changes
1 Revision history for SQL::Abstract
2
3 revision 1.59  2009-09-22 08:39 (UTC)
4 ----------------------------
5     - fixed a couple of untrapped undefined warnings
6     - allow -in/-between to accept literal sql in all logical
7       variants - see POD for details
8     - unroll multiple parenthesis around IN arguments to accomodate
9       crappy databases
10
11 revision 1.58  2009-09-04 15:20 (UTC)
12 ----------------------------
13     - expanded the scope of -bool and -not_bool operators
14     - added proper testing support
15
16 revision 1.57  2009-09-03 20:18 (UTC)
17 ----------------------------
18     - added -bool and -not_bool operators
19
20 revision 1.56  2009-05-30 16:31 (UTC)
21 ----------------------------
22     - support for \[$sql, @bind] in order_by clauses e.g.:
23       { -desc => \['colA LIKE ?', 'somestring'] }
24
25 revision 1.55  2009-05-17 22:54 (UTC)
26 ----------------------------
27     - make sure that sql generation does not mutate the supplied
28       where condition structure
29
30 revision 1.54  2009-05-07 17:23 (UTC)
31 ----------------------------
32     - allow special_operators to take both code refs and method names
33       (makes it possible to properly subclass the builtin ones)
34
35 revision 1.53  2009-04-30 14:58 (UTC)
36 ----------------------------
37     - make sure hash keys are sorted in all search sub-conditions
38     - switch installer from EU::MM to M::I
39
40 revision 1.52  2009-04-28 23:14 (UTC)
41 ----------------------------
42     - allow -between to handle [\"", \""] and \["", @bind] 
43     - allow order_by to handle -asc|desc => [qw/colA colB/] (artifact from DBIx::Class)
44     - more tests and clearing up of some corner cases
45     - t/10test.t does not run by default (developer only, too cpu intensive)
46
47 ----------------------------
48 revision 1.51  2009-03-28 10:00 (UTC)
49     - fixed behavior of [-and => ... ] depending on the current
50       condition scope. This introduces backwards comp with 1.24
51
52 ----------------------------
53 revision 1.50  2009-03-10 12:30 (UTC)
54     - fixed the problem with values() not behaving the same as the rest of the code (RT#43483)
55     - fixed interjecting arrayrefref into a where clause
56     - added value-only insert test with a literal SQL snippet
57     - cleanup and enhancement of t/03values.t
58     - better handling of borked SQL in tests
59     - deal properly with parentheses in is_same_sql_bind()
60     - fixed test subs (is_same_*) in SQL::Abstract::Test to return the correct test value
61     - do not version MANIFEST
62
63     Version 1.50 was a major internal refactoring of SQL::Abstract.
64     Great care has been taken to preserve the published behavior
65     documented in previous versions in the 1.* family; however,
66     some features that were previously undocumented, or behaved.
67     differently from the documentation, had to be changed in order
68     to clarify the semantics. Hence, client code that was relying
69     on some dark areas of SQL::Abstract v1.* might behave differently
70     in v1.50.
71
72 ----------------------------
73 revision 1.49_04  2009-03-03
74     - add support for a [\%column_meta => value] bind value format
75
76 ----------------------------
77 revision 1.49_03  2009-02-17
78     - clarify syntax of \['...', @bind] when used with a bindtype
79       of 'columns'
80
81 ----------------------------
82 revision 1.49_02  2009-02-16
83     - added an AST-aware SQL::Abstract::Test library for sql syntax tests
84     - vastly expanded test coverage
85     - support for the { operator => \'...'|\['...', @bind] } syntax
86       allowing to embed arbitrary operators on the LHS
87     - fixed multiple regressions wrt DBIx::Class
88
89 ----------------------------
90 revision 1.49_01  2009-02-11
91     - support for literal SQL through the [$sql, bind] syntax.
92     - added -nest1, -nest2 or -nest_1, -nest_2, ...
93     - optional support for array datatypes
94     - defensive programming : check arguments to functions/methods
95     - fixed bug with global logic of -and/-or (no side-effects any more)
96     - changed logic for distributing an op over arrayrefs
97     - fixed semantics of  _bindtype on array args
98     - dropped the _anoncopy of the %where tree. No longer necessary.
99     - dropped the _modlogic function
100     - Make col => [] and col => {$op => [] } DTRT or die instead of generating
101       broken SQL. Added tests for this.
102     - Added { -desc => 'column' } order by support
103     - Tiny "$_"-related fix for { -desc => 'columns'} order by support
104       tests + docs
105
106 ----------------------------
107 revision 1.20
108 date: 2005/08/18 18:41:58;  author: nwiger;  state: Exp;  lines: +104 -50
109 - added patch from Dan Kubb enabling quote_char and name_sep options
110 - added patch from Andy Grundman to enhance _anoncopy for deep refs
111 ----------------------------
112 revision 1.19
113 date: 2005/04/29 18:20:30;  author: nwiger;  state: Exp;  lines: +34 -20
114 added _anoncopy to prevent destroying original; updated docs
115 ----------------------------
116 revision 1.18
117 date: 2005/03/07 20:14:12;  author: nwiger;  state: Exp;  lines: +201 -65
118 added support for -and, -or, and -nest; see docs for details
119 ----------------------------
120 revision 1.17
121 date: 2004/08/25 20:11:27;  author: nwiger;  state: Exp;  lines: +58 -46
122 added patch from Eric Kolve to iterate over all hashref elements
123 ----------------------------
124 revision 1.16
125 date: 2004/06/10 17:20:01;  author: nwiger;  state: Exp;  lines: +178 -12
126 added bindtype param to allow this to work with Orasuck 9+
127 ----------------------------
128 revision 1.15
129 date: 2003/11/05 23:40:40;  author: nwiger;  state: Exp;  lines: +18 -6
130 several bugfixes, including _convert being applied wrong and
131 the edge case field => { '!=', [qw/this that/] } not working
132 ----------------------------
133 revision 1.14
134 date: 2003/11/04 21:20:33;  author: nwiger;  state: Exp;  lines: +115 -34
135 added patch from Philip Collins, and also added 'convert' option
136 ----------------------------
137 revision 1.13
138 date: 2003/05/21 17:22:29;  author: nwiger;  state: Exp;  lines: +230 -74
139 added "IN" and "BETWEEN" operator support, as well as "NOT"
140 modified where() to support ORDER BY, and fixed some bugs too
141 added PERFORMANCE and FORMBUILDER doc sections
142 fixed several bugs in _recurse_where(), it now works as expected
143 added test suite, many thanks to Chas Owens
144 modified all hash access to return keys sorted, to allow cached queries
145 ----------------------------
146 revision 1.12
147 date: 2003/05/08 20:10:56;  author: nwiger;  state: Exp;  lines: +181 -96
148 1.11 interim checking; major bugfixes and order_by, 1.12 will go to CPAN
149 ----------------------------
150 revision 1.11
151 date: 2003/05/02 00:07:30;  author: nwiger;  state: Exp;  lines: +52 -12
152 many minor enhancements to add querying flexibility
153 ----------------------------
154 revision 1.10
155 date: 2002/09/27 18:06:25;  author: nwiger;  state: Exp;  lines: +6 -2
156 added precatch for messed up where string
157 ----------------------------
158 revision 1.9
159 date: 2002/08/29 18:04:35;  author: nwiger;  state: Exp;  lines: +4 -3
160 CPAN
161 ----------------------------
162 revision 1.8
163 date: 2001/11/07 22:18:12;  author: nwiger;  state: Exp;  lines: +31 -14
164 added embedded SCALAR ref capability to insert() and update()
165 ----------------------------
166 revision 1.7
167 date: 2001/11/07 01:23:28;  author: nwiger;  state: Exp;  lines: +3 -3
168 damn uninit warning
169 ----------------------------
170 revision 1.6
171 date: 2001/11/06 21:09:44;  author: nwiger;  state: Exp;  lines: +14 -6
172 oops, had to actually *implement* the order by for select()!
173 ----------------------------
174 revision 1.5
175 date: 2001/11/06 03:13:16;  author: nwiger;  state: Exp;  lines: +43 -4
176 lots of docs
177 ----------------------------
178 revision 1.4
179 date: 2001/11/06 03:07:42;  author: nwiger;  state: Exp;  lines: +16 -7
180 added extra layer of ()'s to ensure correct semantics on AND
181 ----------------------------
182 revision 1.3
183 date: 2001/11/06 01:16:31;  author: nwiger;  state: Exp;  lines: +11 -10
184 updated all statements so that they use wantarray to just return SQL if asked
185 ----------------------------
186 revision 1.2
187 date: 2001/10/26 22:23:46;  author: nwiger;  state: Exp;  lines: +112 -15
188 added scalar ref for SQL verbatim in where, fixed bugs, array ref, docs
189 ----------------------------
190 revision 1.1
191 date: 2001/10/24 00:26:43;  author: nwiger;  state: Exp;
192 Initial revision