5
drop table if exists t1, t2;
9
create table t1 (a int);
10
--error ER_TABLE_EXISTS_ERROR
11
create table t1 (a int);
15
--error ER_PARSE_ERROR
19
insert into t1 values (1);
20
--error ER_TRUNCATED_WRONG_VALUE_FOR_FIELD
21
insert into t1 values ("hej");
22
--error ER_TRUNCATED_WRONG_VALUE_FOR_FIELD
23
insert into t1 values ("hej"),("d�");
25
--error ER_TRUNCATED_WRONG_VALUE_FOR_FIELD
26
insert into t1 values ("hej");
27
--error ER_TRUNCATED_WRONG_VALUE_FOR_FIELD
28
insert into t1 values ("hej"),("d�");
36
drop temporary table if exists not_exists;
37
drop table if exists not_exists_table;
38
show warnings limit 1;
39
drop database if exists not_exists_db;
40
show count(*) warnings;
41
create table t1(id int);
42
create table if not exists t1(id int);
44
select @@warning_count;
49
# Test error for LOAD DATA INFILE
52
create table t1(a int, b int not null, c date, d char(5));
53
--replace_result $DRIZZLETEST_VARDIR DRIZZLETEST_VARDIR
54
--error ER_WARN_NULL_TO_NOTNULL
55
eval load data infile '$DRIZZLETEST_VARDIR/std_data_ln/warnings_loaddata.dat' into table t1 fields terminated by ',';
56
# PS doesn't work good with @@warning_count
58
select @@warning_count;
63
# Errors and Warnings from basic INSERT, UPDATE and ALTER commands
66
create table t1(a int NOT NULL, b int, c char(5));
68
# Error data to big for character field
69
--error ER_DATA_TOO_LONG
70
insert into t1 values(-1,100,'mysql'),(10,-1,'mysql ab'),(500,256,'open source'),(20,NULL,'test');
71
insert into t1 values(-1,100,'mysql'),(10,-1,'dri '),(500,256,'zzle'),(20,NULL,'test');
73
# Error as changing width truncates data
74
--error ER_WARN_DATA_TRUNCATED
75
alter table t1 modify c char(4);
76
alter table t1 add d char(2);
78
# Error trying to insert NULL data into NOT NULL field
79
--error ER_BAD_NULL_ERROR
80
update t1 set a=NULL where a=10;
82
# Error data to big for character field
83
--error ER_DATA_TOO_LONG
84
update t1 set c='drizzle' where c='test';
86
# Error data to big for character field
87
--error ER_DATA_TOO_LONG
90
create table t2(a int NOT NULL, b char(3));
92
# Error data to big for character field
93
--error ER_DATA_TOO_LONG
94
insert into t2 select b,c from t1;
96
# Error 'a' doesn't have a default value
97
--error ER_NO_DEFAULT_FOR_FIELD
98
insert into t2(b) values('mysqlab');
99
insert into t2(a) values(1);
103
# Error data to big for character field
104
--error ER_DATA_TOO_LONG
105
insert into t2(a,b) values(1,'mysqlab');
106
insert into t2(a,b) values(1,'mys');
112
# Test for max_error_count
115
create table t1(a char(10));
121
eval insert into t1 values('drizzle ab');
126
alter table t1 add b char;
127
set max_error_count=10;
129
# Error data to big for character field
130
--error ER_DATA_TOO_LONG
133
alter table t1 modify b char(10);
135
--disable_ps_protocol
136
select @@warning_count;
140
set max_error_count=0;
141
show variables like 'max_error_count';
142
update t1 set b='hi';
143
--disable_ps_protocol
144
select @@warning_count;
147
set max_error_count=65535;
148
show variables like 'max_error_count';
149
set max_error_count=10;
150
show variables like 'max_error_count';
155
# Tests for show errors and warnings limit a, b
157
create table t1 (a int);
158
insert into t1 (a) values (1), (2), (3), (4), (5), (6), (7), (8), (9), (10);
159
# Incorrect integer value abc for column a
160
--error ER_TRUNCATED_WRONG_VALUE_FOR_FIELD
161
update t1 set a='abc';
162
show warnings limit 2, 1;
163
show warnings limit 0, 10;
164
show warnings limit 9, 1;
165
show warnings limit 10, 1;
166
show warnings limit 9, 2;
167
show warnings limit 0, 0;
168
show warnings limit 1;
169
show warnings limit 0;
170
show warnings limit 1, 0;
171
# make sure behaviour is consistent with select ... limit
172
select * from t1 limit 0;
173
select * from t1 limit 1, 0;
174
select * from t1 limit 0, 0;
177
--echo End of 4.1 tests
179
create table t1 (c_char char(255), c_varchar varchar(255), c_tinytext blob);
180
set @c = repeat(' ', 256);
181
set @q = repeat('q', 256);
183
# BUG, 309791 currently only gives a warning but should give error
184
--error ER_DATA_TOO_LONG
185
insert into t1 values(@c, @c, @c);
187
--error ER_DATA_TOO_LONG
188
insert into t1 values(@q, NULL, NULL);
189
--error ER_DATA_TOO_LONG
190
insert into t1 values(NULL, @q, NULL);
191
insert into t1 values(NULL, NULL, @q);
195
--echo End of Drizzle tests