Fixed bug #15160: Queries should only be parsed once
[Packages/TYPO3.CMS.git] / typo3 / sysext / dbal / ChangeLog
1 2010-07-27  Xavier Perseguers  <typo3@perseguers.ch>
2
3         * Fixed bug #15160: Queries should only be parsed once
4
5 2010-07-17  Xavier Perseguers  <typo3@perseguers.ch>
6
7         * Updated PHP documentation
8
9 2010-07-16  Xavier Perseguers  <typo3@perseguers.ch>
10
11         * Added unit test for bug #14818: t3lib_db->listQuery() performance
12         * Fixed bug #14985: FIND_IN_SET should be used isntead of complicated LIKE where clause
13
14 2010-07-11  Xavier Perseguers  <typo3@perseguers.ch>
15
16         * Fixed bug #15045: Trailing newlines after php closing tag
17
18 2010-06-27  Xavier Perseguers  <typo3@perseguers.ch>
19
20         * Synchronized @deprecated annotations with Core
21
22 2010-06-22  Jeff Segars  <jeff@webempoweredchurch.org>
23
24         * Fixed bug #14814: Improve install tool texts
25
26 2010-06-19  Xavier Perseguers  <typo3@perseguers.ch>
27
28         * Fixed bug #3855: Log number of returned or affected rows
29         * Updated copyright year in manual
30
31 2010-06-12  Xavier Perseguers  <typo3@perseguers.ch>
32
33         * Fixed bug #13431: Include BE:forceCharset config option (thanks to Armin Guenther)
34
35 2010-06-11  Xavier Perseguers  <typo3@perseguers.ch>
36
37         * Fixed bug #14405: Rename the test cases from *_testcase to *Test
38
39 2010-06-03  Xavier Perseguers  <typo3@perseguers.ch>
40
41         * Fixed bug #14479: Speed up Oracle layer by not defaulting to dbms_lob.instr for LIKE query (thanks to Michiel Roos)
42
43 2010-05-28  Xavier Perseguers  <typo3@perseguers.ch>
44
45         * Fixed bug #7015: t3lib_DB displays wrong SQL in error case
46
47 2010-05-27  Xavier Perseguers  <typo3@perseguers.ch>
48
49         * Fixed bug #14496: SQL parser does not handle ALTER TABLE with character set operation
50         * Fixed bug #14456: SQL parser doesn't accept ALTER TABLE statement without CHANGE, DROP or ADD keyword
51         * Fixed bug #14457: 1-2-3 Install Process breaks with PostgreSQL
52
53 2010-05-21  Xavier Perseguers  <typo3@perseguers.ch>
54
55         * Fixed bug #14372: Mapping does not work with table alias
56         * Follow-up of changeset 32847: DBAL cannot be loaded if typo3conf/ is not writable
57
58 2010-05-03  Xavier Perseguers  <typo3@perseguers.ch>
59
60         * Fixed 1-2-3 installer crash when having only mysql available
61
62 2010-05-01  Xavier Perseguers  <typo3@perseguers.ch>
63
64         * Fixed bug #14274: Some exception are not caught when trying to install DBAL in 1-2-3 Install Tool process
65         * Fixed bug #2186: Error installing static_info_tables
66         * Fixed bug #14265: Driver dropdown in install tool should be hidden when only MySQL is available
67
68 2010-04-29  Xavier Perseguers  <typo3@perseguers.ch>
69
70         * Added autoloader for Install Tool
71
72 2010-04-22  Xavier Perseguers  <typo3@perseguers.ch>
73
74         * Fixed bug #14182: Multiple join conditions are not supported
75
76 2010-04-15  Xavier Perseguers  <typo3@perseguers.ch>
77
78         * Fixed bug #14120: Add a method to check if database is connected
79
80 2010-04-14  Xavier Perseguers  <typo3@perseguers.ch>
81
82         * Set version to 1.1.2
83
84 2010-04-12  Xavier Perseguers  <typo3@perseguers.ch>
85
86         * Added feature #13508: Use exec_TRUNCATEquery() instead of DELETE FROM throughout the core
87
88 2010-03-07  Xavier Perseguers  <typo3@perseguers.ch>
89
90         * Fixed bug #4640: Backend login impossible with MSSQL via ODBC (thanks to Felix Eckhofer)
91
92 2010-02-21  Xavier Perseguers  <typo3@perseguers.ch>
93
94         * Fixed bug #2367: No support for LIMIT [PostgreSQL]
95
96 2010-02-14  Xavier Perseguers  <typo3@perseguers.ch>
97
98         * Set version to 1.1.1
99
100 2010-02-14  Xavier Perseguers  <typo3@perseguers.ch>
101
102         * Added unit test for #12829: ALTER TABLE is not able to parse length restriction in index creation
103
104 2010-02-13  Xavier Perseguers  <typo3@perseguers.ch>
105
106         * Added unit tests for #4493: WHERE func(expr) IN (n,...m) is broken
107         * Fixed bug #6196: IFNULL operator cannot be parsed
108         * Fixed bug #13528: Argument 1 passed to ux_t3lib_DB::_quoteFieldNames() must be an array, string given
109
110 2010-02-11  Xavier Perseguers  <typo3@perseguers.ch>
111
112         * Follow-up of #13504: Using TRUNCATE instead of TRUNCATETABLE as public DB API
113
114 2010-02-10  Xavier Perseguers  <typo3@perseguers.ch>
115
116         * Fixed bug #13504: Cannot parse TRUNCATE TABLE in install tool
117
118 2010-02-09  Xavier Perseguers  <typo3@perseguers.ch>
119
120         * Added unit test for bug #13490: Where clause 0=0 cannot be parsed
121
122 2010-02-07  Xavier Perseguers  <typo3@perseguers.ch>
123
124         * Added feature #12858: Provide an API to insert multiple rows at once
125         * Fixed bug #13453: Method compileINSERT of ux_t3lib_sqlparser should be protected
126         * Added feature #13209: MySQL extended INSERT statements cannot be parsed
127
128 2010-02-06  Xavier Perseguers  <typo3@perseguers.ch>
129
130         * Added unit tests for bug #13430: Cannot parse INSERT when VALUES has no space before left parenthesis
131
132 2010-02-05  Xavier Perseguers  <typo3@perseguers.ch>
133
134         * Fixed bug #13422: Invalid quoting of numeric column names
135
136 2010-02-03  Xavier Perseguers  <typo3@perseguers.ch>
137
138         * Added unit tests for bug #13412: BETWEEN operator is not supported
139
140 2010-01-24  Xavier Perseguers  <typo3@perseguers.ch>
141
142         * Fixed bug #13090: version warning with CSS styled content
143
144 2010-01-14  Steffen Kamper  <info@sk-typo3.de>
145
146         * Fixed bug #13199: fileadminDir is hardcoded in several places (Thanks to Susanne Moog)
147
148 2010-01-08  Xavier Perseguers  <typo3@perseguers.ch>
149
150         * Updated copyright year
151
152 2010-01-05  Xavier Perseguers  <typo3@perseguers.ch>
153
154         * Added feature #13134: Support of SQL LOCATE function
155
156 2010-01-03  Xavier Perseguers  <typo3@perseguers.ch>
157
158         * Added feature #13135: Support for CASE WHEN flow control
159
160 2009-12-30  Xavier Perseguers  <typo3@perseguers.ch>
161
162         * Set version to 1.1.0
163
164 2009-12-28  Xavier Perseguers  <typo3@perseguers.ch>
165
166         * Fixed bug #12603: sql_query does not respect "mapping"
167         * Fixed bug #13104: SQL parser cannot parse escaped single quote in INSERT statement
168
169 2009-12-27  Xavier Perseguers  <typo3@perseguers.ch>
170
171         * Updated documentation: now using new documentation template
172         * Updated documentation: removed obsolete information, added small cookbook for extension developers, added tutorials for Oracle and PostgreSQL
173
174 2009-12-13  Xavier Perseguers  <typo3@perseguers.ch>
175
176         * Fixed bug #13003: Move back methods belonging to t3lib_sqlparser
177
178 2009-12-11  Xavier Perseguers  <typo3@perseguers.ch>
179
180         * Fixed bug #12897: Cannot parse SQL hints
181
182 2009-11-29  Xavier Perseguers  <typo3@perseguers.ch>
183
184         * Fixed bug #12758: Added support for EXISTS (subquery)
185
186 2009-11-29  Xavier Perseguers  <typo3@perseguers.ch>
187
188         * Set version to 1.0.2 [TYPO3 4.3.0]
189         * Fixed bug #12800: Add functionality to work with caching framework (support for "IN (subquery)" in where clause)
190         * Follow-up of changeset 26118: parts of initial patch for RFC 12231 had actually not been integrated
191
192 2009-11-27  Xavier Perseguers  <typo3@perseguers.ch>
193
194         * Cleanup: Reorganized unit-tests
195
196 2009-11-25  Xavier Perseguers  <typo3@perseguers.ch>
197
198         * Set version to 1.0.1
199
200 2009-11-20  Xavier Perseguers  <typo3@perseguers.ch>
201
202         * Added unit-test for bug #5708: Fieldmapping doesn't work on the "right side" in where clause with table.field
203         * Fixed bugs #5044/#11142: Column's default value is not properly quoted in CREATE TABLE
204         * Added unit-test for bug #12670: Columns with NOT NULL are created as NULLable
205
206 2009-11-17  Xavier Perseguers  <typo3@perseguers.ch>
207
208         * Set version to 1.0.0 (stable)
209         * Updated documentation: updated copyright and refreshed TOC
210         * Added unit-test for bug #4466: Index on tx_realurl_uniqalias breaks with DBAL
211
212 2009-11-16  Xavier Perseguers  <typo3@perseguers.ch>
213
214         * Now using Core dispatcher for backend module (thanks to Oliver Hader)
215
216 2009-11-15  Xavier Perseguers  <typo3@perseguers.ch>
217
218         * Fixed bug #12596: RIGHT OUTER JOIN is not supported
219
220 2009-11-11  Xavier Perseguers  <typo3@perseguers.ch>
221
222         * Added unit test for bug #11093: bigint (int8) values get converted to int4 by int-cast 
223
224 2009-11-10  Xavier Perseguers  <typo3@perseguers.ch>
225
226         * Removed comments stating that SQL parser is experimental
227         * Follow-up of revision 26334: LIKE on Oracle should use dbms_lob.instr() function
228         * Updated Oracle unit tests to use $GLOBALS['TYPO3_DB'] instead of a fixture to avoid side-effects on SQL rewriting
229         * Updated general database unit tests to use $GLOBALS['TYPO3_DB'] instead of a fixture to avoid side-effects on SQL rewriting
230
231 2009-11-09  Xavier Perseguers  <typo3@perseguers.ch>
232
233         * Fixed bug #10965: Float database field gets converted to integer on insert (thanks to Christian Ducrot)
234         * Fixed bug #12515: DAM-related: CONCAT operator cannot be used after LIKE
235         * Fixed bug #10411: Applied missing chunks of patch
236
237 2009-11-07  Xavier Perseguers  <typo3@perseguers.ch>
238
239         * Added unit test for RFC #6198: Problem with strings in IN
240         * Added unit test for RFC #6953: Mapping of fieldnames in SQL-functions like MIN(), MAX() or SUM() does not work
241
242 2009-11-06  Xavier Perseguers  <typo3@perseguers.ch>
243
244         * Set version to 0.9.25
245         * Fixed bug: tables and fields were not always properly mapped in INNER JOINs
246         * Added unit tests to test quoting and remapping of tables and fields when using Oracle
247
248 2009-11-05  Xavier Perseguers  <typo3@perseguers.ch>
249
250         * Set version to 0.9.24
251         * Follow-up of RFC #12452: Reflected change of visibility of method compileFieldCfg() in t3lib_sqlparser
252
253 2009-11-04  Xavier Perseguers  <typo3@perseguers.ch>
254
255         * Updated ext_emconf.php's author and extension version dependencies
256
257 2009-11-03  Xavier Perseguers  <typo3@perseguers.ch>
258
259         * Added some general unit tests (without any engine-specific test nor mapping)
260         * Cleanup #12440: Copy DBAL-only SQL parser methods from t3lib_sqlparser to ux_t3lib_sqlparser
261         * Fixed bug #12231: New caching framework (4.3-dev) does not work with DBAL
262
263 2009-10-28  Xavier Perseguers  <typo3@perseguers.ch>
264
265         * Added compatibility operators for PostgreSQL as resource script (thanks to Ries van Twisk)
266         * Added message in Extension Manager to let users know compatibility scripts may need to be run
267
268 2009-10-27  Xavier Perseguers  <typo3@perseguers.ch>
269
270         * Follow-up of changeset 25876: Using tx_dbal_sqlengine instead of t3lib_sqlengine for sample handlers
271         * Created icons for extension and Debug module
272         * Cleanup: Applied CGL
273
274 2009-10-26  Xavier Perseguers  <typo3@perseguers.ch>
275
276         * Fixed bug #12354: Include t3lib_sqlengine from Core to DBAL
277         * Fixed bug #12349: Clean-up SQL parser and SQL engine
278
279 2009-10-20  Oliver Hader  <oliver@typo3.org>
280
281         * Set version to 0.9.23
282
283 2009-10-08  Xavier Perseguers  <typo3@perseguers.ch>
284
285         * Fixed bug #6953: Mapping of fieldnames in SQL-functions like MIN(), MAX() or SUM() does not work (Thanks to Christian and Michael Miousse)
286
287 2009-10-01  Xavier Perseguers  <typo3@perseguers.ch>
288
289         * Raised version to 0.9.22
290
291 2009-09-29  Xavier Perseguers  <typo3@perseguers.ch>
292
293         * Fixed bug #12071: t3lib_sqlparser is not able to parse alias of a joined table
294
295 2009-09-20  Xavier Perseguers  <typo3@perseguers.ch>
296
297         * Fixed bug #12012: admin_get_tables() method is using PHP5.3-deprecated function mysql_list_tables
298
299 2009-09-18  Xavier Perseguers  <typo3@perseguers.ch>
300
301         * Raised version to 0.9.21
302
303 2009-09-18  Xavier Perseguers  <typo3@perseguers.ch>
304
305         * Fixed bug #11984: Remove reference operators for objects
306
307 2009-09-03  Xavier Perseguers  <typo3@perseguers.ch>
308
309         * Fixed bug #11436: Unknown tables break Install-Tool (Thanks to David Bruchmann)
310         * Fixed bug #11108: DBAL wildly quotes fields and table names
311
312 2009-09-04  Karsten Dambekalns <karsten@typo3.org>
313
314         * Raised version to 0.9.20
315
316 2008-02-04  Michael Stucki  <michael@typo3.org>
317
318         * Fixed bug #7295: Uninitialized variable in ->handler_getFromTableList() (Patch by Oliver Klee)
319
320 2007-05-30  Karsten Dambekalns <karsten@typo3.org>
321
322         * Added default values and some usability improvements to cached info display in debug module (closes bug #3750)
323         * EXPLAIN PLAN support for Oracle (closes bug #3850)
324         * Fixed a warning when using admin_get_fields() on a non-existent table
325         * Fixed a bug causing inserts with more than one affected CLOB field to fail
326         * quoteWhereClause() now die()s when the input cannot be parsed by parseWhereClause()
327         * PHP backtraces can be logged with the queries now (closes bug #3856)
328
329 2007-05-29  Karsten Dambekalns <karsten@typo3.org>
330
331         * Closes bug #4462: creates tables without OIDs on PostgreSQL now
332         * Closes bugs #4494, #3759: & is translated to BITAND() on Oracle now
333         * Large text fields are CLOB fields now; for Oracle LIKE comparisons against such fields are translated to dbms_lob.instr() calls. This should fix e.g. bug #5535 as well as issues with TV data that cannot be unserialized (see comments on bug #4638)
334         * Updates to the manual
335         * A fix for bug #5481, field mapping not working on the right side of a comparison in WHERE clauses
336         * Fixed bugs #2438 and #4496 about quoting of DISTINCT in SELECT clauses
337
338 2006-07-19  Karsten Dambekalns <karsten@typo3.org>
339
340         * Fixes SQL issues when searching in list view or with the global search box on the bottom of the BE page
341
342 2006-06-30  Karsten Dambekalns <karsten@typo3.org>
343
344         * this update closes bugs #3638, #2106, #2866, #3754 (for Firefox, broken in MSIE) and maybe a few more
345         * Implemented support for sysLog() on connection failure
346         * DBAL now honours the no_pconnect setting
347         * For handlers in native mode the setDBinit queries are executed upon connection
348         * The initial value for generated sequences can be configured per handler, to avoid duplicate key errors after having imported data
349         * BLOB fields are handled correctly now during INSERT and UPDATE
350         * Setting $store_lastBuiltQuery acts like in t3lib_db now (fill $debug_lastBuiltQuery)
351         * For the native handler quoting methods directly return the input for speedup, as no quoting is needed in that case
352         * Added support for native and userdefined handler to MetaType()
353         * Changed mapping of types to always use the largest possible integer, map tinytext to varchar instead of text
354         * admin_get_tables() skips tables whose names match /BIN\$/ (coming from the recycle bin on Oracle)
355         * Importing dumps using the install tool now works, see manual for tips
356         * Changed the way NOT NULL and DEFAULT are handled when setting up tables, see manual for the rules that now apply
357         * Code cleanup (indentation, documentation)
358         * Updated the manual and added new content
359
360 2006-01-19  Karsten Dambekalns <karsten@typo3.org>
361
362         * Changes to connection handling, detecting failed connections.
363         * Added support for $no_quote_fields in UPDATE and INSERT methods.
364
365 2006-01-04  Karsten Dambekalns <karsten@typo3.org>
366
367         * Changed the way a connection is established with ADOdb. The new
368         way allows ODBC connections (rather, connections to drivers having
369         an underscore in their name).
370         * Changes to ext_tables.sql to make it more portable.
371         * When printing errors, output the offending SQL as well.
372         * Some small fixes, enhancements to code documentation.
373         * Some additions to the manual.
374
375 2005-12-27  Karsten Dambekalns <karsten@typo3.org>
376
377         * Converted locallang to XML, small adaptions to syext location.
378         * One slight fix to the SQL check in the BE module (wrong output if
379         an error occurred).
380
381 2005-12-26  Karsten Dambekalns <karsten@typo3.org>
382
383         * Code cleanup and improvements to the mapping. Merged 3rd
384         party changes done by DIACC GmbH.
385
386 2005-12-23  Karsten Dambekalns <karsten@typo3.org>
387
388         * Fixed a few issues that were left undiscovered yet.
389         * Added a new module to test query building and parsing
390         from the DBAL debug module.
391         * Finalized fix for bug #1649.
392
393 2005-12-22  Karsten Dambekalns <karsten@typo3.org>
394
395         * Fixed bug #2077 (NOT handling breaking, consequently
396         discarding WHERE clauses).
397
398 2005-12-21  Karsten Dambekalns <karsten@typo3.org>
399
400         * Fixed bug #1781 to allow easier install.
401         * Closed bug #1204 as not reproducable. Probably rather a
402         PHP/Apache bug than a DBAL bug.
403         * Closed bug #1317 which has been fixed earlier. It was due
404         to a msissing check for the incoming SQL (string/array) in the
405         native part of exec_UPDATEquery().
406         * Fixed parseFieldDef() t3lib_sqlparser to allow datatypes
407         with just a trailing comma (like in "tyinytext," as opposed
408         to "varchar(19)". This prevented installation of some
409         extensions.
410         * Fixed bug #2072.
411         * Fixed bug #1206.
412         * Fixed a bug with error logging and array queries (BLOB).
413         * Prepared a fix for bug #1649, pending core list approval.
414         * Fixed a bug in t3lib_page, getMultipleGroupsWhereClause()
415         where double quotes were used to quote a literal for use in
416         SQL. THIS IS MYSQL-ONLY! NEVER DO THIS! ALWAYS USE SINGLE
417         QUOTES!
418
419 2005-06-07  Karsten Dambekalns <karsten@typo3.org>
420
421         Documentation update.
422
423 2005-05-19  Karsten Dambekalns <karsten@typo3.org>
424
425         Committed changes to go along with the library removal done
426         earlier. Completed debug logging.
427
428 2005-02-07  Karsten Dambekalns <karsten@typo3.org>
429
430         Bringing the DBAL extension AS OF JANUARY 2005 into CVS.  Works
431         pretty well, but still needs more work. A few optimizations are
432         planned and some bugs in native mode need to be fixed. Checking
433         this in is (similar to yesterday's commit) more for
434         historic/archival reasons.  This version will NOT work with 3.7.x.
435         You have been warned.
436
437 2005-02-06  Karsten Dambekalns <karsten@typo3.org>
438
439         Bringing the DBAL extension AS OF JULY 2004 into CVS. This is
440         rather for historic purposes, more changes will follow in the near
441         future.  This version was already a huge step forward, but it will
442         not work as expected with 3.7.x or 3.8.x. You have been warned.
443
444 2004-03-28  Kasper Skaarhoej <kasperYYYY@typo3.com>
445
446         Initial revision