2001-09-27 23:05:54 -06:00
|
|
|
|
drop table if exists t1;
|
|
|
|
|
insert into t1 values(1);
|
2003-06-04 18:28:51 +03:00
|
|
|
|
ERROR 42S02: Table 'test.t1' doesn't exist
|
2001-09-27 23:05:54 -06:00
|
|
|
|
delete from t1;
|
2003-06-04 18:28:51 +03:00
|
|
|
|
ERROR 42S02: Table 'test.t1' doesn't exist
|
2001-09-27 23:05:54 -06:00
|
|
|
|
update t1 set a=1;
|
2003-06-04 18:28:51 +03:00
|
|
|
|
ERROR 42S02: Table 'test.t1' doesn't exist
|
2001-09-27 23:05:54 -06:00
|
|
|
|
create table t1 (a int);
|
|
|
|
|
select count(test.t1.b) from t1;
|
2003-06-04 18:28:51 +03:00
|
|
|
|
ERROR 42S22: Unknown column 'test.t1.b' in 'field list'
|
2001-09-27 23:05:54 -06:00
|
|
|
|
select count(not_existing_database.t1) from t1;
|
Implementation of WL#2486 -
"Process NATURAL and USING joins according to SQL:2003".
* Some of the main problems fixed by the patch:
- in "select *" queries the * expanded correctly according to
ANSI for arbitrary natural/using joins
- natural/using joins are correctly transformed into JOIN ... ON
for any number/nesting of the joins.
- column references are correctly resolved against natural joins
of any nesting and combined with arbitrary other joins.
* This patch also contains a fix for name resolution of items
inside the ON condition of JOIN ... ON - in this case items must
be resolved only against the JOIN operands. To support such
'local' name resolution, the patch introduces a stack of
name resolution contexts used at parse time.
NOTICE:
- This patch is not complete in the sense that
- there are 2 test cases that still do not pass -
one in join.test, one in select.test. Both are marked
with a comment "TODO: WL#2486".
- it does not include a new test specific for the task
mysql-test/include/ps_query.inc:
Adjusted according to standard NATURAL/USING join semantics.,
mysql-test/r/bdb.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/derived.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/errors.result:
The column as a whole cannot be resolved, so different error message.
mysql-test/r/fulltext.result:
Adjusted according to standard JOIN ... ON semantics =>
the ON condition can refer only to the join operands.
mysql-test/r/fulltext_order_by.result:
More detailed error message.
mysql-test/r/innodb.result:
Adjusted according to standard NATURAL/USING join semantics.
This test doesn't pass completetly yet!
mysql-test/r/insert_select.result:
More detailed error message.
mysql-test/r/join.result:
Adjusted according to standard NATURAL/USING join semantics.
NOTICE: there is one test case that still fails, and it is
commeted out and marked with WL#2486 in the test file.
mysql-test/r/join_crash.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/join_nested.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/join_outer.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/multi_update.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/null_key.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/order_by.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/ps_2myisam.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/ps_3innodb.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/ps_4heap.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/ps_5merge.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/ps_6bdb.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/ps_7ndb.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/select.result:
Adjusted according to standard NATURAL/USING join semantics.
NOTICE: there is one failing test case which is commented with
WL#2486 in the test file.
mysql-test/r/subselect.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/type_ranges.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/union.result:
More detailed error message.
mysql-test/t/bdb.test:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/t/errors.test:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/t/fulltext.test:
Adjusted according to standard JOIN ... ON semantics =>
the ON condition can refer only to the join operands.
mysql-test/t/fulltext_order_by.test:
More detailed error message.
mysql-test/t/innodb.test:
Adjusted according to standard NATURAL/USING join semantics.
This test doesn't pass completetly yet!
mysql-test/t/insert_select.test:
More detailed error message.
mysql-test/t/join.test:
Adjusted according to standard NATURAL/USING join semantics.
NOTICE: there is one test case that still fails, and it is
commeted out and marked with WL#2486 in the test file.
mysql-test/t/join_crash.test:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/t/join_nested.test:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/t/join_outer.test:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/t/null_key.test:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/t/order_by.test:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/t/select.test:
Adjusted according to standard NATURAL/USING join semantics.
NOTICE: there is one test case that still fails, and it is
commeted out and marked with WL#2486 in the test file.
mysql-test/t/subselect.test:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/t/type_ranges.test:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/t/union.test:
More detailed error message.
sql/item.cc:
- extra parameter to find_field_in_tables
- find_field_in_real_table renamed to find_field_in_table
- fixed comments/typos
sql/item.h:
- added [first | last]_name_resolution_table to class
Name_resolution_context
- commented old code
- standardized formatting
sql/mysql_priv.h:
- refactored the find_field_in_XXX procedures,
- added a new procedure for natural join table references,
- renamed the find_field_in_XXX procedures to clearer names
sql/sp.cc:
- pass the top-most list of the FROM clause to setup_tables
- extra parameter to find_field_in_tables
sql/sql_acl.cc:
- renamed find_field_in_table => find_field_in_table_ref
- extra parameter to find_field_in_table_ref
- commented old code
sql/sql_base.cc:
This file contains the core of the implementation of the processing
of NATURAL/USING joins (WL#2486).
- added many comments to old code
- refactored the group of find_field_in_XXX procedures, and added a
new procedure for natural joins. There is one find_field_in_XXX procedure
per each type of table reference (stored table, merge view, or natural
join); one meta-procedure that selects the correct one depeneding on the
table reference; and one procedure that goes over a list of table
referenes.
- NATURAL/USING joins are processed through the procedures:
mark_common_columns, store_natural_using_join_columns,
store_top_level_join_columns, setup_natural_join_row_types.
The entry point to processing NATURAL/USING joins is the
procedure 'setup_natural_join_row_types'.
- Replaced the specialized Field_iterator_XXX iterators with one
generic iterator over the fields of a table reference.
- Simplified 'insert_fields' and 'setup_conds' due to encapsulation of
the processing of natural joins in a separate set of procedures.
sql/sql_class.h:
- Commented old code.
sql/sql_delete.cc:
- Pass the FROM clause to setup_tables.
sql/sql_help.cc:
- pass the end name resolution table to find_field_in_tables
- adjust the list of tables for name resolution
sql/sql_insert.cc:
- Changed the code that saves and restores the current context to
support the list of tables for name resolution -
context->first_name_resolution_table, and
table_list->next_name_resolution_table.
Needed to support an ugly trick to resolve inserted columns only in
the first table.
- Added Name_resolution_context::[first | last]_name_resolution_table.
- Commented old code
sql/sql_lex.cc:
- set select_lex.parent_lex correctly
- set correct state of the current name resolution context
sql/sql_lex.h:
- Added a stack of name resolution contexts to support local
contexts for JOIN ... ON conditions.
- Commented old code.
sql/sql_load.cc:
- Pass the FROM clause to setup_tables.
sql/sql_olap.cc:
- Pass the FROM clause to setup_tables.
sql/sql_parse.cc:
- correctly set SELECT_LEX::parent_lex
- set the first table of the current name resoltion context
- added support for NATURAL/USING joins
- commented old code
sql/sql_select.cc:
- Pass the FROM clause to setup_tables.
- Pass the end table to find_field_in_tables
- Improved comments
sql/sql_show.cc:
- Set SELECT_LEX::parent_lex.
sql/sql_update.cc:
- Pass the FROM clause to setup_tables.
sql/sql_yacc.yy:
- Added support for a stack of name resolution contexts needed to
implement name resolution for JOIN ... ON. A context is pushed
for each new JOIN ... ON, and popped afterwards.
- Added support for NATURAL/USING joins.
sql/table.cc:
- Added new class Natural_join_column to hide the heterogeneous
representation of column references for stored tables and for
views.
- Added a new list TABLE_LIST::next_name_resolution_table to
support name resolution with NATURAL/USING joins. Also added
other members to TABLE_LIST to support NATURAL/USING joins.
- Added a generic iterator over the fields of table references
of various types - class Field_iterator_table_ref
sql/table.h:
- Added new class Natural_join_column to hide the heterogeneous
representation of column references for stored tables and for
views.
- Added a new list TABLE_LIST::next_name_resolution_table to
support name resolution with NATURAL/USING joins. Also added
other members to TABLE_LIST to support NATURAL/USING joins.
- Added a generic iterator over the fields of table references
of various types - class Field_iterator_table_ref
tests/mysql_client_test.c:
Adjusted according to standard NATURAL JOIN syntax.
2005-08-12 17:57:19 +03:00
|
|
|
|
ERROR 42S22: Unknown column 'not_existing_database.t1' in 'field list'
|
2001-09-27 23:05:54 -06:00
|
|
|
|
select count(not_existing_database.t1.a) from t1;
|
Implementation of WL#2486 -
"Process NATURAL and USING joins according to SQL:2003".
* Some of the main problems fixed by the patch:
- in "select *" queries the * expanded correctly according to
ANSI for arbitrary natural/using joins
- natural/using joins are correctly transformed into JOIN ... ON
for any number/nesting of the joins.
- column references are correctly resolved against natural joins
of any nesting and combined with arbitrary other joins.
* This patch also contains a fix for name resolution of items
inside the ON condition of JOIN ... ON - in this case items must
be resolved only against the JOIN operands. To support such
'local' name resolution, the patch introduces a stack of
name resolution contexts used at parse time.
NOTICE:
- This patch is not complete in the sense that
- there are 2 test cases that still do not pass -
one in join.test, one in select.test. Both are marked
with a comment "TODO: WL#2486".
- it does not include a new test specific for the task
mysql-test/include/ps_query.inc:
Adjusted according to standard NATURAL/USING join semantics.,
mysql-test/r/bdb.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/derived.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/errors.result:
The column as a whole cannot be resolved, so different error message.
mysql-test/r/fulltext.result:
Adjusted according to standard JOIN ... ON semantics =>
the ON condition can refer only to the join operands.
mysql-test/r/fulltext_order_by.result:
More detailed error message.
mysql-test/r/innodb.result:
Adjusted according to standard NATURAL/USING join semantics.
This test doesn't pass completetly yet!
mysql-test/r/insert_select.result:
More detailed error message.
mysql-test/r/join.result:
Adjusted according to standard NATURAL/USING join semantics.
NOTICE: there is one test case that still fails, and it is
commeted out and marked with WL#2486 in the test file.
mysql-test/r/join_crash.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/join_nested.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/join_outer.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/multi_update.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/null_key.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/order_by.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/ps_2myisam.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/ps_3innodb.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/ps_4heap.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/ps_5merge.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/ps_6bdb.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/ps_7ndb.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/select.result:
Adjusted according to standard NATURAL/USING join semantics.
NOTICE: there is one failing test case which is commented with
WL#2486 in the test file.
mysql-test/r/subselect.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/type_ranges.result:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/r/union.result:
More detailed error message.
mysql-test/t/bdb.test:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/t/errors.test:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/t/fulltext.test:
Adjusted according to standard JOIN ... ON semantics =>
the ON condition can refer only to the join operands.
mysql-test/t/fulltext_order_by.test:
More detailed error message.
mysql-test/t/innodb.test:
Adjusted according to standard NATURAL/USING join semantics.
This test doesn't pass completetly yet!
mysql-test/t/insert_select.test:
More detailed error message.
mysql-test/t/join.test:
Adjusted according to standard NATURAL/USING join semantics.
NOTICE: there is one test case that still fails, and it is
commeted out and marked with WL#2486 in the test file.
mysql-test/t/join_crash.test:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/t/join_nested.test:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/t/join_outer.test:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/t/null_key.test:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/t/order_by.test:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/t/select.test:
Adjusted according to standard NATURAL/USING join semantics.
NOTICE: there is one test case that still fails, and it is
commeted out and marked with WL#2486 in the test file.
mysql-test/t/subselect.test:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/t/type_ranges.test:
Adjusted according to standard NATURAL/USING join semantics.
mysql-test/t/union.test:
More detailed error message.
sql/item.cc:
- extra parameter to find_field_in_tables
- find_field_in_real_table renamed to find_field_in_table
- fixed comments/typos
sql/item.h:
- added [first | last]_name_resolution_table to class
Name_resolution_context
- commented old code
- standardized formatting
sql/mysql_priv.h:
- refactored the find_field_in_XXX procedures,
- added a new procedure for natural join table references,
- renamed the find_field_in_XXX procedures to clearer names
sql/sp.cc:
- pass the top-most list of the FROM clause to setup_tables
- extra parameter to find_field_in_tables
sql/sql_acl.cc:
- renamed find_field_in_table => find_field_in_table_ref
- extra parameter to find_field_in_table_ref
- commented old code
sql/sql_base.cc:
This file contains the core of the implementation of the processing
of NATURAL/USING joins (WL#2486).
- added many comments to old code
- refactored the group of find_field_in_XXX procedures, and added a
new procedure for natural joins. There is one find_field_in_XXX procedure
per each type of table reference (stored table, merge view, or natural
join); one meta-procedure that selects the correct one depeneding on the
table reference; and one procedure that goes over a list of table
referenes.
- NATURAL/USING joins are processed through the procedures:
mark_common_columns, store_natural_using_join_columns,
store_top_level_join_columns, setup_natural_join_row_types.
The entry point to processing NATURAL/USING joins is the
procedure 'setup_natural_join_row_types'.
- Replaced the specialized Field_iterator_XXX iterators with one
generic iterator over the fields of a table reference.
- Simplified 'insert_fields' and 'setup_conds' due to encapsulation of
the processing of natural joins in a separate set of procedures.
sql/sql_class.h:
- Commented old code.
sql/sql_delete.cc:
- Pass the FROM clause to setup_tables.
sql/sql_help.cc:
- pass the end name resolution table to find_field_in_tables
- adjust the list of tables for name resolution
sql/sql_insert.cc:
- Changed the code that saves and restores the current context to
support the list of tables for name resolution -
context->first_name_resolution_table, and
table_list->next_name_resolution_table.
Needed to support an ugly trick to resolve inserted columns only in
the first table.
- Added Name_resolution_context::[first | last]_name_resolution_table.
- Commented old code
sql/sql_lex.cc:
- set select_lex.parent_lex correctly
- set correct state of the current name resolution context
sql/sql_lex.h:
- Added a stack of name resolution contexts to support local
contexts for JOIN ... ON conditions.
- Commented old code.
sql/sql_load.cc:
- Pass the FROM clause to setup_tables.
sql/sql_olap.cc:
- Pass the FROM clause to setup_tables.
sql/sql_parse.cc:
- correctly set SELECT_LEX::parent_lex
- set the first table of the current name resoltion context
- added support for NATURAL/USING joins
- commented old code
sql/sql_select.cc:
- Pass the FROM clause to setup_tables.
- Pass the end table to find_field_in_tables
- Improved comments
sql/sql_show.cc:
- Set SELECT_LEX::parent_lex.
sql/sql_update.cc:
- Pass the FROM clause to setup_tables.
sql/sql_yacc.yy:
- Added support for a stack of name resolution contexts needed to
implement name resolution for JOIN ... ON. A context is pushed
for each new JOIN ... ON, and popped afterwards.
- Added support for NATURAL/USING joins.
sql/table.cc:
- Added new class Natural_join_column to hide the heterogeneous
representation of column references for stored tables and for
views.
- Added a new list TABLE_LIST::next_name_resolution_table to
support name resolution with NATURAL/USING joins. Also added
other members to TABLE_LIST to support NATURAL/USING joins.
- Added a generic iterator over the fields of table references
of various types - class Field_iterator_table_ref
sql/table.h:
- Added new class Natural_join_column to hide the heterogeneous
representation of column references for stored tables and for
views.
- Added a new list TABLE_LIST::next_name_resolution_table to
support name resolution with NATURAL/USING joins. Also added
other members to TABLE_LIST to support NATURAL/USING joins.
- Added a generic iterator over the fields of table references
of various types - class Field_iterator_table_ref
tests/mysql_client_test.c:
Adjusted according to standard NATURAL JOIN syntax.
2005-08-12 17:57:19 +03:00
|
|
|
|
ERROR 42S22: Unknown column 'not_existing_database.t1.a' in 'field list'
|
2001-09-27 23:05:54 -06:00
|
|
|
|
select count(not_existing_database.t1.a) from not_existing_database.t1;
|
2001-10-08 20:18:37 -06:00
|
|
|
|
Got one of the listed errors
|
2001-09-27 23:05:54 -06:00
|
|
|
|
select 1 from t1 order by 2;
|
2003-06-04 18:28:51 +03:00
|
|
|
|
ERROR 42S22: Unknown column '2' in 'order clause'
|
2001-09-27 23:05:54 -06:00
|
|
|
|
select 1 from t1 group by 2;
|
2003-06-04 18:28:51 +03:00
|
|
|
|
ERROR 42S22: Unknown column '2' in 'group statement'
|
2001-09-27 23:05:54 -06:00
|
|
|
|
select 1 from t1 order by t1.b;
|
2003-06-04 18:28:51 +03:00
|
|
|
|
ERROR 42S22: Unknown column 't1.b' in 'order clause'
|
2001-09-27 23:05:54 -06:00
|
|
|
|
select count(*),b from t1;
|
2003-06-04 18:28:51 +03:00
|
|
|
|
ERROR 42S22: Unknown column 'b' in 'field list'
|
2001-09-27 23:05:54 -06:00
|
|
|
|
drop table t1;
|
2005-08-05 17:22:53 -07:00
|
|
|
|
create table t1 (a int(256));
|
2011-05-19 19:16:17 +02:00
|
|
|
|
ERROR 42000: Display width out of range for 'a' (max = 255)
|
2005-08-05 17:22:53 -07:00
|
|
|
|
set sql_mode='traditional';
|
|
|
|
|
create table t1 (a varchar(66000));
|
|
|
|
|
ERROR 42000: Column length too big for column 'a' (max = 65535); use BLOB or TEXT instead
|
2007-04-04 13:38:19 +03:00
|
|
|
|
set sql_mode=default;
|
2007-04-03 18:00:57 +03:00
|
|
|
|
CREATE TABLE t1 (a INT);
|
|
|
|
|
SELECT a FROM t1 WHERE a IN(1, (SELECT IF(1=0,1,2/0)));
|
|
|
|
|
a
|
|
|
|
|
INSERT INTO t1 VALUES(1);
|
|
|
|
|
SELECT a FROM t1 WHERE a IN(1, (SELECT IF(1=0,1,2/0)));
|
|
|
|
|
a
|
|
|
|
|
1
|
|
|
|
|
INSERT INTO t1 VALUES(2),(3);
|
|
|
|
|
SELECT a FROM t1 WHERE a IN(1, (SELECT IF(1=0,1,2/0)));
|
|
|
|
|
a
|
|
|
|
|
1
|
|
|
|
|
DROP TABLE t1;
|
2007-06-18 16:35:01 +03:00
|
|
|
|
CREATE TABLE t1( a INT );
|
|
|
|
|
SELECT b FROM t1;
|
|
|
|
|
ERROR 42S22: Unknown column 'b' in 'field list'
|
|
|
|
|
SHOW ERRORS;
|
|
|
|
|
Level Code Message
|
|
|
|
|
Error 1054 Unknown column 'b' in 'field list'
|
|
|
|
|
CREATE TABLE t2 SELECT b FROM t1;
|
|
|
|
|
ERROR 42S22: Unknown column 'b' in 'field list'
|
|
|
|
|
SHOW ERRORS;
|
|
|
|
|
Level Code Message
|
|
|
|
|
Error 1054 Unknown column 'b' in 'field list'
|
|
|
|
|
INSERT INTO t1 SELECT b FROM t1;
|
|
|
|
|
ERROR 42S22: Unknown column 'b' in 'field list'
|
|
|
|
|
DROP TABLE t1;
|
2009-11-21 02:06:30 +03:00
|
|
|
|
flush status;
|
|
|
|
|
drop table if exists t1, t2;
|
|
|
|
|
create table t1 (a int unique);
|
|
|
|
|
create table t2 (a int);
|
|
|
|
|
drop function if exists f1;
|
|
|
|
|
Warnings:
|
2010-02-23 11:43:26 -07:00
|
|
|
|
Note 1305 FUNCTION test.f1 does not exist
|
2009-11-21 02:06:30 +03:00
|
|
|
|
drop function if exists f2;
|
|
|
|
|
Warnings:
|
2010-02-23 11:43:26 -07:00
|
|
|
|
Note 1305 FUNCTION test.f2 does not exist
|
2009-11-21 02:06:30 +03:00
|
|
|
|
create function f1() returns int
|
|
|
|
|
begin
|
|
|
|
|
insert into t1 (a) values (1);
|
|
|
|
|
insert into t1 (a) values (1);
|
|
|
|
|
return 1;
|
|
|
|
|
end|
|
|
|
|
|
create function f2() returns int
|
|
|
|
|
begin
|
|
|
|
|
insert into t2 (a) values (1);
|
|
|
|
|
return 2;
|
|
|
|
|
end|
|
|
|
|
|
flush status;
|
|
|
|
|
select f1(), f2();
|
|
|
|
|
ERROR 23000: Duplicate entry '1' for key 'a'
|
|
|
|
|
show status like 'Com_insert';
|
|
|
|
|
Variable_name Value
|
|
|
|
|
Com_insert 2
|
|
|
|
|
select * from t1;
|
|
|
|
|
a
|
|
|
|
|
1
|
|
|
|
|
select * from t2;
|
|
|
|
|
a
|
|
|
|
|
drop table t1;
|
|
|
|
|
drop table t2;
|
|
|
|
|
drop function f1;
|
|
|
|
|
drop function f2;
|
2009-10-15 17:23:43 +05:00
|
|
|
|
SET NAMES utf8;
|
|
|
|
|
SET sql_quote_show_create= _binary x'5452C39C45';
|
|
|
|
|
ERROR 42000: Variable 'sql_quote_show_create' can't be set to the value of 'TR\xC3\x9CE'
|
|
|
|
|
SET sql_quote_show_create= _utf8 x'5452C39C45';
|
|
|
|
|
ERROR 42000: Variable 'sql_quote_show_create' can't be set to the value of 'TRÜE'
|
|
|
|
|
SET sql_quote_show_create=_latin1 x'5452DC45';
|
|
|
|
|
ERROR 42000: Variable 'sql_quote_show_create' can't be set to the value of 'TRÜE'
|
|
|
|
|
SET sql_quote_show_create='TRÜE';
|
|
|
|
|
ERROR 42000: Variable 'sql_quote_show_create' can't be set to the value of 'TRÜE'
|
|
|
|
|
SET sql_quote_show_create=TRÜE;
|
|
|
|
|
ERROR 42000: Variable 'sql_quote_show_create' can't be set to the value of 'TRÜE'
|
|
|
|
|
SET NAMES latin1;
|
|
|
|
|
SET sql_quote_show_create= _binary x'5452C39C45';
|
|
|
|
|
ERROR 42000: Variable 'sql_quote_show_create' can't be set to the value of 'TR\xC3\x9CE'
|
|
|
|
|
SET sql_quote_show_create= _utf8 x'5452C39C45';
|
|
|
|
|
ERROR 42000: Variable 'sql_quote_show_create' can't be set to the value of 'TR<54>E'
|
|
|
|
|
SET sql_quote_show_create=_latin1 x'5452DC45';
|
|
|
|
|
ERROR 42000: Variable 'sql_quote_show_create' can't be set to the value of 'TR<54>E'
|
2009-12-22 10:35:56 +01:00
|
|
|
|
SET sql_quote_show_create='TR<54>E';
|
|
|
|
|
ERROR 42000: Variable 'sql_quote_show_create' can't be set to the value of 'TR<54>E'
|
|
|
|
|
SET sql_quote_show_create=TR<54>E;
|
|
|
|
|
ERROR 42000: Variable 'sql_quote_show_create' can't be set to the value of 'TR<54>E'
|
2009-10-15 17:23:43 +05:00
|
|
|
|
SET NAMES binary;
|
|
|
|
|
SET sql_quote_show_create= _binary x'5452C39C45';
|
|
|
|
|
ERROR 42000: Variable 'sql_quote_show_create' can't be set to the value of 'TR\xC3\x9CE'
|
|
|
|
|
SET sql_quote_show_create= _utf8 x'5452C39C45';
|
|
|
|
|
ERROR 42000: Variable 'sql_quote_show_create' can't be set to the value of 'TRÜE'
|
|
|
|
|
SET sql_quote_show_create=_latin1 x'5452DC45';
|
|
|
|
|
ERROR 42000: Variable 'sql_quote_show_create' can't be set to the value of 'TRÜE'
|
2010-05-27 20:01:43 +04:00
|
|
|
|
#
|
|
|
|
|
# Bug#52430 Incorrect key in the error message for duplicate key error involving BINARY type
|
|
|
|
|
#
|
|
|
|
|
CREATE TABLE t1(c1 BINARY(10), c2 BINARY(10), c3 BINARY(10),
|
|
|
|
|
PRIMARY KEY(c1,c2,c3));
|
|
|
|
|
INSERT INTO t1 (c1,c2,c3) VALUES('abc','abc','abc');
|
|
|
|
|
INSERT INTO t1 (c1,c2,c3) VALUES('abc','abc','abc');
|
|
|
|
|
ERROR 23000: Duplicate entry 'abc-abc-abc' for key 'PRIMARY'
|
|
|
|
|
DROP TABLE t1;
|
|
|
|
|
CREATE TABLE t1 (f1 VARBINARY(19) PRIMARY KEY);
|
|
|
|
|
INSERT INTO t1 VALUES ('abc\0\0');
|
|
|
|
|
INSERT INTO t1 VALUES ('abc\0\0');
|
|
|
|
|
ERROR 23000: Duplicate entry 'abc\x00\x00' for key 'PRIMARY'
|
|
|
|
|
DROP TABLE t1;
|
2010-11-04 09:36:04 +01:00
|
|
|
|
#
|
|
|
|
|
# Bug#57882: Item_func_conv_charset::val_str(String*):
|
|
|
|
|
# Assertion `fixed == 1' failed
|
|
|
|
|
#
|
|
|
|
|
SELECT (CONVERT('0' USING latin1) IN (CHAR(COT('v') USING utf8),''));
|
|
|
|
|
ERROR 22003: DOUBLE value is out of range in 'cot('v')'
|
|
|
|
|
SET NAMES utf8 COLLATE utf8_latvian_ci ;
|
2010-11-04 13:36:36 +01:00
|
|
|
|
SELECT UPDATEXML(-73 * -2465717823867977728,@@global.auto_increment_increment,null);
|
2010-11-04 09:36:04 +01:00
|
|
|
|
ERROR 22003: BIGINT value is out of range in '(-(73) * -(2465717823867977728))'
|
|
|
|
|
#
|
|
|
|
|
# End Bug#57882
|
|
|
|
|
#
|
2012-03-12 08:56:56 +01:00
|
|
|
|
CREATE TABLE t1 (a INT);
|
|
|
|
|
CREATE TABLE t2(a INT PRIMARY KEY, b INT);
|
|
|
|
|
SELECT '' AS b FROM t1 GROUP BY VALUES(b);
|
|
|
|
|
ERROR 42S22: Unknown column '' in 'VALUES() function'
|
|
|
|
|
REPLACE t2(b) SELECT '' AS b FROM t1 GROUP BY VALUES(b);
|
|
|
|
|
ERROR 42S22: Unknown column '' in 'VALUES() function'
|
|
|
|
|
UPDATE t2 SET a=(SELECT '' AS b FROM t1 GROUP BY VALUES(b));
|
|
|
|
|
ERROR 42S22: Unknown column '' in 'VALUES() function'
|
|
|
|
|
INSERT INTO t2 VALUES (1,0) ON DUPLICATE KEY UPDATE
|
|
|
|
|
b=(SELECT '' AS b FROM t1 GROUP BY VALUES(b));
|
|
|
|
|
ERROR 42S22: Unknown column '' in 'VALUES() function'
|
|
|
|
|
INSERT INTO t2(a,b) VALUES (1,0) ON DUPLICATE KEY UPDATE
|
|
|
|
|
b=(SELECT VALUES(a)+2 FROM t1);
|
|
|
|
|
DROP TABLE t1, t2;
|
2012-08-29 11:35:42 +03:00
|
|
|
|
#
|
|
|
|
|
# MDEV-492: incorrect error check before sending OK in mysql_update
|
|
|
|
|
#
|
|
|
|
|
CREATE TABLE t1 (a CHAR(3), b BLOB);
|
|
|
|
|
UPDATE t1 SET a = 'new'
|
|
|
|
|
WHERE COLUMN_CREATE( 1, 'v', 1, 'w' ) IS NULL;
|
|
|
|
|
ERROR 22007: Illegal value used as argument of dynamic column function
|
|
|
|
|
drop table t1;
|