~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to plugin/innobase/tests/r/innodb-autoinc-44030.result

  • Committer: Stewart Smith
  • Date: 2009-05-15 06:57:12 UTC
  • mto: (991.1.5 for-brian)
  • mto: This revision was merged to the branch mainline in revision 1022.
  • Revision ID: stewart@flamingspork.com-20090515065712-bmionylacjmexmmm
Make sql_mode=NO_AUTO_VALUE_ON_ZERO default for Drizzle.

Also fix DEFAULT keyword handling for auto-increment so that it defaults to
NULL and not 0 so that the following is valid and generates two auto-inc
values:

create table t1 (a int auto_increment primary key)
insert into t1 (a) values (default);
insert into t1 (a) values (default);

Important to note that 0 is no longer magic. So this gives you duplicate
primary key error:

insert into t1 (a) values(0);
insert into t1 (a) values(0);

as you've inserted the explicit value of 0 twice.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
drop table if exists t1;
2
 
SET @@SESSION.AUTO_INCREMENT_INCREMENT=1, @@SESSION.AUTO_INCREMENT_OFFSET=1;
3
 
CREATE TABLE t1 (c1 INT PRIMARY KEY AUTO_INCREMENT) ENGINE=InnoDB;
4
 
INSERT INTO t1 VALUES (null);
5
 
INSERT INTO t1 VALUES (null);
6
 
ALTER TABLE t1 CHANGE c1 d1 INT NOT NULL AUTO_INCREMENT;
7
 
SELECT * FROM t1;
8
 
d1
9
 
1
10
 
2
11
 
SELECT * FROM t1;
12
 
d1
13
 
1
14
 
2
15
 
INSERT INTO t1 VALUES(null);
16
 
ALTER TABLE t1 AUTO_INCREMENT = 3;
17
 
SHOW CREATE TABLE t1;
18
 
Table   Create Table
19
 
t1      CREATE TABLE `t1` (
20
 
  `d1` INT NOT NULL AUTO_INCREMENT,
21
 
  PRIMARY KEY (`d1`)
22
 
) ENGINE=InnoDB COLLATE = utf8_general_ci AUTO_INCREMENT=3
23
 
INSERT INTO t1 VALUES(null);
24
 
SELECT * FROM t1;
25
 
d1
26
 
1
27
 
2
28
 
3
29
 
4
30
 
DROP TABLE t1;