mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-31 15:50:51 +03:00 
			
		
		
		
	columns
Fixed confusing warning.
Quoting INSERT section of the manual:
----
Inserting NULL into a column that has been declared NOT NULL. For
multiple-row INSERT statements or INSERT INTO ... SELECT statements, the
column is set to the implicit default value for the column data type. This
is 0 for numeric types, the empty string ('') for string types, and the
"zero" value for date and time types. INSERT INTO ... SELECT statements are
handled the same way as multiple-row inserts because the server does not
examine the result set from the SELECT to see whether it returns a single
row. (For a single-row INSERT, no warning occurs when NULL is inserted into
a NOT NULL column. Instead, the statement fails with an error.)
----
This is also true for LOAD DATA INFILE. For INSERT user can specify
DEFAULT keyword as a value to set column default. There is no similiar
feature available for LOAD DATA INFILE.
mysql-test/r/auto_increment.result:
  Fixed confusing warning.
mysql-test/r/create.result:
  Fixed confusing warning.
mysql-test/r/insert.result:
  Fixed confusing warning.
mysql-test/r/insert_select.result:
  Fixed confusing warning.
mysql-test/r/key.result:
  Fixed confusing warning.
mysql-test/r/null.result:
  Fixed confusing warning.
mysql-test/r/null_key.result:
  Fixed confusing warning.
mysql-test/r/ps_2myisam.result:
  Fixed confusing warning.
mysql-test/r/ps_3innodb.result:
  Fixed confusing warning.
mysql-test/r/ps_4heap.result:
  Fixed confusing warning.
mysql-test/r/ps_5merge.result:
  Fixed confusing warning.
mysql-test/r/ps_6bdb.result:
  Fixed confusing warning.
mysql-test/r/strict.result:
  Fixed confusing warning.
mysql-test/r/view.result:
  Fixed confusing warning.
mysql-test/r/warnings.result:
  Fixed confusing warning.
sql/share/errmsg.txt:
  Fixed confusing warning.
		
	
		
			
				
	
	
		
			443 lines
		
	
	
		
			9.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			443 lines
		
	
	
		
			9.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| drop table if exists t1;
 | |
| drop table if exists t2;
 | |
| SET SQL_WARNINGS=1;
 | |
| create table t1 (a int not null auto_increment,b int, primary key (a)) engine=myisam auto_increment=3;
 | |
| insert into t1 values (1,1),(NULL,3),(NULL,4);
 | |
| delete from t1 where a=4;
 | |
| insert into t1 values (NULL,5),(NULL,6);
 | |
| select * from t1;
 | |
| a	b
 | |
| 1	1
 | |
| 3	3
 | |
| 5	5
 | |
| 6	6
 | |
| delete from t1 where a=6;
 | |
| replace t1 values (3,1);
 | |
| ALTER TABLE t1 add c int;
 | |
| replace t1 values (3,3,3);
 | |
| insert into t1 values (NULL,7,7);
 | |
| update t1 set a=8,b=b+1,c=c+1 where a=7;
 | |
| insert into t1 values (NULL,9,9);
 | |
| select * from t1;
 | |
| a	b	c
 | |
| 1	1	NULL
 | |
| 3	3	3
 | |
| 5	5	NULL
 | |
| 8	8	8
 | |
| 9	9	9
 | |
| drop table t1;
 | |
| create table t1 (
 | |
| skey tinyint unsigned NOT NULL auto_increment PRIMARY KEY,
 | |
| sval char(20)
 | |
| );
 | |
| insert into t1 values (NULL, "hello");
 | |
| insert into t1 values (NULL, "hey");
 | |
| select * from t1;
 | |
| skey	sval
 | |
| 1	hello
 | |
| 2	hey
 | |
| select _rowid,t1._rowid,skey,sval from t1;
 | |
| _rowid	_rowid	skey	sval
 | |
| 1	1	1	hello
 | |
| 2	2	2	hey
 | |
| drop table t1;
 | |
| create table t1 (a char(10) not null, b int not null auto_increment, primary key(a,b));
 | |
| insert into t1 values ("a",1),("b",2),("a",2),("c",1);
 | |
