mirror of
https://github.com/MariaDB/server.git
synced 2025-01-17 12:32:27 +01:00
2a49121590
Under strict mode MySQL will generate an error message if there was any conversion when assigning data to a field. Added checking of date/datetime fields. If strict mode, give error if we have not given value to field without a default value (for INSERT) client/mysqltest.c: Added --exit as an option to abort a test in a middle (good for debugging) include/my_time.h: Added flags to allow checking of dates in strict mode include/mysql_com.h: Added flag to check if field has a default value or not include/mysqld_error.h: New error messages for strict mode include/sql_state.h: Fixed SQL states (for strict mode tests) mysql-test/r/auto_increment.result: Updated error messages mysql-test/r/func_sapdb.result: Added test for ALLOW_INVALID_DATES mysql-test/r/func_str.result: Updated error messages mysql-test/r/func_time.result: Updated error messages mysql-test/r/insert.result: Updated error messages mysql-test/r/loaddata.result: Updated error messages mysql-test/r/select.result: Updated error messages mysql-test/r/sp.result: Updated error messages mysql-test/r/timezone2.result: Updated error messages mysql-test/r/type_datetime.result: Updated error messages mysql-test/r/type_decimal.result: Updated error messages mysql-test/r/type_float.result: Updated error messages mysql-test/r/type_ranges.result: Updated error messages mysql-test/r/type_time.result: Updated error messages mysql-test/r/type_uint.result: Updated error messages mysql-test/r/warnings.result: Updated error messages mysql-test/t/func_sapdb.test: Aded test sql-common/my_time.c: Added checking of dates sql/field.cc: Better error messages Optimization of warning handling (by introducing of check_int()) Changed to use my_strtoll10() sql/field.h: Added check_int() sql/item_func.cc: Warnings when dividing by NULL sql/item_func.h: Warnings when dividing by NULL sql/item_timefunc.cc: Testing of date/datetime Use macros instead of constants sql/mysql_priv.h: New modes (part of strict mode) sql/mysqld.cc: New modes (part of strict mode) sql/opt_range.cc: Simple optimizations sql/protocol.cc: Add note/warning level to find_handler() sql/set_var.cc: Added mode 'traditional' sql/share/czech/errmsg.txt: New error messages for strict mode sql/share/danish/errmsg.txt: New error messages for strict mode sql/share/dutch/errmsg.txt: New error messages for strict mode sql/share/english/errmsg.txt: New error messages for strict mode sql/share/estonian/errmsg.txt: New error messages for strict mode sql/share/french/errmsg.txt: New error messages for strict mode sql/share/german/errmsg.txt: New error messages for strict mode sql/share/greek/errmsg.txt: New error messages for strict mode sql/share/hungarian/errmsg.txt: New error messages for strict mode sql/share/italian/errmsg.txt: New error messages for strict mode sql/share/japanese/errmsg.txt: New error messages for strict mode sql/share/korean/errmsg.txt: New error messages for strict mode sql/share/norwegian-ny/errmsg.txt: New error messages for strict mode sql/share/norwegian/errmsg.txt: New error messages for strict mode sql/share/polish/errmsg.txt: New error messages for strict mode sql/share/portuguese/errmsg.txt: New error messages for strict mode sql/share/romanian/errmsg.txt: New error messages for strict mode sql/share/russian/errmsg.txt: New error messages for strict mode sql/share/serbian/errmsg.txt: New error messages for strict mode sql/share/slovak/errmsg.txt: New error messages for strict mode sql/share/spanish/errmsg.txt: New error messages for strict mode sql/share/swedish/errmsg.txt: New error messages for strict mode sql/share/ukrainian/errmsg.txt: New error messages for strict mode sql/sp_rcontext.cc: Add note/warning level to find_handler() sql/sp_rcontext.h: Add note/warning level to find_handler() sql/sql_base.cc: Fix bug for detecting crashed table sql/sql_class.cc: Variables for strct mode sql/sql_class.h: Variables for strct mode sql/sql_error.cc: In strict mode, convert warnings to errors sql/sql_insert.cc: Strict mode If strict mode, give error if we have not given value to field without a default value sql/sql_load.cc: Strict mode sql/sql_parse.cc: Strict mode. Add flag to field if it doesn't have a default value sql/sql_select.cc: Added comment Prepare for upper level handling of table->status sql/sql_union.cc: Added THD to write_record() sql/sql_update.cc: Strict mode sql/table.cc: Handling of default values sql/time.cc: Checking of dates
339 lines
12 KiB
Text
339 lines
12 KiB
Text
drop table if exists t1,t2;
|
|
create table t1 (a int not null);
|
|
insert into t1 values (1);
|
|
insert into t1 values (a+2);
|
|
insert into t1 values (a+3);
|
|
insert into t1 values (4),(a+5);
|
|
select * from t1;
|
|
a
|
|
1
|
|
2
|
|
3
|
|
4
|
|
5
|
|
drop table t1;
|
|
create table t1 (id int not null auto_increment primary key, username varchar(32) not null, unique (username));
|
|
insert into t1 values (0,"mysql");
|
|
insert into t1 values (0,"mysql ab");
|
|
insert into t1 values (0,"mysql a");
|
|
insert into t1 values (0,"r1manic");
|
|
insert into t1 values (0,"r1man");
|
|
drop table t1;
|
|
create table t1 (a int not null auto_increment, primary key (a), t timestamp, c char(10) default "hello", i int);
|
|
insert into t1 values (default,default,default,default), (default,default,default,default), (4,0,"a",5),(default,default,default,default);
|
|
select a,t>0,c,i from t1;
|
|
a t>0 c i
|
|
1 1 hello NULL
|
|
2 1 hello NULL
|
|
4 0 a 5
|
|
5 1 hello NULL
|
|
truncate table t1;
|
|
insert into t1 set a=default,t=default,c=default;
|
|
insert into t1 set a=default,t=default,c=default,i=default;
|
|
insert into t1 set a=4,t=0,c="a",i=5;
|
|
insert into t1 set a=5,t=0,c="a",i=null;
|
|
insert into t1 set a=default,t=default,c=default,i=default;
|
|
select a,t>0,c,i from t1;
|
|
a t>0 c i
|
|
1 1 hello NULL
|
|
2 1 hello NULL
|
|
4 0 a 5
|
|
5 0 a NULL
|
|
6 1 hello NULL
|
|
drop table t1;
|
|
create table t1 (sid char(20), id int(2) NOT NULL auto_increment, key(sid, id));
|
|
insert into t1 values ('skr',NULL),('skr',NULL),('test',NULL);
|
|
select * from t1;
|
|
sid id
|
|
skr 1
|
|
skr 2
|
|
test 1
|
|
insert into t1 values ('rts',NULL),('rts',NULL),('test',NULL);
|
|
select * from t1;
|
|
sid id
|
|
rts 1
|
|
rts 2
|
|
skr 1
|
|
skr 2
|
|
test 1
|
|
test 2
|
|
drop table t1;
|
|
create table t1 (id int NOT NULL DEFAULT 8);
|
|
insert into t1 values(NULL);
|
|
ERROR 23000: Column 'id' cannot be null
|
|
insert into t1 values (1), (NULL), (2);
|
|
Warnings:
|
|
Warning 1263 Data truncated; NULL supplied to NOT NULL column 'id' at row 2
|
|
select * from t1;
|
|
id
|
|
1
|
|
0
|
|
2
|
|
drop table t1;
|
|
create table t1 (email varchar(50));
|
|
insert into t1 values ('sasha@mysql.com'),('monty@mysql.com'),('foo@hotmail.com'),('foo@aol.com'),('bar@aol.com');
|
|
create table t2(id int not null auto_increment primary key, t2 varchar(50), unique(t2));
|
|
insert delayed into t2 (t2) select distinct substring(email, locate('@', email)+1) from t1;
|
|
select * from t2;
|
|
id t2
|
|
1 mysql.com
|
|
2 hotmail.com
|
|
3 aol.com
|
|
drop table t1,t2;
|
|
drop database if exists mysqltest;
|
|
create database mysqltest;
|
|
use mysqltest;
|
|
create table t1 (c int);
|
|
insert into mysqltest.t1 set mysqltest.t1.c = '1';
|
|
drop database mysqltest;
|
|
use test;
|
|
create table t1(number int auto_increment primary key, original_value varchar(50), f_double double, f_float float, f_double_7_2 double(7,2), f_float_4_3 float (4,3), f_double_u double unsigned, f_float_u float unsigned, f_double_15_1_u double(15,1) unsigned, f_float_3_1_u float (3,1) unsigned);
|
|
set @value= "aa";
|
|
insert into t1 values(null,@value,@value,@value,@value,@value,@value,@value,@value,@value);
|
|
Warnings:
|
|
Warning 1265 Data truncated for column 'f_double' at row 1
|
|
Warning 1265 Data truncated for column 'f_float' at row 1
|
|
Warning 1265 Data truncated for column 'f_double_7_2' at row 1
|
|
Warning 1265 Data truncated for column 'f_float_4_3' at row 1
|
|
Warning 1265 Data truncated for column 'f_double_u' at row 1
|
|
Warning 1265 Data truncated for column 'f_float_u' at row 1
|
|
Warning 1265 Data truncated for column 'f_double_15_1_u' at row 1
|
|
Warning 1265 Data truncated for column 'f_float_3_1_u' at row 1
|
|
select * from t1 where number =last_insert_id();
|
|
number 1
|
|
original_value aa
|
|
f_double 0
|
|
f_float 0
|
|
f_double_7_2 0.00
|
|
f_float_4_3 0.000
|
|
f_double_u 0
|
|
f_float_u 0
|
|
f_double_15_1_u 0.0
|
|
f_float_3_1_u 0.0
|
|
set @value= "1aa";
|
|
insert into t1 values(null,@value,@value,@value,@value,@value,@value,@value,@value,@value);
|
|
Warnings:
|
|
Warning 1265 Data truncated for column 'f_double' at row 1
|
|
Warning 1265 Data truncated for column 'f_float' at row 1
|
|
Warning 1265 Data truncated for column 'f_double_7_2' at row 1
|
|
Warning 1265 Data truncated for column 'f_float_4_3' at row 1
|
|
Warning 1265 Data truncated for column 'f_double_u' at row 1
|
|
Warning 1265 Data truncated for column 'f_float_u' at row 1
|
|
Warning 1265 Data truncated for column 'f_double_15_1_u' at row 1
|
|
Warning 1265 Data truncated for column 'f_float_3_1_u' at row 1
|
|
select * from t1 where number =last_insert_id();
|
|
number 2
|
|
original_value 1aa
|
|
f_double 1
|
|
f_float 1
|
|
f_double_7_2 1.00
|
|
f_float_4_3 1.000
|
|
f_double_u 1
|
|
f_float_u 1
|
|
f_double_15_1_u 1.0
|
|
f_float_3_1_u 1.0
|
|
set @value= "aa1";
|
|
insert into t1 values(null,@value,@value,@value,@value,@value,@value,@value,@value,@value);
|
|
Warnings:
|
|
Warning 1265 Data truncated for column 'f_double' at row 1
|
|
Warning 1265 Data truncated for column 'f_float' at row 1
|
|
Warning 1265 Data truncated for column 'f_double_7_2' at row 1
|
|
Warning 1265 Data truncated for column 'f_float_4_3' at row 1
|
|
Warning 1265 Data truncated for column 'f_double_u' at row 1
|
|
Warning 1265 Data truncated for column 'f_float_u' at row 1
|
|
Warning 1265 Data truncated for column 'f_double_15_1_u' at row 1
|
|
Warning 1265 Data truncated for column 'f_float_3_1_u' at row 1
|
|
select * from t1 where number =last_insert_id();
|
|
number 3
|
|
original_value aa1
|
|
f_double 0
|
|
f_float 0
|
|
f_double_7_2 0.00
|
|
f_float_4_3 0.000
|
|
f_double_u 0
|
|
f_float_u 0
|
|
f_double_15_1_u 0.0
|
|
f_float_3_1_u 0.0
|
|
set @value= "1e+1111111111a";
|
|
insert into t1 values(null,@value,@value,@value,@value,@value,@value,@value,@value,@value);
|
|
Warnings:
|
|
Warning 1265 Data truncated for column 'f_double' at row 1
|
|
Warning 1265 Data truncated for column 'f_float' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_float' at row 1
|
|
Warning 1265 Data truncated for column 'f_double_7_2' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_double_7_2' at row 1
|
|
Warning 1265 Data truncated for column 'f_float_4_3' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_float_4_3' at row 1
|
|
Warning 1265 Data truncated for column 'f_double_u' at row 1
|
|
Warning 1265 Data truncated for column 'f_float_u' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_float_u' at row 1
|
|
Warning 1265 Data truncated for column 'f_double_15_1_u' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_double_15_1_u' at row 1
|
|
Warning 1265 Data truncated for column 'f_float_3_1_u' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_float_3_1_u' at row 1
|
|
select * from t1 where number =last_insert_id();
|
|
number 4
|
|
original_value 1e+1111111111a
|
|
f_double 1.79769313486232e+308
|
|
f_float 3.40282e+38
|
|
f_double_7_2 99999.99
|
|
f_float_4_3 9.999
|
|
f_double_u 1.79769313486232e+308
|
|
f_float_u 3.40282e+38
|
|
f_double_15_1_u 99999999999999.9
|
|
f_float_3_1_u 99.9
|
|
set @value= "-1e+1111111111a";
|
|
insert into t1 values(null,@value,@value,@value,@value,@value,@value,@value,@value,@value);
|
|
Warnings:
|
|
Warning 1265 Data truncated for column 'f_double' at row 1
|
|
Warning 1265 Data truncated for column 'f_float' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_float' at row 1
|
|
Warning 1265 Data truncated for column 'f_double_7_2' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_double_7_2' at row 1
|
|
Warning 1265 Data truncated for column 'f_float_4_3' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_float_4_3' at row 1
|
|
Warning 1265 Data truncated for column 'f_double_u' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_double_u' at row 1
|
|
Warning 1265 Data truncated for column 'f_float_u' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_float_u' at row 1
|
|
Warning 1265 Data truncated for column 'f_double_15_1_u' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_double_15_1_u' at row 1
|
|
Warning 1265 Data truncated for column 'f_float_3_1_u' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_float_3_1_u' at row 1
|
|
select * from t1 where number =last_insert_id();
|
|
number 5
|
|
original_value -1e+1111111111a
|
|
f_double -1.79769313486232e+308
|
|
f_float -3.40282e+38
|
|
f_double_7_2 -99999.99
|
|
f_float_4_3 -9.999
|
|
f_double_u 0
|
|
f_float_u 0
|
|
f_double_15_1_u 0.0
|
|
f_float_3_1_u 0.0
|
|
set @value= 1e+1111111111;
|
|
insert into t1 values(null,@value,@value,@value,@value,@value,@value,@value,@value,@value);
|
|
Warnings:
|
|
Warning 1264 Out of range value adjusted for column 'f_float' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_double_7_2' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_float_4_3' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_float_u' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_double_15_1_u' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_float_3_1_u' at row 1
|
|
select * from t1 where number =last_insert_id();
|
|
number 6
|
|
original_value 1.7976931348623e+308
|
|
f_double 1.79769313486232e+308
|
|
f_float 3.40282e+38
|
|
f_double_7_2 99999.99
|
|
f_float_4_3 9.999
|
|
f_double_u 1.79769313486232e+308
|
|
f_float_u 3.40282e+38
|
|
f_double_15_1_u 99999999999999.9
|
|
f_float_3_1_u 99.9
|
|
set @value= -1e+1111111111;
|
|
insert into t1 values(null,@value,@value,@value,@value,@value,@value,@value,@value,@value);
|
|
Warnings:
|
|
Warning 1264 Out of range value adjusted for column 'f_float' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_double_7_2' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_float_4_3' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_double_u' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_float_u' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_double_15_1_u' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_float_3_1_u' at row 1
|
|
select * from t1 where number =last_insert_id();
|
|
number 7
|
|
original_value -1.7976931348623e+308
|
|
f_double -1.79769313486232e+308
|
|
f_float -3.40282e+38
|
|
f_double_7_2 -99999.99
|
|
f_float_4_3 -9.999
|
|
f_double_u 0
|
|
f_float_u 0
|
|
f_double_15_1_u 0.0
|
|
f_float_3_1_u 0.0
|
|
set @value= 1e+111;
|
|
insert into t1 values(null,@value,@value,@value,@value,@value,@value,@value,@value,@value);
|
|
Warnings:
|
|
Warning 1264 Out of range value adjusted for column 'f_float' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_double_7_2' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_float_4_3' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_float_u' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_double_15_1_u' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_float_3_1_u' at row 1
|
|
select * from t1 where number =last_insert_id();
|
|
number 8
|
|
original_value 1e+111
|
|
f_double 1e+111
|
|
f_float 3.40282e+38
|
|
f_double_7_2 99999.99
|
|
f_float_4_3 9.999
|
|
f_double_u 1e+111
|
|
f_float_u 3.40282e+38
|
|
f_double_15_1_u 99999999999999.9
|
|
f_float_3_1_u 99.9
|
|
set @value= -1e+111;
|
|
insert into t1 values(null,@value,@value,@value,@value,@value,@value,@value,@value,@value);
|
|
Warnings:
|
|
Warning 1264 Out of range value adjusted for column 'f_float' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_double_7_2' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_float_4_3' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_double_u' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_float_u' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_double_15_1_u' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_float_3_1_u' at row 1
|
|
select * from t1 where number =last_insert_id();
|
|
number 9
|
|
original_value -1e+111
|
|
f_double -1e+111
|
|
f_float -3.40282e+38
|
|
f_double_7_2 -99999.99
|
|
f_float_4_3 -9.999
|
|
f_double_u 0
|
|
f_float_u 0
|
|
f_double_15_1_u 0.0
|
|
f_float_3_1_u 0.0
|
|
set @value= 1;
|
|
insert into t1 values(null,@value,@value,@value,@value,@value,@value,@value,@value,@value);
|
|
select * from t1 where number =last_insert_id();
|
|
number 10
|
|
original_value 1
|
|
f_double 1
|
|
f_float 1
|
|
f_double_7_2 1.00
|
|
f_float_4_3 1.000
|
|
f_double_u 1
|
|
f_float_u 1
|
|
f_double_15_1_u 1.0
|
|
f_float_3_1_u 1.0
|
|
set @value= -1;
|
|
insert into t1 values(null,@value,@value,@value,@value,@value,@value,@value,@value,@value);
|
|
Warnings:
|
|
Warning 1264 Out of range value adjusted for column 'f_double_u' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_float_u' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_double_15_1_u' at row 1
|
|
Warning 1264 Out of range value adjusted for column 'f_float_3_1_u' at row 1
|
|
select * from t1 where number =last_insert_id();
|
|
number 11
|
|
original_value -1
|
|
f_double -1
|
|
f_float -1
|
|
f_double_7_2 -1.00
|
|
f_float_4_3 -1.000
|
|
f_double_u 0
|
|
f_float_u 0
|
|
f_double_15_1_u 0.0
|
|
f_float_3_1_u 0.0
|
|
use test;
|
|
drop table if exists t1,t2,t3;
|
|
create table t1(id1 int not null auto_increment primary key, t char(12));
|
|
create table t2(id2 int not null, t char(12));
|
|
create table t3(id3 int not null, t char(12), index(id3));
|
|
select count(*) from t2;
|
|
count(*)
|
|
500
|
|
insert into t2 select t1.* from t1, t2 t, t3 where t1.id1 = t.id2 and t.id2 = t3.id3;
|
|
select count(*) from t2;
|
|
count(*)
|
|
25500
|
|
drop table if exists t1,t2,t3;
|