Georgi Kodinov
9ba74e5d21
Bug #46175 : NULL read_view and consistent read assertion
...
The SE API requires mysql to notify the storage engine that
it's going to read certain tables at the beginning of the
statement (by calling start_stmt(), store_lock() or
external_lock()).
These are typically called by the lock_tables().
However SHOW CREATE TABLE is not pre-locking the tables
because it's not expected to access the data at all.
But for some view definitions (that include comparing a
date/datetime/timestamp column to a string returning
scalar subquery) the JOIN::prepare may still access data
when materializing the scalar non-correlated subquery
in Arg_comparator::can_compare_as_dates().
Fixed by not materializing the subquery when the function
is called in a SHOW/EXPLAIN/CREATE VIEW
2009-11-04 13:54:28 +02:00
..
2009-06-17 15:54:01 +02:00
2009-09-29 17:38:40 +02:00
2009-08-13 17:07:20 -03:00
2009-09-29 17:38:40 +02:00
2009-10-04 12:53:02 +03:00
2009-09-29 17:38:40 +02:00
2007-10-09 17:56:32 -04:00
2007-10-09 17:56:32 -04:00
2007-10-09 17:56:32 -04:00
2009-10-16 13:29:42 +03:00
2008-05-09 09:43:02 +02:00
2009-09-23 15:21:29 +02:00
2009-02-13 11:41:47 -05:00
2008-11-10 21:21:49 +01:00
2008-05-09 09:43:02 +02:00
2009-07-24 15:45:42 -03:00
2009-10-16 13:29:42 +03:00
2009-06-17 15:54:01 +02:00
2009-11-02 09:21:39 -02:00
2009-11-02 09:21:39 -02:00
2009-01-09 14:04:47 +02:00
2009-02-13 11:41:47 -05:00
2009-06-09 18:11:21 +02:00
2009-10-16 13:29:42 +03:00
2007-09-11 16:17:28 +02:00
2008-03-29 09:52:16 +02:00
2008-03-10 07:07:56 +01:00
2009-10-16 13:29:42 +03:00
2008-02-04 15:40:04 +01:00
2009-10-09 09:56:07 +02:00
2009-09-23 15:21:29 +02:00
2009-10-28 19:39:08 +04:00
2009-10-12 14:46:00 +02:00
2007-10-11 13:29:09 -04:00
2008-04-03 13:14:57 -04:00
2007-10-11 13:29:09 -04:00
2009-11-04 13:54:28 +02:00
2009-11-02 13:24:07 +01:00
2009-08-28 18:21:54 +02:00
2009-11-02 09:21:39 -02:00
2009-11-02 09:21:39 -02:00
2009-10-24 09:57:31 +03:00
2008-02-22 13:30:33 +03:00
2008-02-22 13:30:33 +03:00
2008-02-22 13:30:33 +03:00
2009-09-10 15:30:03 +05:00
2009-06-01 16:00:38 +04:00
2009-11-03 20:45:52 +03:00
2008-02-22 13:30:33 +03:00
2009-11-02 09:21:39 -02:00
2008-12-09 20:35:02 +02:00
2009-09-23 15:21:29 +02:00
2009-02-07 16:50:31 +01:00
2009-09-23 15:21:29 +02:00
2007-11-21 16:00:09 +04:00
2009-11-02 13:24:07 +01:00
2009-11-02 13:24:07 +01:00
2008-10-10 12:01:01 +02:00
2009-07-29 10:54:20 +02:00
2009-08-28 18:21:54 +02:00
2009-10-23 11:13:42 +08:00
2007-12-05 20:00:14 +01:00
2009-10-23 11:13:42 +08:00
2009-09-28 05:41:10 -07:00
2009-10-23 01:03:41 +01:00
2009-06-18 14:52:46 +01:00
2009-09-29 17:38:40 +02:00
2008-10-23 15:28:53 +02:00
2008-10-23 15:28:53 +02:00
2008-10-23 15:28:53 +02:00
2007-10-11 13:29:09 -04:00
2008-10-23 15:28:53 +02:00
2008-11-27 12:33:04 +01:00
2009-11-02 09:21:39 -02:00
2009-10-08 16:21:07 +03:00
2009-10-06 13:04:51 +02:00
2007-10-16 16:11:50 -04:00
2009-11-05 14:07:31 +08:00
2009-07-28 22:44:28 +04:00
2008-11-22 01:10:38 +01:00
2008-11-22 01:10:38 +01:00
2009-11-02 13:24:07 +01:00
2008-08-25 21:18:22 +04:00
2009-10-14 10:46:50 +02:00
2009-06-19 13:24:43 +05:00
2009-04-13 18:09:10 +05:00
2009-09-23 15:21:29 +02:00
2009-09-02 18:42:08 +03:00
2009-06-01 16:00:38 +04:00
2007-10-11 14:37:45 -04:00
2008-03-21 17:48:28 +02:00
2009-07-29 22:07:08 +02:00
2009-07-29 22:07:08 +02:00
2009-11-03 20:45:52 +03:00
2009-09-23 17:10:23 +04:00
2008-12-29 17:04:10 +01:00
2009-09-10 11:40:57 +04:00
2008-02-19 14:43:01 +03:00
2007-12-14 15:21:37 +02:00
2009-03-05 20:54:53 +01:00
2008-01-31 14:54:03 +02:00
2009-06-16 16:04:30 +01:00
2009-06-16 16:04:30 +01:00
2009-11-05 14:07:31 +08:00
2009-02-21 09:36:07 +00:00
2008-08-20 19:06:31 +05:00
2008-08-20 19:06:31 +05:00
2008-06-30 22:11:18 +02:00
2009-03-25 12:53:56 +02:00
2007-11-14 16:12:46 -05:00
2009-09-29 17:38:40 +02:00
2009-09-29 17:38:40 +02:00
2009-10-16 13:29:42 +03:00
2009-10-14 09:39:05 +08:00
2008-07-03 23:41:22 +04:00
2008-07-03 23:41:22 +04:00
2009-10-26 11:55:57 +02:00
2009-04-29 07:59:10 +05:00
2009-04-29 07:59:10 +05:00
2009-04-29 07:59:10 +05:00
2008-01-23 15:36:57 -07:00
2008-01-23 13:26:41 -07:00
2009-10-16 13:29:42 +03:00
2009-07-28 18:44:38 +01:00
2009-08-28 18:21:54 +02:00
2009-06-17 16:56:44 +02:00
2009-10-27 15:02:58 +04:00
2009-05-29 15:37:54 +02:00
2009-06-17 16:56:44 +02:00
2008-03-21 17:48:28 +02:00
2007-10-18 14:32:43 +04:00
2009-11-03 18:20:08 +08:00
2009-10-14 09:39:05 +08:00
2008-01-29 14:14:34 +03:00
2009-10-16 13:29:42 +03:00
2009-06-16 10:34:47 +02:00
2009-11-01 23:13:11 +00:00
2009-10-20 11:00:07 -07:00
2009-09-23 15:21:29 +02:00
2009-04-23 12:43:42 +05:00
2009-04-23 12:43:42 +05:00
2008-12-10 18:16:21 +04:00
2007-10-16 16:11:50 -04:00
2009-10-16 13:29:42 +03:00
2009-10-16 13:29:42 +03:00
2009-05-27 18:19:44 +03:00
2008-02-19 15:45:21 +03:00
2009-02-13 11:41:47 -05:00
2009-09-17 17:25:52 +02:00
2009-06-17 16:56:44 +02:00
2009-10-16 13:29:42 +03:00
2009-09-17 17:10:30 +02:00
2009-09-28 05:41:10 -07:00
2009-06-10 10:59:49 +02:00
2009-10-27 15:15:53 +00:00
2009-10-19 13:41:52 +05:00
2008-12-04 19:41:53 +01:00
2007-10-23 14:27:11 +05:00
2009-10-28 19:39:08 +04:00
2009-10-16 13:29:42 +03:00
2007-11-20 11:21:00 +01:00
2009-10-27 06:16:02 -07:00
2009-05-14 14:03:33 +02:00
2009-10-19 16:55:04 +03:00
2009-07-16 15:37:38 +03:00
2009-06-10 10:59:49 +02:00
2009-10-16 13:29:42 +03:00
2009-09-18 16:20:29 +08:00
2008-03-14 18:38:54 +01:00
2009-11-03 20:45:52 +03:00
2009-11-03 20:45:52 +03:00
2009-03-20 16:27:53 +02:00
2009-10-16 13:29:42 +03:00
2008-11-10 21:21:49 +01:00
2009-07-31 22:14:52 +05:00
2009-07-31 22:14:52 +05:00
2009-10-16 13:29:42 +03:00
2009-10-16 13:29:42 +03:00
2009-04-14 14:05:32 +02:00
2009-10-16 13:29:42 +03:00
2009-01-14 18:50:51 +04:00
2009-10-16 13:29:42 +03:00
2009-05-15 12:11:07 +05:00
2009-10-23 16:35:06 +02:00
2009-10-16 13:29:42 +03:00
2009-04-13 18:09:10 +05:00
2009-10-30 11:56:32 +02:00
2009-09-23 15:21:29 +02:00
2009-11-03 20:45:52 +03:00
2009-10-07 18:03:42 +03:00
2009-10-07 18:03:42 +03:00
2009-06-29 16:00:47 +02:00
2009-11-02 13:24:07 +01:00
2009-06-17 16:56:44 +02:00
2009-01-12 17:40:29 +01:00
2009-09-17 17:25:52 +02:00
2007-10-17 17:54:11 -04:00
2009-06-17 16:56:44 +02:00
2009-09-02 16:19:28 +05:00
2009-07-31 15:28:15 -04:00