| insert into t1 values ("a",NULL),("b",NULL),("c",NULL),("e",NULL);
 | |
| insert into t1 (a) values ("a"),("b"),("c"),("d");
 | |
| insert into t1 (a) values ('k'),('d');
 | |
| insert into t1 (a) values ("a");
 | |
| insert into t1 values ("d",last_insert_id());
 | |
| select * from t1;
 | |
| a	b
 | |
| a	1
 | |
| a	2
 | |
| a	3
 | |
| a	4
 | |
| a	5
 | |
| b	2
 | |
| b	3
 | |
| b	4
 | |
| c	1
 | |
| c	2
 | |
| c	3
 | |
| d	1
 | |
| d	2
 | |
| d	5
 | |
| e	1
 | |
| k	1
 | |
| drop table t1;
 | |
| create table t1 (ordid int(8) not null auto_increment, ord  varchar(50) not null, primary key (ordid), index(ord,ordid));
 | |
| insert into t1 (ordid,ord) values (NULL,'sdj'),(NULL,'sdj');
 | |
| select * from t1;
 | |
| ordid	ord
 | |
| 1	sdj
 | |
| 2	sdj
 | |
| drop table t1;
 | |
| create table t1 (ordid int(8) not null auto_increment, ord  varchar(50) not null, primary key (ord,ordid));
 | |
| insert into t1 values (NULL,'sdj'),(NULL,'sdj'),(NULL,"abc"),(NULL,'abc'),(NULL,'zzz'),(NULL,'sdj'),(NULL,'abc');
 | |
| select * from t1;
 | |
| ordid	ord
 | |
| 1	abc
 | |
| 2	abc
 | |
| 3	abc
 | |
| 1	sdj
 | |
| 2	sdj
 | |
| 3	sdj
 | |
| 1	zzz
 | |
| drop table t1;
 | |
| create table t1 (sid char(5), id int(2) NOT NULL auto_increment, key(sid,  id));
 | |
| create table t2 (sid char(20), id int(2));
 | |
| insert into t2 values ('skr',NULL),('skr',NULL),('test',NULL);
 | |
| insert into t1 select * from t2;
 | |
| select * from t1;
 | |
| sid	id
 | |
| skr	1
 | |
| skr	2
 | |
| test	1
 | |
| drop table t1,t2;
 | |
| create table t1 (a int not null primary key auto_increment);
 | |
| insert into t1 values (0);
 | |
| update t1 set a=0;
 | |
| select * from t1;
 | |
| a
 | |
| 0
 | |
| check table t1;
 | |
| Table	Op	Msg_type	Msg_text
 | |
| test.t1	check	warning	Found row where the auto_increment column has the value 0
 | |
| test.t1	check	status	OK
 | |
| drop table t1;
 | |
| create table t1 (a int not null auto_increment primary key);
 | |
| insert into t1 values (NULL);
 | |
| insert into t1 values (-1);
 | |
| select last_insert_id();
 | |
| last_insert_id()
 | |
| 1
 | |
| insert into t1 values (NULL);
 | |
| select * from t1;
 | |
| a
 | |
| -1
 | |
| 1
 | |
| 2
 | |
| drop table t1;
 | |
| create table t1 (a int not null auto_increment primary key) /*!40102 engine=heap */;
 | |
| insert into t1 values (NULL);
 | |
| insert into t1 values (-1);
 | |
| select last_insert_id();
 | |
| last_insert_id()
 | |
| 1
 | |
| insert into t1 values (NULL);
 | |
| select * from t1;
 | |
| a
 | |
| 1
 | |
| -1
 | |
| 2
 | |
| drop table t1;
 | |
| create table t1 (i tinyint unsigned not null auto_increment primary key);
 | |
| insert into t1 set i = 254;
 | |
| insert into t1 set i = null;
 | |
| select last_insert_id();
 | |
| last_insert_id()
 | |
| 255
 | |
| explain extended select last_insert_id();
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	SIMPLE	NULL	NULL	NULL	NULL	NULL	NULL	NULL	No tables used
 | |
| Warnings:
 | |
