malff/marcsql@weblab.(none)
f5ad4eed95
Bug#21904 (parser problem when using IN with a double "(())")
...
Before this fix, a IN predicate of the form: "IN (( subselect ))", with two
parenthesis, would be evaluated as a single row subselect: if the subselect
returns more that 1 row, the statement would fail.
The SQL:2003 standard defines a special exception in the specification,
and mandates that this particular form of IN predicate shall be equivalent
to "IN ( subselect )", which involves a table subquery and works with more
than 1 row.
This fix implements "IN (( subselect ))", "IN ((( subselect )))" etc
as per the SQL:2003 requirement.
All the details related to the implementation of this change have been
commented in the code, and the relevant sections of the SQL:2003 spec
are given for reference, so they are not repeated here.
Having access to the spec is a requirement to review in depth this patch.
2007-01-29 17:32:52 -07:00
..
2006-09-28 14:32:30 -04:00
2006-10-11 14:50:19 +02:00
2006-10-23 15:02:51 +05:00
2006-07-10 20:46:05 +02:00
2006-09-13 15:18:14 +04:00
2006-07-12 13:22:38 -07:00
2006-08-15 10:13:17 +03:00
2006-10-03 16:14:23 +02:00
2006-11-20 22:42:06 +02:00
2006-11-20 22:42:06 +02:00
2006-11-20 22:42:06 +02:00
2006-11-20 22:42:06 +02:00
2006-09-29 16:24:11 +05:00
2006-09-01 08:53:56 +02:00
2006-08-11 13:19:44 +05:00
2006-08-11 13:19:44 +05:00
2006-11-20 22:46:52 +02:00
2006-11-09 14:41:34 +04:00
2006-07-18 21:32:25 +04:00
2006-09-20 11:05:11 +02:00
2006-10-27 18:08:50 +05:00
2006-07-19 22:33:19 +04:00
2006-11-15 19:17:52 +01:00
2006-08-23 18:22:53 +03:00
2006-08-21 12:18:59 +04:00
2006-09-27 14:42:56 -04:00
2006-07-25 18:38:09 -04:00
2006-11-16 23:16:44 +04:00
2006-11-16 23:16:44 +04:00
2006-10-13 19:09:22 +05:00
2006-10-02 12:37:01 +02:00
2006-11-08 22:03:08 +04:00
2006-10-31 11:01:27 +02:00
2006-09-13 15:18:14 +04:00
2006-11-16 13:25:55 +03:00
2006-08-23 18:24:59 -06:00
2006-11-20 22:42:06 +02:00
2006-11-29 02:44:12 +03:00
2006-11-06 17:45:47 -05:00
2006-11-10 15:05:38 +03:00
2006-11-06 11:16:13 +04:00
2006-07-04 12:56:53 +05:00
2006-08-09 22:23:41 -04:00
2006-11-20 22:42:06 +02:00
2006-11-20 22:42:06 +02:00
2006-10-16 13:24:54 +03:00
2006-11-20 22:42:06 +02:00
2006-08-20 20:47:32 +05:00
2006-09-01 03:44:03 +02:00
2006-11-23 22:55:36 +03:00
2006-11-23 22:55:36 +03:00
2006-08-29 15:46:40 +04:00
2006-08-29 15:46:40 +04:00
2006-11-23 22:55:36 +03:00
2006-09-12 18:25:35 +05:00
2006-08-07 11:56:22 +05:00
2006-11-21 13:45:01 +04:00
2006-07-04 23:46:15 +04:00
2006-10-03 16:14:23 +02:00
2006-11-03 16:18:32 +01:00
2006-10-23 15:02:51 +05:00
2006-10-23 15:02:51 +05:00
2006-11-20 22:42:06 +02:00
2006-09-12 17:50:24 +03:00
2006-09-15 14:14:38 +02:00
2006-08-21 14:20:03 +04:00
2006-11-20 22:42:06 +02:00
2006-06-30 19:37:11 +02:00
2006-11-23 22:55:36 +03:00
2006-11-20 22:42:06 +02:00
2006-09-05 16:52:05 +02:00
2006-09-05 16:52:05 +02:00
2006-11-16 23:16:44 +04:00
2006-12-04 14:05:27 +03:00
2006-09-19 12:40:31 +02:00
2006-10-19 10:54:23 +02:00
2006-10-30 14:40:15 +04:00
2006-09-29 00:00:27 +05:00
2006-11-09 16:55:42 +02:00
2006-10-09 20:03:12 +02:00
2006-10-03 15:33:44 +02:00
2006-10-19 10:54:23 +02:00
2006-11-17 10:30:16 +04:00
2006-08-03 11:57:52 +02:00
2006-07-24 13:31:20 -07:00
2006-10-24 17:54:45 +02:00
2006-10-18 18:43:51 -04:00
2006-07-21 20:29:25 -07:00
2006-10-19 13:34:09 +02:00
2006-07-31 13:11:21 +02:00
2006-09-06 11:54:01 +02:00
2006-09-13 23:19:18 +02:00
2006-08-15 13:37:39 +02:00
2006-10-31 16:09:31 +01:00
2006-07-02 01:51:10 +04:00
2006-07-06 18:50:44 +02:00
2006-07-02 01:51:10 +04:00
2006-10-06 14:47:58 +05:00
2006-10-11 14:50:19 +02:00
2006-11-20 22:42:06 +02:00
2006-07-10 16:27:03 +03:00
2006-10-19 15:04:12 +02:00
2006-08-22 14:29:48 +02:00
2006-11-17 10:30:16 +04:00
2006-08-01 11:29:10 +02:00
2006-10-03 16:14:23 +02:00
2006-10-04 11:19:23 -04:00
2006-10-03 16:14:23 +02:00
2006-10-12 17:10:34 -06:00
2006-11-21 16:57:23 +03:00
2006-11-17 10:30:16 +04:00
2006-10-19 16:15:30 +05:00
2006-11-16 23:16:44 +04:00
2006-10-19 18:04:34 +05:00
2006-07-20 13:41:12 +05:00
2006-09-01 04:23:04 -07:00
2006-10-19 10:54:23 +02:00
2006-07-06 14:37:09 +02:00
2006-10-19 10:54:23 +02:00
2006-10-04 22:52:44 +02:00
2006-10-11 10:16:37 +03:00
2006-10-19 10:54:23 +02:00
2006-10-13 11:53:19 +02:00
2006-10-13 20:22:56 +02:00
2006-10-19 10:54:23 +02:00
2006-10-03 16:14:23 +02:00
2006-11-01 12:30:01 +04:00
2006-11-01 12:30:01 +04:00
2006-10-06 13:34:07 +04:00
2006-10-19 10:54:23 +02:00
2006-10-05 18:29:59 +02:00
2006-10-19 10:54:23 +02:00
2006-10-19 10:54:23 +02:00
2006-10-19 10:54:23 +02:00
2006-09-05 16:52:05 +02:00
2006-09-05 16:52:05 +02:00
2006-09-12 00:19:05 +03:00
2006-09-12 00:19:05 +03:00
2006-11-15 12:53:07 +02:00
2006-10-19 10:54:23 +02:00
2006-10-07 20:19:57 +02:00
2006-07-28 02:49:18 +04:00
2006-11-13 15:40:22 -07:00
2006-10-03 15:33:44 +02:00
2006-09-21 00:59:48 +02:00
2006-11-20 22:42:06 +02:00
2006-10-12 17:10:34 -06:00
2006-11-16 23:16:44 +04:00
2006-10-04 13:09:37 +02:00
2006-12-11 18:52:24 -07:00
2006-11-17 12:14:29 -07:00
2006-11-02 17:39:52 -05:00
2006-11-20 22:42:06 +02:00
2006-07-13 17:12:31 +04:00
2006-10-19 11:39:51 -07:00
2006-11-02 17:39:52 -05:00
2006-10-19 00:53:01 +02:00
2006-09-25 16:44:15 +02:00
2006-11-16 23:16:44 +04:00
2006-08-30 13:20:39 -07:00
2006-08-30 13:20:39 -07:00
2006-08-30 13:20:39 -07:00
2006-08-30 13:20:39 -07:00
2006-08-30 13:20:39 -07:00
2006-11-20 22:42:06 +02:00
2006-07-26 19:19:30 +03:00
2006-10-31 20:51:09 +03:00
2007-01-29 17:32:52 -07:00
2006-10-07 20:19:57 +02:00
2006-09-29 12:36:12 +04:00
2006-11-01 17:35:35 +03:00
2006-11-01 16:47:40 +03:00
2006-11-01 16:47:40 +03:00
2006-11-01 16:47:40 +03:00
2006-11-13 15:40:22 -07:00
2006-09-28 17:00:29 +05:00
2006-10-03 15:33:44 +02:00
2006-09-14 18:45:23 +04:00
2006-10-25 20:14:39 +05:00
2006-10-11 19:44:12 +04:00
2006-09-11 14:50:46 +05:00
2006-09-22 19:40:07 +04:00
2006-11-27 16:25:52 +01:00
2006-08-08 13:34:27 +05:00
2006-08-30 00:38:58 +04:00
2006-10-24 15:26:41 +03:00
2006-08-03 09:32:58 +02:00
2006-10-04 10:49:39 -04:00
2006-11-23 22:55:36 +03:00
2006-08-15 18:41:21 +02:00
2006-11-20 22:42:06 +02:00
2006-12-19 15:32:02 +03:00
2006-11-23 22:55:36 +03:00
2006-11-29 02:44:12 +03:00
2006-10-05 12:41:26 +02:00
2006-07-21 09:53:12 +02:00
2006-09-27 19:26:25 -04:00