mirror of
https://github.com/MariaDB/server.git
synced 2025-01-25 00:04:33 +01:00
db7561ecf8
CAST() now produces warnings when casting a wrong INTEGER or CHAR values. This also applies to implicite string to number casts. (Bug #5912) ALTER TABLE now fails in STRICT mode if it generates warnings. Inserting a zero date in a DATE, DATETIME or TIMESTAMP column during TRADITIONAL mode now produces an error. (Bug #5933) mysql-test/r/bigint.result: New warning added mysql-test/r/cast.result: Added testing of wrong CAST's of strings to numbers and numbers to strings mysql-test/r/create.result: Added test for wrong default values (#5902) mysql-test/r/func_if.result: Changed tests to produce less warnings mysql-test/r/func_misc.result: New warning mysql-test/r/func_str.result: Added missing drop table Changed test to produce less warnings New warnings mysql-test/r/ndb_index_unique.result: Removed wrong default usage mysql-test/r/ps_1general.result: Changed tests to produce less warnings mysql-test/r/row.result: New warnings mysql-test/r/rpl_session_var.result: Changed tests to produce less warnings mysql-test/r/strict.result: New tests for CAST() and zero date handling mysql-test/r/subselect.result: Changed tests to produce less warnings mysql-test/r/type_ranges.result: Changed tests to produce less warnings mysql-test/t/cast.test: Added testing of wrong CAST's of strings to numbers and numbers to strings mysql-test/t/create.test: Added test for wrong default values (#5902) mysql-test/t/func_if.test: Changed tests to produce less warnings mysql-test/t/func_str.test: Added missing drop table Changed test to produce less warnings New warnings mysql-test/t/ndb_index_unique.test: Removed wrong default usage mysql-test/t/ps_1general.test: Changed tests to produce less warnings mysql-test/t/rpl_session_var.test: Changed tests to produce less warnings mysql-test/t/strict.test: New tests for CAST() and zero date handling mysql-test/t/subselect.test: Changed tests to produce less warnings mysql-test/t/type_ranges.test: Changed tests to produce less warnings sql/Makefile.am: Added new include file sql/field.cc: Added warnings for zero dates for DATE, DATETIME and TIMESTAMP Moved Field_blob::max_length() to a more appropriate position Changed type for 'level' in set_warning() to avoid casts sql/field.h: Changed type for 'level' in set_warning() to avoid casts sql/field_conv.cc: Copy date and datetime fields through string in 'traditional' mode to detect zero dates sql/item.cc: Removed compiler warnings Give warnings for wrong CAST of strings -> number sql/item.h: Moved Item_string::val_real() and ::val_int() to item.cc sql/item_row.cc: Better detection of null values (which doesn't produce warnings) sql/item_sum.cc: Better detection of null values (which doesn't produce warnings) sql/item_timefunc.cc: Give warnings for wrong CAST of number -> string sql/my_decimal.cc: Fixed typo in comment sql/mysql_priv.h: Removed prototype for static function Moved defines for error handling to sql_error.h (to be able to use these in field.h) sql/mysqld.cc: Simplify code sql/sql_class.h: Moved to sql_error.h sql/sql_load.cc: Removed wrong cast sql/sql_parse.cc: Fixed wrong printf() sql/sql_table.cc: Made mysql_prepare_table() static Changed references to pointers to make code more readable ALTER TABLE now aborts if one gets warnings in STRICT mode sql/time.cc: Fixed possible wrong call sql/unireg.cc: Removed one call to current_thd Give errors if one uses a wrong DEFAULT value
628 lines
11 KiB
Text
628 lines
11 KiB
Text
drop table if exists t1, t2, t3, t4, t5, t6, t7, t8;
|
|
CREATE TABLE t1 (
|
|
a int unsigned NOT NULL PRIMARY KEY,
|
|
b int unsigned not null,
|
|
c int unsigned,
|
|
UNIQUE(b)
|
|
) engine=ndbcluster;
|
|
insert t1 values(1, 2, 3), (2, 3, 5), (3, 4, 6), (4, 5, 8), (5,6, 2), (6,7, 2);
|
|
select * from t1 order by b;
|
|
a b c
|
|
1 2 3
|
|
2 3 5
|
|
3 4 6
|
|
4 5 8
|
|
5 6 2
|
|
6 7 2
|
|
select * from t1 where b = 4 order by b;
|
|
a b c
|
|
3 4 6
|
|
insert into t1 values(7,8,3);
|
|
select * from t1 where b = 4 order by a;
|
|
a b c
|
|
3 4 6
|
|
insert into t1 values(8, 2, 3);
|
|
ERROR 23000: Duplicate entry '8' for key 1
|
|
select * from t1 order by a;
|
|
a b c
|
|
1 2 3
|
|
2 3 5
|
|
3 4 6
|
|
4 5 8
|
|
5 6 2
|
|
6 7 2
|
|
7 8 3
|
|
delete from t1 where a = 1;
|
|
insert into t1 values(8, 2, 3);
|
|
select * from t1 order by a;
|
|
a b c
|
|
2 3 5
|
|
3 4 6
|
|
4 5 8
|
|
5 6 2
|
|
6 7 2
|
|
7 8 3
|
|
8 2 3
|
|
drop table t1;
|
|
CREATE TABLE t1 (
|
|
a int unsigned NOT NULL PRIMARY KEY,
|
|
b int unsigned,
|
|
c int unsigned,
|
|
UNIQUE bc(b,c)
|
|
) engine = ndb;
|
|
insert into t1 values(1,1,1),(2,NULL,2),(3,NULL,NULL),(4,4,NULL);
|
|
select * from t1 use index (bc) where b IS NULL order by a;
|
|
a b c
|
|
2 NULL 2
|
|
3 NULL NULL
|
|
select * from t1 use index (bc)order by a;
|
|
a b c
|
|
1 1 1
|
|
2 NULL 2
|
|
3 NULL NULL
|
|
4 4 NULL
|
|
select * from t1 use index (bc) order by a;
|
|
a b c
|
|
1 1 1
|
|
2 NULL 2
|
|
3 NULL NULL
|
|
4 4 NULL
|
|
select * from t1 use index (PRIMARY) where b IS NULL order by a;
|
|
a b c
|
|
2 NULL 2
|
|
3 NULL NULL
|
|
select * from t1 use index (bc) where b IS NULL order by a;
|
|
a b c
|
|
2 NULL 2
|
|
3 NULL NULL
|
|
select * from t1 use index (bc) where b IS NULL and c IS NULL order by a;
|
|
a b c
|
|
3 NULL NULL
|
|
select * from t1 use index (bc) where b IS NULL and c = 2 order by a;
|
|
a b c
|
|
2 NULL 2
|
|
select * from t1 use index (bc) where b < 4 order by a;
|
|
a b c
|
|
1 1 1
|
|
select * from t1 use index (bc) where b IS NOT NULL order by a;
|
|
a b c
|
|
1 1 1
|
|
4 4 NULL
|
|
insert into t1 values(5,1,1);
|
|
ERROR 23000: Duplicate entry '5' for key 1
|
|
drop table t1;
|
|
CREATE TABLE t2 (
|
|
a int unsigned NOT NULL PRIMARY KEY,
|
|
b int unsigned not null,
|
|
c int unsigned not null,
|
|
UNIQUE USING HASH (b, c)
|
|
) engine=ndbcluster;
|
|
insert t2 values(1, 2, 3), (2, 3, 5), (3, 4, 6), (4, 5, 8), (5,6, 2), (6,7, 2);
|
|
select * from t2 where a = 3;
|
|
a b c
|
|
3 4 6
|
|
select * from t2 where b = 4;
|
|
a b c
|
|
3 4 6
|
|
select * from t2 where c = 6;
|
|
a b c
|
|
3 4 6
|
|
insert into t2 values(7,8,3);
|
|
select * from t2 where b = 4 order by a;
|
|
a b c
|
|
3 4 6
|
|
insert into t2 values(8, 2, 3);
|
|
ERROR 23000: Duplicate entry '8' for key 1
|
|
select * from t2 order by a;
|
|
a b c
|
|
1 2 3
|
|
2 3 5
|
|
3 4 6
|
|
4 5 8
|
|
5 6 2
|
|
6 7 2
|
|
7 8 3
|
|
delete from t2 where a = 1;
|
|
insert into t2 values(8, 2, 3);
|
|
select * from t2 order by a;
|
|
a b c
|
|
2 3 5
|
|
3 4 6
|
|
4 5 8
|
|
5 6 2
|
|
6 7 2
|
|
7 8 3
|
|
8 2 3
|
|
drop table t2;
|
|
CREATE TABLE t2 (
|
|
a int unsigned NOT NULL PRIMARY KEY,
|
|
b int unsigned not null,
|
|
c int unsigned,
|
|
UNIQUE USING HASH (b, c)
|
|
) engine=ndbcluster;
|
|
ERROR 42000: Column 'c' is used with UNIQUE or INDEX but is not defined as NOT NULL
|
|
CREATE TABLE t3 (
|
|
a int unsigned NOT NULL,
|
|
b int unsigned not null,
|
|
c int unsigned,
|
|
PRIMARY KEY USING HASH (a, b)
|
|
) engine=ndbcluster;
|
|
insert t3 values(1, 2, 3), (2, 3, 5), (3, 4, 6), (4, 5, 8), (5,6, 2), (6,7, 2);
|
|
select * from t3 where a = 3;
|
|
a b c
|
|
3 4 6
|
|
select * from t3 where b = 4;
|
|
a b c
|
|
3 4 6
|
|
select * from t3 where c = 6;
|
|
a b c
|
|
3 4 6
|
|
insert into t3 values(7,8,3);
|
|
select * from t3 where b = 4 order by a;
|
|
a b c
|
|
3 4 6
|
|
drop table t3;
|
|
CREATE TABLE t1 (
|
|
pk int NOT NULL PRIMARY KEY,
|
|
a int unsigned,
|
|
UNIQUE KEY (a)
|
|
) engine=ndbcluster;
|
|
insert into t1 values (-1,NULL), (0,0), (1,NULL),(2,2),(3,NULL),(4,4);
|
|
select * from t1 order by pk;
|
|
pk a
|
|
-1 NULL
|
|
0 0
|
|
1 NULL
|
|
2 2
|
|
3 NULL
|
|
4 4
|
|
insert into t1 values (5,0);
|
|
ERROR 23000: Duplicate entry '5' for key 1
|
|
select * from t1 order by pk;
|
|
pk a
|
|
-1 NULL
|
|
0 0
|
|
1 NULL
|
|
2 2
|
|
3 NULL
|
|
4 4
|
|
delete from t1 where a = 0;
|
|
insert into t1 values (5,0);
|
|
select * from t1 order by pk;
|
|
pk a
|
|
-1 NULL
|
|
1 NULL
|
|
2 2
|
|
3 NULL
|
|
4 4
|
|
5 0
|
|
CREATE TABLE t2 (
|
|
pk int NOT NULL PRIMARY KEY,
|
|
a int unsigned,
|
|
b tinyint NOT NULL,
|
|
c VARCHAR(10),
|
|
UNIQUE KEY si(a, c)
|
|
) engine=ndbcluster;
|
|
insert into t2 values (-1,1,17,NULL),(0,NULL,18,NULL),(1,3,19,'abc');
|
|
select * from t2 order by pk;
|
|
pk a b c
|
|
-1 1 17 NULL
|
|
0 NULL 18 NULL
|
|
1 3 19 abc
|
|
insert into t2 values(2,3,19,'abc');
|
|
ERROR 23000: Duplicate entry '2' for key 1
|
|
select * from t2 order by pk;
|
|
pk a b c
|
|
-1 1 17 NULL
|
|
0 NULL 18 NULL
|
|
1 3 19 abc
|
|
delete from t2 where c IS NOT NULL;
|
|
insert into t2 values(2,3,19,'abc');
|
|
select * from t2 order by pk;
|
|
pk a b c
|
|
-1 1 17 NULL
|
|
0 NULL 18 NULL
|
|
2 3 19 abc
|
|
drop table t1, t2;
|
|
CREATE TABLE t1 (
|
|
cid smallint(5) unsigned NOT NULL default '0',
|
|
cv varchar(250) NOT NULL default '',
|
|
PRIMARY KEY (cid),
|
|
UNIQUE KEY cv (cv)
|
|
) engine=ndbcluster;
|
|
INSERT INTO t1 VALUES (8,'dummy');
|
|
CREATE TABLE t2 (
|
|
cid bigint(20) unsigned NOT NULL auto_increment,
|
|
cap varchar(255) NOT NULL default '',
|
|
PRIMARY KEY (cid),
|
|
UNIQUE KEY (cid, cap)
|
|
) engine=ndbcluster;
|
|
INSERT INTO t2 VALUES (NULL,'another dummy');
|
|
CREATE TABLE t3 (
|
|
gid bigint(20) unsigned NOT NULL auto_increment,
|
|
gn varchar(255) NOT NULL default '',
|
|
must tinyint(4) default NULL,
|
|
PRIMARY KEY (gid)
|
|
) engine=ndbcluster;
|
|
INSERT INTO t3 VALUES (1,'V1',NULL);
|
|
CREATE TABLE t4 (
|
|
uid bigint(20) unsigned NOT NULL default '0',
|
|
gid bigint(20) unsigned NOT NULL,
|
|
rid bigint(20) unsigned NOT NULL,
|
|
cid bigint(20) unsigned NOT NULL,
|
|
UNIQUE KEY m (uid,gid,rid,cid)
|
|
) engine=ndbcluster;
|
|
INSERT INTO t4 VALUES (1,1,2,4);
|
|
INSERT INTO t4 VALUES (1,1,2,3);
|
|
INSERT INTO t4 VALUES (1,1,5,7);
|
|
INSERT INTO t4 VALUES (1,1,10,8);
|
|
CREATE TABLE t5 (
|
|
rid bigint(20) unsigned NOT NULL auto_increment,
|
|
rl varchar(255) NOT NULL default '',
|
|
PRIMARY KEY (rid)
|
|
) engine=ndbcluster;
|
|
CREATE TABLE t6 (
|
|
uid bigint(20) unsigned NOT NULL auto_increment,
|
|
un varchar(250) NOT NULL default '',
|
|
uc smallint(5) unsigned NOT NULL default '0',
|
|
PRIMARY KEY (uid),
|
|
UNIQUE KEY nc (un,uc)
|
|
) engine=ndbcluster;
|
|
INSERT INTO t6 VALUES (1,'test',8);
|
|
INSERT INTO t6 VALUES (2,'test2',9);
|
|
INSERT INTO t6 VALUES (3,'tre',3);
|
|
CREATE TABLE t7 (
|
|
mid bigint(20) unsigned NOT NULL PRIMARY KEY,
|
|
uid bigint(20) unsigned NOT NULL default '0',
|
|
gid bigint(20) unsigned NOT NULL,
|
|
rid bigint(20) unsigned NOT NULL,
|
|
cid bigint(20) unsigned NOT NULL,
|
|
UNIQUE KEY m (uid,gid,rid,cid)
|
|
) engine=ndbcluster;
|
|
INSERT INTO t7 VALUES(1, 1, 1, 1, 1);
|
|
INSERT INTO t7 VALUES(2, 2, 1, 1, 1);
|
|
INSERT INTO t7 VALUES(3, 3, 1, 1, 1);
|
|
INSERT INTO t7 VALUES(4, 4, 1, 1, 1);
|
|
INSERT INTO t7 VALUES(5, 5, 1, 1, 1);
|
|
INSERT INTO t7 VALUES(6, 1, 1, 1, 6);
|
|
INSERT INTO t7 VALUES(7, 2, 1, 1, 7);
|
|
INSERT INTO t7 VALUES(8, 3, 1, 1, 8);
|
|
INSERT INTO t7 VALUES(9, 4, 1, 1, 9);
|
|
INSERT INTO t7 VALUES(10, 5, 1, 1, 10);
|
|
select * from t1 where cv = 'dummy';
|
|
cid cv
|
|
8 dummy
|
|
select * from t1 where cv = 'test';
|
|
cid cv
|
|
select * from t2 where cap = 'another dummy';
|
|
cid cap
|
|
1 another dummy
|
|
select * from t4 where uid = 1 and gid=1 and rid=2 and cid=4;
|
|
uid gid rid cid
|
|
1 1 2 4
|
|
select * from t4 where uid = 1 and gid=1 and rid=1 and cid=4;
|
|
uid gid rid cid
|
|
select * from t4 where uid = 1 order by cid;
|
|
uid gid rid cid
|
|
1 1 2 3
|
|
1 1 2 4
|
|
1 1 5 7
|
|
1 1 10 8
|
|
select * from t4 where rid = 2 order by cid;
|
|
uid gid rid cid
|
|
1 1 2 3
|
|
1 1 2 4
|
|
select * from t6 where un='test' and uc=8;
|
|
uid un uc
|
|
1 test 8
|
|
select * from t6 where un='test' and uc=7;
|
|
uid un uc
|
|
select * from t6 where un='test';
|
|
uid un uc
|
|
1 test 8
|
|
select * from t7 where mid = 8;
|
|
mid uid gid rid cid
|
|
8 3 1 1 8
|
|
select * from t7 where uid = 8;
|
|
mid uid gid rid cid
|
|
select * from t7 where uid = 1 order by mid;
|
|
mid uid gid rid cid
|
|
1 1 1 1 1
|
|
6 1 1 1 6
|
|
select * from t7 where uid = 4 order by mid;
|
|
mid uid gid rid cid
|
|
4 4 1 1 1
|
|
9 4 1 1 9
|
|
select * from t7 where gid = 4;
|
|
mid uid gid rid cid
|
|
select * from t7 where gid = 1 order by mid;
|
|
mid uid gid rid cid
|
|
1 1 1 1 1
|
|
2 2 1 1 1
|
|
3 3 1 1 1
|
|
4 4 1 1 1
|
|
5 5 1 1 1
|
|
6 1 1 1 6
|
|
7 2 1 1 7
|
|
8 3 1 1 8
|
|
9 4 1 1 9
|
|
10 5 1 1 10
|
|
select * from t7 where cid = 4;
|
|
mid uid gid rid cid
|
|
select * from t7 where cid = 8;
|
|
mid uid gid rid cid
|
|
8 3 1 1 8
|
|
select * from t4 where uid = 1 and gid=1 and rid=2 and cid=4;
|
|
uid gid rid cid
|
|
1 1 2 4
|
|
select * from t4 where uid = 1 and gid=1 and rid=1 and cid=4;
|
|
uid gid rid cid
|
|
select * from t4 where uid = 1 order by gid,cid;
|
|
uid gid rid cid
|
|
1 1 2 3
|
|
1 1 2 4
|
|
1 1 5 7
|
|
1 1 10 8
|
|
1 1 5 12
|
|
1 2 5 12
|
|
1 3 9 11
|
|
1 3 5 12
|
|
1 4 5 12
|
|
1 5 5 12
|
|
1 6 5 12
|
|
1 7 5 12
|
|
1 8 5 12
|
|
1 9 5 12
|
|
1 10 5 12
|
|
1 11 5 12
|
|
1 12 5 12
|
|
1 13 5 12
|
|
1 14 5 12
|
|
1 15 5 12
|
|
1 16 5 12
|
|
1 17 5 12
|
|
1 18 5 12
|
|
1 19 5 12
|
|
1 20 5 12
|
|
1 21 5 12
|
|
1 22 5 12
|
|
1 23 5 12
|
|
1 24 5 12
|
|
1 25 5 12
|
|
1 26 5 12
|
|
1 27 5 12
|
|
1 28 5 12
|
|
1 29 5 12
|
|
1 30 5 12
|
|
1 31 5 12
|
|
1 32 5 12
|
|
1 33 5 12
|
|
1 34 5 12
|
|
1 35 5 12
|
|
1 36 5 12
|
|
1 37 5 12
|
|
1 38 5 12
|
|
1 39 5 12
|
|
1 40 5 12
|
|
1 41 5 12
|
|
1 42 5 12
|
|
1 43 5 12
|
|
1 44 5 12
|
|
1 45 5 12
|
|
1 46 5 12
|
|
1 47 5 12
|
|
1 48 5 12
|
|
1 49 5 12
|
|
1 50 5 12
|
|
1 51 5 12
|
|
1 52 5 12
|
|
1 53 5 12
|
|
1 54 5 12
|
|
1 55 5 12
|
|
1 56 5 12
|
|
1 57 5 12
|
|
1 58 5 12
|
|
1 59 5 12
|
|
1 60 5 12
|
|
1 61 5 12
|
|
1 62 5 12
|
|
1 63 5 12
|
|
1 64 5 12
|
|
1 65 5 12
|
|
1 66 5 12
|
|
1 67 5 12
|
|
1 68 5 12
|
|
1 69 5 12
|
|
1 70 5 12
|
|
1 71 5 12
|
|
1 72 5 12
|
|
1 73 5 12
|
|
1 74 5 12
|
|
1 75 5 12
|
|
1 76 5 12
|
|
1 77 5 12
|
|
1 78 5 12
|
|
1 79 5 12
|
|
1 80 5 12
|
|
1 81 5 12
|
|
1 82 5 12
|
|
1 83 5 12
|
|
1 84 5 12
|
|
1 85 5 12
|
|
1 86 5 12
|
|
1 87 5 12
|
|
1 88 5 12
|
|
1 89 5 12
|
|
1 90 5 12
|
|
1 91 5 12
|
|
1 92 5 12
|
|
1 93 5 12
|
|
1 94 5 12
|
|
1 95 5 12
|
|
1 96 5 12
|
|
1 97 5 12
|
|
1 98 5 12
|
|
1 99 5 12
|
|
1 100 5 12
|
|
select * from t4 where uid = 1 order by gid,cid;
|
|
uid gid rid cid
|
|
1 1 2 3
|
|
1 1 2 4
|
|
1 1 5 7
|
|
1 1 10 8
|
|
1 1 5 12
|
|
1 2 5 12
|
|
1 3 9 11
|
|
1 3 5 12
|
|
1 4 5 12
|
|
1 5 5 12
|
|
1 6 5 12
|
|
1 7 5 12
|
|
1 8 5 12
|
|
1 9 5 12
|
|
1 10 5 12
|
|
1 11 5 12
|
|
1 12 5 12
|
|
1 13 5 12
|
|
1 14 5 12
|
|
1 15 5 12
|
|
1 16 5 12
|
|
1 17 5 12
|
|
1 18 5 12
|
|
1 19 5 12
|
|
1 20 5 12
|
|
1 21 5 12
|
|
1 22 5 12
|
|
1 23 5 12
|
|
1 24 5 12
|
|
1 25 5 12
|
|
1 26 5 12
|
|
1 27 5 12
|
|
1 28 5 12
|
|
1 29 5 12
|
|
1 30 5 12
|
|
1 31 5 12
|
|
1 32 5 12
|
|
1 33 5 12
|
|
1 34 5 12
|
|
1 35 5 12
|
|
1 36 5 12
|
|
1 37 5 12
|
|
1 38 5 12
|
|
1 39 5 12
|
|
1 40 5 12
|
|
1 41 5 12
|
|
1 42 5 12
|
|
1 43 5 12
|
|
1 44 5 12
|
|
1 45 5 12
|
|
1 46 5 12
|
|
1 47 5 12
|
|
1 48 5 12
|
|
1 49 5 12
|
|
1 50 5 12
|
|
1 51 5 12
|
|
1 52 5 12
|
|
1 53 5 12
|
|
1 54 5 12
|
|
1 55 5 12
|
|
1 56 5 12
|
|
1 57 5 12
|
|
1 58 5 12
|
|
1 59 5 12
|
|
1 60 5 12
|
|
1 61 5 12
|
|
1 62 5 12
|
|
1 63 5 12
|
|
1 64 5 12
|
|
1 65 5 12
|
|
1 66 5 12
|
|
1 67 5 12
|
|
1 68 5 12
|
|
1 69 5 12
|
|
1 70 5 12
|
|
1 71 5 12
|
|
1 72 5 12
|
|
1 73 5 12
|
|
1 74 5 12
|
|
1 75 5 12
|
|
1 76 5 12
|
|
1 77 5 12
|
|
1 78 5 12
|
|
1 79 5 12
|
|
1 80 5 12
|
|
1 81 5 12
|
|
1 82 5 12
|
|
1 83 5 12
|
|
1 84 5 12
|
|
1 85 5 12
|
|
1 86 5 12
|
|
1 87 5 12
|
|
1 88 5 12
|
|
1 89 5 12
|
|
1 90 5 12
|
|
1 91 5 12
|
|
1 92 5 12
|
|
1 93 5 12
|
|
1 94 5 12
|
|
1 95 5 12
|
|
1 96 5 12
|
|
1 97 5 12
|
|
1 98 5 12
|
|
1 99 5 12
|
|
1 100 5 12
|
|
select * from t4 where rid = 2 order by cid;
|
|
uid gid rid cid
|
|
1 1 2 3
|
|
1 1 2 4
|
|
drop table t1,t2,t3,t4,t5,t6,t7;
|
|
CREATE TABLE t1 (
|
|
a int unsigned NOT NULL PRIMARY KEY,
|
|
b int unsigned,
|
|
c int unsigned,
|
|
UNIQUE bc(b,c) ) engine = ndb;
|
|
insert into t1 values(1,1,1),(2,NULL,2),(3,NULL,NULL),(4,4,NULL);
|
|
select * from t1 where b=1 and c=1;
|
|
a b c
|
|
1 1 1
|
|
select * from t1 where b is null and c is null;
|
|
a b c
|
|
3 NULL NULL
|
|
select * from t1 where b is null and c = 2;
|
|
a b c
|
|
2 NULL 2
|
|
select * from t1 where b = 4 and c is null;
|
|
a b c
|
|
4 4 NULL
|
|
create table t8 as
|
|
select * from t1 where (b = 1 and c = 1)
|
|
or (b is null and c is null)
|
|
or (b is null and c = 2)
|
|
or (b = 4 and c is null);
|
|
select * from t8 order by a;
|
|
a b c
|
|
1 1 1
|
|
2 NULL 2
|
|
3 NULL NULL
|
|
4 4 NULL
|
|
select * from t1 order by a;
|
|
a b c
|
|
1 1 1
|
|
2 NULL 2
|
|
3 NULL NULL
|
|
4 4 NULL
|
|
drop table t1, t8;
|
|
create table t1(
|
|
id integer not null auto_increment,
|
|
month integer not null,
|
|
year integer not null,
|
|
code varchar( 2) not null,
|
|
primary key ( id),
|
|
unique idx_t1( month, code, year)
|
|
) engine=ndb;
|
|
INSERT INTO t1 (month, year, code) VALUES (4,2004,'12');
|
|
INSERT INTO t1 (month, year, code) VALUES (5,2004,'12');
|
|
select * from t1 where code = '12' and month = 4 and year = 2004 ;
|
|
id month year code
|
|
1 4 2004 12
|
|
drop table t1;
|