| Note	1003	select last_insert_id() AS `last_insert_id()`
 | |
| insert into t1 set i = 254;
 | |
| ERROR 23000: Duplicate entry '254' for key 1
 | |
| select last_insert_id();
 | |
| last_insert_id()
 | |
| 255
 | |
| insert into t1 set i = null;
 | |
| ERROR 23000: Duplicate entry '255' for key 1
 | |
| select last_insert_id();
 | |
| last_insert_id()
 | |
| 0
 | |
| drop table t1;
 | |
| create table t1 (i tinyint unsigned not null auto_increment, key (i));
 | |
| insert into t1 set i = 254;
 | |
| insert into t1 set i = null;
 | |
| select last_insert_id();
 | |
| last_insert_id()
 | |
| 255
 | |
| insert into t1 set i = null;
 | |
| Warnings:
 | |
| Warning	1264	Out of range value adjusted for column 'i' at row 1
 | |
| select last_insert_id();
 | |
| last_insert_id()
 | |
| 255
 | |
| drop table t1;
 | |
| create table t1 (i tinyint unsigned not null auto_increment primary key, b int, unique (b));
 | |
| insert into t1 values (NULL, 10);
 | |
| select last_insert_id();
 | |
| last_insert_id()
 | |
| 1
 | |
| insert into t1 values (NULL, 15);
 | |
| select last_insert_id();
 | |
| last_insert_id()
 | |
| 2
 | |
| insert into t1 values (NULL, 10);
 | |
| ERROR 23000: Duplicate entry '10' for key 2
 | |
| select last_insert_id();
 | |
| last_insert_id()
 | |
| 0
 | |
| drop table t1;
 | |
| create table t1(a int auto_increment,b int null,primary key(a));
 | |
| SET SQL_MODE=NO_AUTO_VALUE_ON_ZERO;
 | |
| insert into t1(a,b)values(NULL,1);
 | |
| insert into t1(a,b)values(200,2);
 | |
| insert into t1(a,b)values(0,3);
 | |
| insert into t1(b)values(4);
 | |
| insert into t1(b)values(5);
 | |
| insert into t1(b)values(6);
 | |
| insert into t1(b)values(7);
 | |
| select * from t1 order by b;
 | |
| a	b
 | |
| 1	1
 | |
| 200	2
 | |
| 0	3
 | |
| 201	4
 | |
| 202	5
 | |
| 203	6
 | |
| 204	7
 | |
| alter table t1 modify b mediumint;
 | |
| select * from t1 order by b;
 | |
| a	b
 | |
| 1	1
 | |
| 200	2
 | |
| 0	3
 | |
| 201	4
 | |
| 202	5
 | |
| 203	6
 | |
| 204	7
 | |
| create table t2 (a int);
 | |
| insert t2 values (1),(2);
 | |
| alter table t2 add b int auto_increment primary key;
 | |
| select * from t2;
 | |
| a	b
 | |
| 1	1
 | |
| 2	2
 | |
| drop table t2;
 | |
| delete from t1 where a=0;
 | |
| update t1 set a=0 where b=5;
 | |
| select * from t1 order by b;
 | |
| a	b
 | |
| 1	1
 | |
| 200	2
 | |
| 201	4
 | |
| 0	5
 | |
| 203	6
 | |
| 204	7
 | |
| delete from t1 where a=0;
 | |
| update t1 set a=NULL where b=6;
 | |
| Warnings:
 | |
| Warning	1263	Column was set to data type implicit default; NULL supplied for NOT NULL column 'a' at row 4
 | |
| update t1 set a=300 where b=7;
 | |
| SET SQL_MODE='';
 | |
| insert into t1(a,b)values(NULL,8);
 | |
| insert into t1(a,b)values(400,9);
 | |
| insert into t1(a,b)values(0,10);
 | |
| insert into t1(b)values(11);
 | |
| insert into t1(b)values(12);
 | |
| insert into t1(b)values(13);
 | |
| insert into t1(b)values(14);
 | |
| select * from t1 order by b;
 | |
| a	b
 | |
| 1	1
 | |
| 200	2
 | |
| 201	4
 | |
