~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to tests/t/insert.test

  • Committer: Brian Aker
  • Date: 2009-12-29 01:38:38 UTC
  • mfrom: (1251.1.1 drizzle)
  • Revision ID: brian@gaz-20091229013838-03kb2z5xbqw03ddt
Merge of Diego fix.

Show diffs side-by-side

added added

removed removed

Lines of Context:
19
19
#
20
20
 
21
21
create table t1 (id int not null auto_increment primary key, username varchar(32) not null, unique (username));
22
 
insert into t1 values (0,"mysql");
23
 
insert into t1 values (0,"mysql ab");
24
 
insert into t1 values (0,"mysql a");
25
 
insert into t1 values (0,"r1manic");
26
 
insert into t1 values (0,"r1man");
 
22
insert into t1 values (NULL,"mysql");
 
23
insert into t1 values (NULL,"mysql ab");
 
24
insert into t1 values (NULL,"mysql a");
 
25
insert into t1 values (NULL,"r1manic");
 
26
insert into t1 values (NULL,"r1man");
27
27
drop table t1;
28
28
 
29
29
#
30
30
# Test insert syntax
31
31
#
32
32
 
33
 
create table t1 (a int not null auto_increment, primary key (a), t timestamp, c char(10) default "hello", i int);
34
 
insert into t1 values (default,default,default,default), (default,default,default,default), (4,0,"a",5),(default,default,default,default);
35
 
select a,t>0,c,i from t1;
 
33
create table t1 (a int not null auto_increment, primary key (a), t timestamp null, c char(10) default "hello", i int);
 
34
insert into t1 values (default,default,default,default);
 
35
insert into t1 values (default,default,default,default);
 
36
--error 1685 # Bad timestamp
 
37
insert into t1 values (4,0,"a",5);
 
38
insert into t1 values (default,default,default,default);
 
39
select a,t is not null,c,i from t1;
36
40
truncate table t1;
37
41
insert into t1 set a=default,t=default,c=default;
38
42
insert into t1 set a=default,t=default,c=default,i=default;
39
 
insert into t1 set a=4,t=0,c="a",i=5;
40
 
insert into t1 set a=5,t=0,c="a",i=null;
 
43
insert into t1 set a=4,t= NULL,c="a",i=5;
 
44
insert into t1 set a=5,t= NULL,c="a",i=null;
41
45
insert into t1 set a=default,t=default,c=default,i=default;
42
 
select a,t>0,c,i from t1;
 
46
select a,t is not null,c,i from t1;
43
47
drop table t1;
44
48
 
45
49
#
61
65
create table t1 (email varchar(50));
62
66
insert into t1 values ('sasha@mysql.com'),('monty@mysql.com'),('foo@hotmail.com'),('foo@aol.com'),('bar@aol.com');
63
67
create table t2(id int not null auto_increment primary key, t2 varchar(50), unique(t2));
64
 
insert delayed into t2 (t2) select distinct substring(email, locate('@', email)+1) from t1;
 
68
insert into t2 (t2) select distinct substring(email, locate('@', email)+1) from t1;
65
69
select * from t2;
66
70
drop table t1,t2;
67
71
 
169
173
insert ignore into t1 values(NULL,100),(NULL,110),(NULL,120);
170
174
insert ignore into t1 values(NULL,10),(NULL,20),(NULL,110),(NULL,120),(NULL,100),(NULL,90);
171
175
insert ignore into t1 values(NULL,130),(NULL,140),(500,110),(550,120),(450,100),(NULL,150);
 
176
# PBXT differs from InnoDB here. Main reason is that inserting
 
177
# 500 causes auto inc value to be set to 501, this is never
 
178
# undone because of possible concurrent inserts.
172
179
select * from t1 order by id;
173
180
 
174
181
drop table t1;