mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-31 15:50:51 +03:00 
			
		
		
		
	(Mostly in DBUG_PRINT() and unused arguments) Fixed bug in query cache when used with traceing (--with-debug) Fixed memory leak in mysqldump Removed warnings from mysqltest scripts (replaced -- with #) BitKeeper/etc/ignore: added mysql-test/r/*.warnings BUILD/SETUP.sh: Don't build with BDB as default client/client_priv.h: Added OPT_DEBUG_INFO client/mysqlbinlog.cc: Fixed compiler warning client/mysqldump.c: Removed compiler warnings Added option --debug-info to detect memory leaks Fixed memory leak Don't backup cluster replication tables (if used with 5.1) cmd-line-utils/readline/bind.c: Fixed compiler warning cmd-line-utils/readline/chardefs.h: Fixed compiler warning cmd-line-utils/readline/complete.c: Fixed compiler warning cmd-line-utils/readline/display.c: Fixed compiler warning cmd-line-utils/readline/histexpand.c: Fixed compiler warning cmd-line-utils/readline/input.c: Fixed compiler warning cmd-line-utils/readline/isearch.c: Fixed compiler warning cmd-line-utils/readline/kill.c: Fixed compiler warning cmd-line-utils/readline/macro.c: Fixed compiler warning cmd-line-utils/readline/misc.c: Fixed compiler warning cmd-line-utils/readline/nls.c: Fixed compiler warning cmd-line-utils/readline/readline.c: Fixed compiler warning cmd-line-utils/readline/rltty.c: Fixed compiler warning cmd-line-utils/readline/search.c: Fixed compiler warning cmd-line-utils/readline/terminal.c: Fixed compiler warning cmd-line-utils/readline/text.c: Fixed compiler warning cmd-line-utils/readline/tilde.c: Fixed compiler warning cmd-line-utils/readline/undo.c: Fixed compiler warning cmd-line-utils/readline/util.c: Fixed compiler warning cmd-line-utils/readline/vi_mode.c: Fixed compiler warning dbug/dbug_analyze.c: Fixed compiler warning extra/yassl/src/ssl.cpp: Fixed compiler warning extra/yassl/testsuite/testsuite.cpp: Fixed compiler warning heap/_check.c: Fixed compiler warning heap/hp_delete.c: Fixed compiler warning heap/hp_hash.c: Fixed compiler warning heap/hp_open.c: Fixed compiler warning heap/hp_rkey.c: Fixed compiler warning heap/hp_rrnd.c: Fixed compiler warning heap/hp_write.c: Fixed compiler warning libmysql/libmysql.c: Fixed compiler warning libmysqld/libmysqld.c: Fixed compiler warning myisam/mi_close.c: Fixed compiler warning myisam/mi_delete.c: Fixed compiler warning myisam/mi_dynrec.c: Fixed compiler warning myisam/mi_keycache.c: Fixed compiler warning myisam/mi_page.c: Fixed compiler warning myisam/mi_statrec.c: Fixed compiler warning myisam/mi_test2.c: Fixed compiler warning myisam/mi_write.c: Fixed compiler warning myisam/myisampack.c: Fixed compiler warning myisammrg/myrg_extra.c: Fixed compiler warning mysql-test/mysql-test-run.pl: Remove .reject, .progress, .log and .warnings flag at start cluster -> mysql database (for 5.1) mysql-test/include/federated.inc: Remove mysqltest warnings mysql-test/include/sp-vars.inc: Remove mysqltest warnings mysql-test/mysql-test-run.sh: Fix so that 'make test' works again Remove .reject, .progress .log and .warnings files at startup mysql-test/r/ctype_cp1250_ch.result: Drop used tables at startup mysql-test/t/create.test: Remove mysqltest warnings mysql-test/t/csv.test: Remove mysqltest warnings mysql-test/t/ctype_collate.test: Remove mysqltest warnings mysql-test/t/ctype_cp1250_ch.test: Drop used tables at startup mysql-test/t/ctype_ucs.test: Remove mysqltest warnings mysql-test/t/func_sapdb.test: Remove mysqltest warnings mysql-test/t/func_str.test: Remove mysqltest warnings mysql-test/t/grant.test: Remove mysqltest warnings mysql-test/t/greedy_optimizer.test: Remove mysqltest warnings mysql-test/t/group_min_max.test: Remove mysqltest warnings mysql-test/t/innodb.test: Remove mysqltest warnings mysql-test/t/join.test: Remove mysqltest warnings mysql-test/t/limit.test: Remove mysqltest warnings mysql-test/t/null.test: Remove mysqltest warnings mysql-test/t/select.test: Remove mysqltest warnings mysql-test/t/sp-prelocking.test: Remove mysqltest warnings mysql-test/t/strict.test: Remove mysqltest warnings mysql-test/t/subselect.test: Remove mysqltest warnings mysql-test/t/type_newdecimal.test: Remove mysqltest warnings mysql-test/t/view_grant.test: Remove mysqltest warnings mysys/default.c: Fixed compiler warning mysys/hash.c: Fixed compiler warning mysys/list.c: Fixed compiler warning mysys/mf_iocache.c: Fixed compiler warning mysys/mf_keycache.c: Fixed compiler warning mysys/mf_keycaches.c: Fixed compiler warning mysys/my_alloc.c: Fixed compiler warning mysys/my_dup.c: Fixed compiler warning mysys/my_fopen.c: Fixed compiler warning mysys/my_fstream.c: Fixed compiler warning mysys/my_getwd.c: Fixed compiler warning mysys/my_handler.c: Fixed compiler warning Added missing enums in switch mysys/my_lib.c: Fixed compiler warning mysys/my_lread.c: Fixed compiler warning mysys/my_lwrite.c: Fixed compiler warning mysys/my_malloc.c: Fixed compiler warning mysys/my_pread.c: Fixed compiler warning mysys/my_read.c: Fixed compiler warning mysys/my_realloc.c: Fixed compiler warning mysys/my_seek.c: Fixed compiler warning mysys/my_write.c: Fixed compiler warning mysys/safemalloc.c: Fixed compiler warning mysys/thr_lock.c: Fixed compiler warning mysys/tree.c: Fixed compiler warning mysys/typelib.c: Fixed compiler warning ndb/include/logger/LogHandler.hpp: Changed SetErrorStr() to take const char* to remove compiler warnings (as many arguments to this are const strings) ndb/include/ndb_global.h.in: Added LINT_SET_PTR macro to be able to remove some compiler warnings ndb/include/util/InputStream.hpp: Fixed compiler warning ndb/include/util/OutputStream.hpp: Fixed compiler warning ndb/include/util/SimpleProperties.hpp: Fixed compiler warning ndb/src/common/debugger/EventLogger.cpp: remove if on 'signal' as this is a function pointer and is always true ndb/src/common/debugger/signaldata/BackupSignalData.cpp: Add missing enums ndb/src/common/logger/LogHandler.cpp: Changed SetErrorStr() to take const char* to remove compiler warnings (as many arguments to this are const strings) ndb/src/common/portlib/NdbMutex.c: Fixed compiler warning ndb/src/common/portlib/NdbThread.c: Fixed compiler warning ndb/src/common/transporter/Transporter.cpp: Swapped arguments to remove compiler warnings ndb/src/cw/cpcd/CPCD.hpp: Fixed compiler warning ndb/src/kernel/blocks/backup/Backup.cpp: Fixed compiler warning ndb/src/kernel/blocks/cmvmi/Cmvmi.cpp: Fixed compiler warning ndb/src/kernel/blocks/dbdict/Dbdict.cpp: Fixed compiler warning ndb/src/kernel/blocks/dbtux/DbtuxSearch.cpp: Fixed compiler warning ndb/src/kernel/blocks/ndbcntr/NdbcntrMain.cpp: Added missing enums ndb/src/kernel/blocks/qmgr/QmgrMain.cpp: Fixed compiler warning ndb/src/kernel/error/ErrorReporter.cpp: Fixed compiler warning ndb/src/kernel/error/ErrorReporter.hpp: Fixed compiler warning ndb/src/kernel/error/ndbd_exit_codes.c: Fixed compiler warning ndb/src/kernel/vm/TransporterCallback.cpp: Fixed compiler warning ndb/src/mgmapi/mgmapi.cpp: Fixed compiler warning ndb/src/mgmclient/CommandInterpreter.cpp: Fixed compiler warning ndb/src/mgmsrv/MgmtSrvr.cpp: Fixed compiler warning ndb/src/mgmsrv/Services.cpp: Fixed compiler warning ndb/src/ndbapi/ClusterMgr.cpp: Fixed compiler warning ndb/src/ndbapi/DictCache.cpp: Fixed compiler warning ndb/src/ndbapi/Ndb.cpp: Fixed compiler warning ndb/src/ndbapi/NdbOperationDefine.cpp: Fixed compiler warning ndb/src/ndbapi/NdbOperationExec.cpp: Fixed compiler warning ndb/src/ndbapi/NdbOperationInt.cpp: Fixed compiler warning ndb/src/ndbapi/NdbOperationSearch.cpp: Fixed compiler warning ndb/src/ndbapi/NdbTransaction.cpp: Fixed compiler warning ndb/src/ndbapi/Ndbif.cpp: Fixed compiler warning ndb/src/ndbapi/Ndbinit.cpp: Fixed compiler warning ndb/src/ndbapi/ndb_cluster_connection.cpp: Fixed compiler warning ndb/tools/drop_index.cpp: Fixed compiler warning ndb/tools/drop_tab.cpp: Fixed compiler warning ndb/tools/ndb_config.cpp: Fixed compiler warning regex/regexec.c: Fixed compiler warning server-tools/instance-manager/mysql_connection.cc: Fixed compiler warning sql/Makefile.am: Fix for bison 1.875, which adds an attribute statement that gcc 4.1.0 can't parse sql/filesort.cc: Fixed compiler warning sql/ha_archive.cc: Fixed compiler warning sql/ha_federated.cc: Fixed compiler warning sql/ha_federated.h: Fixed compiler warning sql/ha_innodb.cc: Fixed compiler warning sql/ha_myisam.cc: Fixed compiler warning sql/ha_myisammrg.cc: Fixed compiler warning sql/ha_ndbcluster.cc: Fixed compiler warning sql/handler.cc: Fixed compiler warning sql/item_cmpfunc.cc: Fixed compiler warning sql/item_subselect.cc: Fixed compiler warning sql/item_timefunc.cc: Fixed compiler warning sql/log_event.cc: Fixed compiler warning sql/mysqld.cc: Fixed compiler warning sql/net_serv.cc: Fixed compiler warning sql/opt_range.cc: Fixed compiler warning Formated DBUG statements to be as rest of code sql/slave.cc: Fixed compiler warning sql/sql_acl.cc: Fixed compiler warning sql/sql_cache.cc: Fixed compiler warning Fixed bug in query cache when used with DBUG traceing sql/sql_class.cc: Fixed compiler warning sql/sql_class.h: Fixed compiler warning sql/sql_delete.cc: Fixed compiler warning sql/sql_parse.cc: Fixed compiler warning Hack to fix my_sprintf() strings with %b sql/sql_prepare.cc: Fixed compiler warning Hack to fix my_sprintf() strings with %b sql/sql_repl.cc: Fixed compiler warning sql/sql_select.cc: Fixed compiler warning sql/sql_update.cc: Fixed compiler warning sql/sql_view.cc: Fixed compiler warning sql/strfunc.cc: Fixed compiler warning sql-common/client.c: Fixed compiler warning sql-common/my_time.c: Fixed compiler warning sql/table.cc: Fixed compiler warning sql/tztime.cc: Fixed compiler warning sql/unireg.cc: Fixed compiler warning strings/decimal.c: Fixed compiler warning tests/mysql_client_test.c: Fixed compiler warning vio/viosocket.c: Fixed compiler warning vio/viossl.c: Fixed compiler warning vio/viosslfactories.c: Fixed compiler warning
		
			
				
	
	
		
			235 lines
		
	
	
		
			8.0 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			235 lines
		
	
	
		
			8.0 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| # Initialise
 | |
| --disable_warnings
 | |
| drop table if exists t1;
 | |
| --enable_warnings
 | |
| 
 | |
| #
 | |
| # Testing of NULL in a lot of different places
 | |
| #
 | |
| 
 | |
| select null,\N,isnull(null),isnull(1/0),isnull(1/0 = null),ifnull(null,1),ifnull(null,"TRUE"),ifnull("TRUE","ERROR"),1/0 is null,1 is not null;
 | |
| explain extended select null,\N,isnull(null),isnull(1/0),isnull(1/0 = null),ifnull(null,1),ifnull(null,"TRUE"),ifnull("TRUE","ERROR"),1/0 is null,1 is not null;
 | |
| select 1 | NULL,1 & NULL,1+NULL,1-NULL;
 | |
| select NULL=NULL,NULL<>NULL,IFNULL(NULL,1.1)+0,IFNULL(NULL,1) | 0;
 | |
| select strcmp("a",NULL),(1<NULL)+0.0,NULL regexp "a",null like "a%","a%" like null;
 | |
| select concat("a",NULL),replace(NULL,"a","b"),replace("string","i",NULL),replace("string",NULL,"i"),insert("abc",1,1,NULL),left(NULL,1);
 | |
| select repeat("a",0),repeat("ab",5+5),repeat("ab",-1),reverse(NULL);
 | |
| select field(NULL,"a","b","c");
 | |
| select 2 between null and 1,2 between 3 AND NULL,NULL between 1 and 2,2 between NULL and 3, 2 between 1 AND null;
 | |
| explain extended select 2 between null and 1,2 between 3 AND NULL,NULL between 1 and 2,2 between NULL and 3, 2 between 1 AND null;
 | |
| SELECT NULL AND NULL, 1 AND NULL, NULL AND 1, NULL OR NULL, 0 OR NULL, NULL OR 0;
 | |
| SELECT (NULL OR NULL) IS NULL;
 | |
| select NULL AND 0, 0 and NULL;
 | |
| select inet_ntoa(null),inet_aton(null),inet_aton("122.256"),inet_aton("122.226."),inet_aton("");
 | |
| explain extended select inet_ntoa(null),inet_aton(null),inet_aton("122.256"),inet_aton("122.226."),inet_aton("");
 | |
| 
 | |
| create table t1 (x int);
 | |
| insert into t1 values (null);
 | |
| select * from t1 where x != 0;
 | |
| drop table t1;
 | |
| 
 | |
| #
 | |
| # Test problem med index on NULL columns and testing with =NULL;
 | |
| #
 | |
| 
 | |
| CREATE TABLE t1 (
 | |
|   indexed_field int default NULL,
 | |
|   KEY indexed_field (indexed_field)
 | |
| );
 | |
| INSERT INTO t1 VALUES (NULL),(NULL);
 | |
| SELECT * FROM t1 WHERE indexed_field=NULL;
 | |
| SELECT * FROM t1 WHERE indexed_field IS NULL;
 | |
| SELECT * FROM t1 WHERE indexed_field<=>NULL;
 | |
| DROP TABLE t1;
 | |
| 
 | |
| #
 | |
| # Testing of IFNULL
 | |
| #
 | |
| create table t1 (a int, b int) engine=myisam;
 | |
| insert into t1 values(20,null);
 | |
| select t2.b, ifnull(t2.b,"this is null") from t1 as t2 left join t1 as t3 on
 | |
| t2.b=t3.a;
 | |
| select t2.b, ifnull(t2.b,"this is null") from t1 as t2 left join t1 as t3 on
 | |
| t2.b=t3.a order by 1;
 | |
| insert into t1 values(10,null);
 | |
| select t2.b, ifnull(t2.b,"this is null") from t1 as t2 left join t1 as t3 on
 | |
| t2.b=t3.a order by 1;
 | |
| drop table t1;
 | |
| 
 | |
| #
 | |
| # Test inserting and updating with NULL
 | |
| #
 | |
| CREATE TABLE t1 (a varchar(16) NOT NULL default '', b smallint(6) NOT NULL default 0, c datetime NOT NULL default '0000-00-00 00:00:00', d smallint(6) NOT NULL default 0);
 | |
| INSERT INTO t1 SET a = "", d= "2003-01-14 03:54:55";
 | |
| UPDATE t1 SET d=1/NULL;
 | |
| UPDATE t1 SET d=NULL;
 | |
| --error 1048
 | |
| INSERT INTO t1 (a) values (null);
 | |
| --error 1048
 | |
| INSERT INTO t1 (a) values (1/null);
 | |
| INSERT INTO t1 (a) values (null),(null);
 | |
| --error 1048
 | |
| INSERT INTO t1 (b) values (null);
 | |
| --error 1048
 | |
| INSERT INTO t1 (b) values (1/null);
 | |
| INSERT INTO t1 (b) values (null),(null);
 | |
| --error 1048
 | |
| INSERT INTO t1 (c) values (null);
 | |
| --error 1048
 | |
| INSERT INTO t1 (c) values (1/null);
 | |
| INSERT INTO t1 (c) values (null),(null);
 | |
| --error 1048
 | |
| INSERT INTO t1 (d) values (null);
 | |
| --error 1048
 | |
| INSERT INTO t1 (d) values (1/null);
 | |
| INSERT INTO t1 (d) values (null),(null);
 | |
| select * from t1;
 | |
| drop table t1;
 | |
| 
 | |
| #
 | |
| # Test to check elimination of IS NULL predicate for a non-nullable attribute
 | |
| # (bug #1990)  
 | |
| #
 | |
| create table t1 (a int not null, b int not null, index idx(a));
 | |
| insert into t1 values
 | |
|   (1,1), (2,2), (3,3), (4,4), (5,5), (6,6),
 | |
|   (7,7), (8,8), (9,9), (10,10), (11,11), (12,12);
 | |
| explain select * from t1 where a between 2 and 3;
 | |
| explain select * from t1 where a between 2 and 3 or b is null;
 | |
| drop table t1;
 | |
| select cast(NULL as signed);
 | |
| 
 | |
| #
 | |
| # IS NULL is unable to use index in range if column is declared not null
 | |
| # (Bug #4256)
 | |
| #
 | |
| create table t1(i int, key(i));
 | |
| insert into t1 values(1);
 | |
| insert into t1 select i*2 from t1;
 | |
| insert into t1 select i*2 from t1;
 | |
| insert into t1 select i*2 from t1;
 | |
| insert into t1 select i*2 from t1;
 | |
| insert into t1 select i*2 from t1;
 | |
| insert into t1 select i*2 from t1;
 | |
| insert into t1 select i*2 from t1;
 | |
| insert into t1 select i*2 from t1;
 | |
| insert into t1 select i*2 from t1;
 | |
| insert into t1 values(null);
 | |
| explain select * from t1 where i=2 or i is null;
 | |
| select count(*) from t1 where i=2 or i is null;
 | |
| alter table t1 change i i int not null;
 | |
| explain select * from t1 where i=2 or i is null;
 | |
| select count(*) from t1 where i=2 or i is null;
 | |
| drop table t1;
 | |
| 
 | |
| #
 | |
| # NULL has its own type BINARY(0) by default.
 | |
| # But NULL should be weaker than a constant
 | |
| # when mixing charsets/collations
 | |
| #
 | |
| set names latin2;
 | |
| # Check that result type is taken from a non-null string
 | |
| create table t1 select
 | |
|   null as c00,
 | |
|   if(1, null, 'string') as c01,
 | |
|   if(0, null, 'string') as c02,
 | |
|   ifnull(null, 'string') as c03,
 | |
|   ifnull('string', null) as c04,
 | |
|   case when 0 then null else 'string' end as c05,
 | |
|   case when 1 then null else 'string' end as c06,
 | |
|   coalesce(null, 'string') as c07,
 | |
|   coalesce('string', null) as c08,
 | |
|   least('string',null) as c09,
 | |
|   least(null, 'string') as c10,
 | |
|   greatest('string',null) as c11,
 | |
|   greatest(null, 'string') as c12,
 | |
|   nullif('string', null) as c13,
 | |
|   nullif(null, 'string') as c14,
 | |
|   trim('string' from null) as c15,
 | |
|   trim(null from 'string') as c16,
 | |
|   substring_index('string', null, 1) as c17,
 | |
|   substring_index(null, 'string', 1) as c18,
 | |
|   elt(1, null, 'string') as c19,
 | |
|   elt(1, 'string', null) as c20,
 | |
|   concat('string', null) as c21,
 | |
|   concat(null, 'string') as c22,
 | |
|   concat_ws('sep', 'string', null) as c23,
 | |
|   concat_ws('sep', null, 'string') as c24,
 | |
|   concat_ws(null, 'string', 'string') as c25,
 | |
|   make_set(3, 'string', null) as c26,
 | |
|   make_set(3, null, 'string') as c27,
 | |
|   export_set(3, null, 'off', 'sep') as c29,
 | |
|   export_set(3, 'on', null, 'sep') as c30,
 | |
|   export_set(3, 'on', 'off', null) as c31,
 | |
|   replace(null, 'from', 'to') as c32,
 | |
|   replace('str', null, 'to') as c33,
 | |
|   replace('str', 'from', null) as c34,
 | |
|   insert('str', 1, 2, null) as c35,
 | |
|   insert(null, 1, 2, 'str') as c36,
 | |
|   lpad('str', 10, null) as c37,
 | |
|   rpad(null, 10, 'str') as c38;
 | |
|   
 | |
| show create table t1;
 | |
| drop table t1;
 | |
| 
 | |
| #
 | |
| # Check that comparison is done according to
 | |
| # non-null string collation, i.e. case insensitively,
 | |
| # rather than according to NULL's collation, i.e. case sensitively
 | |
| #
 | |
| # in field
 | |
| select 
 | |
|   case 'str' when 'STR' then 'str' when null then 'null' end as c01,
 | |
|   case 'str' when null then 'null' when 'STR' then 'str' end as c02,
 | |
|   field(null, 'str1', 'str2') as c03,
 | |
|   field('str1','STR1', null) as c04,
 | |
|   field('str1', null, 'STR1') as c05,
 | |
|   'string' in ('STRING', null) as c08,
 | |
|   'string' in (null, 'STRING') as c09;
 | |
| 
 | |
| # Restore charset to the default value.
 | |
| set names latin1;
 | |
| 
 | |
| #
 | |
| # Bug#19145: mysqld crashes if you set the default value of an enum field to NULL
 | |
| #
 | |
| create table bug19145a (e enum('a','b','c')          default 'b' , s set('x', 'y', 'z')          default 'y' ) engine=MyISAM;
 | |
| create table bug19145b (e enum('a','b','c')          default null, s set('x', 'y', 'z')          default null) engine=MyISAM;
 | |
| 
 | |
| create table bug19145c (e enum('a','b','c') not null default 'b' , s set('x', 'y', 'z') not null default 'y' ) engine=MyISAM;
 | |
| 
 | |
| # Invalid default value for 's'
 | |
| --error 1067
 | |
| create table bug19145setnotnulldefaultnull (e enum('a','b','c')          default null, s set('x', 'y', 'z') not null default null) engine=MyISAM;
 | |
| 
 | |
| # Invalid default value for 'e'
 | |
| --error 1067
 | |
| create table bug19145enumnotnulldefaultnull (e enum('a','b','c') not null default null, s set('x', 'y', 'z')          default null) engine=MyISAM;
 | |
| 
 | |
| alter table bug19145a alter column e set default null;
 | |
| alter table bug19145a alter column s set default null;
 | |
| alter table bug19145a add column (i int);
 | |
| 
 | |
| alter table bug19145b alter column e set default null;
 | |
| alter table bug19145b alter column s set default null;
 | |
| alter table bug19145b add column (i int);
 | |
| 
 | |
| # Invalid default value for 'e'
 | |
| --error 1067
 | |
| alter table bug19145c alter column e set default null;
 | |
| 
 | |
| # Invalid default value for 's'
 | |
| --error 1067
 | |
| alter table bug19145c alter column s set default null;
 | |
| alter table bug19145c add column (i int);
 | |
| 
 | |
| show create table bug19145a;
 | |
| show create table bug19145b;
 | |
| show create table bug19145c;
 | |
| 
 | |
| drop table bug19145a;
 | |
| drop table bug19145b;
 | |
| drop table bug19145c;
 | |
| 
 | |
| # End of 4.1 tests
 |