| 0	6
 | |
| 300	7
 | |
| 301	8
 | |
| 400	9
 | |
| 401	10
 | |
| 402	11
 | |
| 403	12
 | |
| 404	13
 | |
| 405	14
 | |
| delete from t1 where a=0;
 | |
| update t1 set a=0 where b=12;
 | |
| select * from t1 order by b;
 | |
| a	b
 | |
| 1	1
 | |
| 200	2
 | |
| 201	4
 | |
| 300	7
 | |
| 301	8
 | |
| 400	9
 | |
| 401	10
 | |
| 402	11
 | |
| 0	12
 | |
| 404	13
 | |
| 405	14
 | |
| delete from t1 where a=0;
 | |
| update t1 set a=NULL where b=13;
 | |
| Warnings:
 | |
| Warning	1263	Column was set to data type implicit default; NULL supplied for NOT NULL column 'a' at row 9
 | |
| update t1 set a=500 where b=14;
 | |
| select * from t1 order by b;
 | |
| a	b
 | |
| 1	1
 | |
| 200	2
 | |
| 201	4
 | |
| 300	7
 | |
| 301	8
 | |
| 400	9
 | |
| 401	10
 | |
| 402	11
 | |
| 0	13
 | |
| 500	14
 | |
| drop table t1;
 | |
| create table t1 (a bigint);
 | |
| insert into t1 values (1), (2), (3), (NULL), (NULL);
 | |
| alter table t1 modify a bigint not null auto_increment primary key;
 | |
| select * from t1;
 | |
| a
 | |
| 1
 | |
| 2
 | |
| 3
 | |
| 4
 | |
| 5
 | |
| drop table t1;
 | |
| create table t1 (a bigint);
 | |
| insert into t1 values (1), (2), (3), (0), (0);
 | |
| alter table t1 modify a bigint not null auto_increment primary key;
 | |
| select * from t1;
 | |
| a
 | |
| 1
 | |
| 2
 | |
| 3
 | |
| 4
 | |
| 5
 | |
| drop table t1;
 | |
| create table t1 (a bigint);
 | |
| insert into t1 values (0), (1), (2), (3);
 | |
| set sql_mode=NO_AUTO_VALUE_ON_ZERO;
 | |
| alter table t1 modify a bigint not null auto_increment primary key;
 | |
| set sql_mode= '';
 | |
| select * from t1;
 | |
| a
 | |
| 0
 | |
| 1
 | |
| 2
 | |
| 3
 | |
| drop table t1;
 | |
| create table t1 (a int auto_increment primary key , b int null);
 | |
| set sql_mode=NO_AUTO_VALUE_ON_ZERO;
 | |
| insert into t1 values (0,1),(1,2),(2,3);
 | |
| select * from t1;
 | |
| a	b
 | |
| 0	1
 | |
| 1	2
 | |
| 2	3
 | |
| set sql_mode= '';
 | |
| alter table t1 modify b varchar(255);
 | |
| insert into t1 values (0,4);
 | |
| select * from t1;
 | |
| a	b
 | |
| 0	1
 | |
| 1	2
 | |
| 2	3
 | |
| 3	4
 | |
| drop table t1;
 | |
| CREATE TABLE t1 ( a INT AUTO_INCREMENT, b BLOB, PRIMARY KEY (a,b(10)));
 | |
| INSERT INTO t1 (b) VALUES ('aaaa');
 | |
| CHECK TABLE t1;
 | |
| Table	Op	Msg_type	Msg_text
 | |
| test.t1	check	status	OK
 | |
| INSERT INTO t1 (b) VALUES ('');
 | |
| CHECK TABLE t1;
 | |
| Table	Op	Msg_type	Msg_text
 | |
| test.t1	check	status	OK
 | |
| INSERT INTO t1 (b) VALUES ('bbbb');
 | |
| CHECK TABLE t1;
 | |
| Table	Op	Msg_type	Msg_text
 | |
| test.t1	check	status	OK
 | |
| DROP TABLE IF EXISTS t1;
 | |
