89 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
		
		
			
		
	
	
			89 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
| 
								 | 
							
								#
							 | 
						||
| 
								 | 
							
								# Bug when using comparions of strings and integers.
							 | 
						||
| 
								 | 
							
								#
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								--disable_warnings
							 | 
						||
| 
								 | 
							
								drop table if exists t1;
							 | 
						||
| 
								 | 
							
								--enable_warnings
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								CREATE TABLE t1 (id CHAR(12) not null, PRIMARY KEY (id));
							 | 
						||
| 
								 | 
							
								insert into t1 values ('000000000001'),('000000000002');
							 | 
						||
| 
								 | 
							
								explain select * from t1 where id=000000000001;
							 | 
						||
| 
								 | 
							
								select * from t1 where id=000000000001;
							 | 
						||
| 
								 | 
							
								delete from t1 where id=000000000002;
							 | 
						||
| 
								 | 
							
								select * from t1;
							 | 
						||
| 
								 | 
							
								drop table t1;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#
							 | 
						||
| 
								 | 
							
								# Check the following:
							 | 
						||
| 
								 | 
							
								# "a"  == "a "
							 | 
						||
| 
								 | 
							
								# "a\0" < "a"
							 | 
						||
| 
								 | 
							
								# "a\0" < "a "
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								SELECT 'a' = 'a ';
							 | 
						||
| 
								 | 
							
								SELECT 'a\0' < 'a';
							 | 
						||
| 
								 | 
							
								SELECT 'a\0' < 'a ';
							 | 
						||
| 
								 | 
							
								SELECT 'a\t' < 'a';
							 | 
						||
| 
								 | 
							
								SELECT 'a\t' < 'a ';
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								CREATE TABLE t1 (a char(10) not null);
							 | 
						||
| 
								 | 
							
								INSERT INTO t1 VALUES ('a'),('a\0'),('a\t'),('a ');
							 | 
						||
| 
								 | 
							
								SELECT hex(a),STRCMP(a,'a'), STRCMP(a,'a ') FROM t1;
							 | 
						||
| 
								 | 
							
								DROP TABLE t1;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								# Bug #8134: Comparison against CHAR(31) at end of string
							 | 
						||
| 
								 | 
							
								SELECT CHAR(31) = '', '' = CHAR(31);
							 | 
						||
| 
								 | 
							
								# Extra test
							 | 
						||
| 
								 | 
							
								SELECT CHAR(30) = '', '' = CHAR(30);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								# End of 4.1 tests
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#
							 | 
						||
| 
								 | 
							
								#Bug #21159: Optimizer: wrong result after AND with different data types
							 | 
						||
| 
								 | 
							
								#
							 | 
						||
| 
								 | 
							
								create table t1 (a tinyint(1),b binary(1));
							 | 
						||
| 
								 | 
							
								insert into t1 values (0x01,0x01);
							 | 
						||
| 
								 | 
							
								select * from t1 where a=b;
							 | 
						||
| 
								 | 
							
								select * from t1 where a=b and b=0x01;
							 | 
						||
| 
								 | 
							
								drop table if exists t1;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#
							 | 
						||
| 
								 | 
							
								# Bug #31887: DML Select statement not returning same results when executed
							 | 
						||
| 
								 | 
							
								# in version 5
							 | 
						||
| 
								 | 
							
								#
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								CREATE TABLE  t1 (b int(2) zerofill, c int(2) zerofill);
							 | 
						||
| 
								 | 
							
								INSERT INTO t1 (b,c) VALUES (1,2), (1,1), (2,2);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								SELECT CONCAT(b,c), CONCAT(b,c) = '0101' FROM t1;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								EXPLAIN EXTENDED SELECT b,c FROM t1 WHERE b = 1 AND CONCAT(b,c) = '0101';
							 | 
						||
| 
								 | 
							
								SELECT b,c FROM t1 WHERE b = 1 AND CONCAT(b,c) = '0101';
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								CREATE TABLE t2 (a int);
							 | 
						||
| 
								 | 
							
								INSERT INTO t2 VALUES (1),(2);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								SELECT a, 
							 | 
						||
| 
								 | 
							
								  (SELECT COUNT(*) FROM t1 
							 | 
						||
| 
								 | 
							
								   WHERE b = t2.a AND CONCAT(b,c) = CONCAT('0',t2.a,'01')) x 
							 | 
						||
| 
								 | 
							
								FROM t2 ORDER BY a;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								EXPLAIN EXTENDED 
							 | 
						||
| 
								 | 
							
								SELECT a, 
							 | 
						||
| 
								 | 
							
								  (SELECT COUNT(*) FROM t1 
							 | 
						||
| 
								 | 
							
								   WHERE b = t2.a AND CONCAT(b,c) = CONCAT('0',t2.a,'01')) x 
							 | 
						||
| 
								 | 
							
								FROM t2 ORDER BY a;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								DROP TABLE t1,t2;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#
							 | 
						||
| 
								 | 
							
								# Bug #39353: Multiple conditions on timestamp column crashes server
							 | 
						||
| 
								 | 
							
								#
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								CREATE TABLE t1 (a TIMESTAMP); 
							 | 
						||
| 
								 | 
							
								INSERT INTO t1 VALUES (NOW()),(NOW()),(NOW());
							 | 
						||
| 
								 | 
							
								SELECT * FROM t1 WHERE a > '2008-01-01' AND a = '0000-00-00';
							 | 
						||
| 
								 | 
							
								DROP TABLE t1;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								--echo End of 5.0 tests
							 |