mirror of
https://github.com/MariaDB/server.git
synced 2025-01-18 04:53:01 +01:00
567bf9d37c
For application compatibility reasons MySQL converts "<autoincrement_column> IS NULL" predicates to "<autoincrement_column> = LAST_INSERT_ID()" in the first SELECT following an INSERT regardless of whether they're top level predicates or not. This causes wrong and obscure results when these predicates are combined with others on the same columns. Fixed by only doing the transformation on a single top-level predicate if a special SQL mode is turned on (sql_auto_is_null). Also made sql_auto_is_null off by default. per-file comments: mysql-test/r/func_isnull.result Bug#41371 Select returns 1 row with condition "col is not null and col is null" test result updated mysql-test/t/func_isnull.test Bug#41371 Select returns 1 row with condition "col is not null and col is null" test case added sql/mysqld.cc Bug#41371 Select returns 1 row with condition "col is not null and col is null" sql_auto_is_null now is OFF by default. sql/sql_select.cc Bug#41371 Select returns 1 row with condition "col is not null and col is null" remove_eq_conds() split in two parts - one only checks the upper condition, the req_remove_eq_conds() recursively checks all the condition tree. mysql-test/extra/rpl_tests/rpl_insert_id.test Bug#41371 Select returns 1 row with condition "col is not null and col is null" test fixed (set the sql_auto_is_null variable) mysql-test/r/mysqlbinlog.result Bug#41371 Select returns 1 row with condition "col is not null and col is null" result updated mysql-test/r/mysqlbinlog2.result Bug#41371 Select returns 1 row with condition "col is not null and col is null" result updated mysql-test/r/odbc.result Bug#41371 Select returns 1 row with condition "col is not null and col is null" result updated mysql-test/r/query_cache.result Bug#41371 Select returns 1 row with condition "col is not null and col is null" result updated mysql-test/r/user_var-binlog.result Bug#41371 Select returns 1 row with condition "col is not null and col is null" result updated mysql-test/suite/binlog/r/binlog_row_ctype_ucs.result Bug#41371 Select returns 1 row with condition "col is not null and col is null" result updated mysql-test/suite/binlog/r/binlog_stm_ctype_ucs.result Bug#41371 Select returns 1 row with condition "col is not null and col is null" result updated mysql-test/suite/rpl/r/rpl_insert_id.result Bug#41371 Select returns 1 row with condition "col is not null and col is null" result updated mysql-test/suite/rpl/r/rpl_row_mysqlbinlog.result Bug#41371 Select returns 1 row with condition "col is not null and col is null" result updated mysql-test/suite/rpl/r/rpl_sp.result Bug#41371 Select returns 1 row with condition "col is not null and col is null" result updated mysql-test/t/odbc.test Bug#41371 Select returns 1 row with condition "col is not null and col is null" test fixed (set the sql_auto_is_null variable)
29 lines
954 B
Text
29 lines
954 B
Text
drop table if exists t1;
|
|
set @@session.sql_auto_is_null=1;
|
|
select {fn length("hello")}, { date "1997-10-20" };
|
|
{fn length("hello")} 1997-10-20
|
|
5 1997-10-20
|
|
create table t1 (a int not null auto_increment,b int not null,primary key (a,b));
|
|
insert into t1 SET A=NULL,B=1;
|
|
insert into t1 SET a=null,b=2;
|
|
select * from t1 where a is null and b=2;
|
|
a b
|
|
select * from t1 where a is null;
|
|
a b
|
|
2 2
|
|
explain select * from t1 where b is null;
|
|
id select_type table type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL Impossible WHERE
|
|
drop table t1;
|
|
CREATE TABLE t1 (a INT AUTO_INCREMENT PRIMARY KEY);
|
|
INSERT INTO t1 VALUES (NULL);
|
|
SELECT sql_no_cache a, last_insert_id() FROM t1 WHERE a IS NULL;
|
|
a last_insert_id()
|
|
1 1
|
|
SELECT sql_no_cache a, last_insert_id() FROM t1 WHERE a IS NULL;
|
|
a last_insert_id()
|
|
SELECT sql_no_cache a, last_insert_id() FROM t1;
|
|
a last_insert_id()
|
|
1 1
|
|
DROP TABLE t1;
|
|
set @@session.sql_auto_is_null=default;
|