| CREATE TABLE `t1` (
 | |
| t1_name VARCHAR(255) DEFAULT NULL,
 | |
| t1_id INT(10) UNSIGNED NOT NULL AUTO_INCREMENT,
 | |
| KEY (t1_name),
 | |
| PRIMARY KEY (t1_id)
 | |
| ) AUTO_INCREMENT = 1000;
 | |
| INSERT INTO t1 (t1_name) VALUES('MySQL');
 | |
| INSERT INTO t1 (t1_name) VALUES('MySQL');
 | |
| INSERT INTO t1 (t1_name) VALUES('MySQL');
 | |
| SELECT * from t1;
 | |
| t1_name	t1_id
 | |
| MySQL	1000
 | |
| MySQL	1001
 | |
| MySQL	1002
 | |
| SHOW CREATE TABLE `t1`;
 | |
| Table	Create Table
 | |
| t1	CREATE TABLE `t1` (
 | |
|   `t1_name` varchar(255) default NULL,
 | |
|   `t1_id` int(10) unsigned NOT NULL auto_increment,
 | |
|   PRIMARY KEY  (`t1_id`),
 | |
|   KEY `t1_name` (`t1_name`)
 | |
| ) ENGINE=MyISAM AUTO_INCREMENT=1003 DEFAULT CHARSET=latin1
 | |
| DROP TABLE `t1`;
 | |
| create table t1(a int not null auto_increment primary key);
 | |
| create table t2(a int not null auto_increment primary key, t1a int);
 | |
| insert into t1 values(NULL);
 | |
| insert into t2 values (NULL, LAST_INSERT_ID()), (NULL, LAST_INSERT_ID());
 | |
| insert into t1 values (NULL);
 | |
| insert into t2 values (NULL, LAST_INSERT_ID()), (NULL, LAST_INSERT_ID()),
 | |
| (NULL, LAST_INSERT_ID());
 | |
| insert into t1 values (NULL);
 | |
| insert into t2 values (NULL, LAST_INSERT_ID()), (NULL, LAST_INSERT_ID()),
 | |
| (NULL, LAST_INSERT_ID()), (NULL, LAST_INSERT_ID());
 | |
| select * from t2;
 | |
| a	t1a
 | |
| 1	1
 | |
| 2	1
 | |
| 3	2
 | |
| 4	2
 | |
| 5	2
 | |
| 6	3
 | |
| 7	3
 | |
| 8	3
 | |
| 9	3
 | |
| drop table t1, t2;
 | |
| End of 4.1 tests
 | |
| CREATE TABLE t1 ( `a` int(11) NOT NULL auto_increment, `b` int(11) default NULL,PRIMARY KEY  (`a`),UNIQUE KEY `b` (`b`));
 | |
| insert into t1 (b) values (1);
 | |
| replace into t1 (b) values (2), (1), (3);
 | |
| select * from t1;
 | |
| a	b
 | |
| 3	1
 | |
| 2	2
 | |
| 4	3
 | |
| truncate table t1;
 | |
| insert into t1 (b) values (1);
 | |
| replace into t1 (b) values (2);
 | |
| replace into t1 (b) values (1);
 | |
| replace into t1 (b) values (3);
 | |
| select * from t1;
 | |
| a	b
 | |
| 3	1
 | |
| 2	2
 | |
| 4	3
 | |
| drop table t1;
 | |
| create table t1 (rowid int not null auto_increment, val int not null,primary
 | |
| key (rowid), unique(val));
 | |
| replace into t1 (val) values ('1'),('2');
 | |
| replace into t1 (val) values ('1'),('2');
 | |
| insert into t1 (val) values ('1'),('2');
 | |
| ERROR 23000: Duplicate entry '1' for key 2
 | |
| select * from t1;
 | |
| rowid	val
 | |
| 3	1
 | |
| 4	2
 | |
| drop table t1;
 | |
| create table t1 (a int not null auto_increment primary key, val int);
 | |
| insert into t1 (val) values (1);
 | |
| update t1 set a=2 where a=1;
 | |
| insert into t1 (val) values (1);
 | |
| select * from t1;
 | |
| a	val
 | |
| 2	1
 | |
| 3	1
 | |
| drop table t1;
 |