~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to tests/t/delete.test

  • Committer: Jay Pipes
  • Date: 2009-01-30 04:01:12 UTC
  • mto: This revision was merged to the branch mainline in revision 830.
  • Revision ID: jpipes@serialcoder-20090130040112-svbn774guj98pwi4
To remain in compatibility with MySQL, added ability to interpret
decimal arguments as datetime strings for temporal functions.

Fixed YEAR(), MONTH(), DAYOFMONTH(), DAYOFYEAR(), HOUR(), MINUTE(), SECOND(), and MICROSECOND()
to accept decimal parameters and interpret them the same way as MySQL.

Fixed an issue with the TemporalFormat::matches() method which was 
incorrectly assuming all microsecond arguments were specified as 6 digits.
Added power of 10 multiplier to usecond calculation. This fixes issues with
failures in type_date and func_sapdb test cases.

Show diffs side-by-side

added added

removed removed

Lines of Context:
7
7
--enable_warnings
8
8
CREATE TABLE t1 (a int, b int);
9
9
INSERT INTO t1 VALUES (1,1);
10
 
INSERT INTO t1 VALUES (1,2);
 
10
INSERT LOW_PRIORITY INTO t1 VALUES (1,2);
11
11
INSERT INTO t1 VALUES (1,3);
12
12
DELETE from t1 where a=1 limit 1;
13
 
DELETE from t1 where a=1;
 
13
DELETE LOW_PRIORITY from t1 where a=1;
14
14
 
15
15
INSERT INTO t1 VALUES (1,1);
16
16
DELETE from t1;
 
17
LOCK TABLE t1 write;
17
18
INSERT INTO t1 VALUES (1,2);
18
19
DELETE from t1;
 
20
UNLOCK TABLES;
19
21
INSERT INTO t1 VALUES (1,2);
20
22
SET AUTOCOMMIT=0;
21
23
DELETE from t1;
63
65
  `i2` int NOT NULL default '0',
64
66
  PRIMARY KEY  (`i`)
65
67
);
 
68
-- error 1054
 
69
DELETE FROM t1 USING t1 WHERE post='1';
66
70
drop table t1;
67
71
 
68
72
#
69
73
# CHAR(0) bug - not actually DELETE bug, but anyway...
70
74
#
71
75
 
72
 
CREATE TEMPORARY TABLE t1 (
 
76
CREATE TABLE t1 (
73
77
  bool     char(0) default NULL,
74
 
  not_null varchar(20) NOT NULL default '',
 
78
  not_null varchar(20) binary NOT NULL default '',
75
79
  misc     integer not null,
76
80
  PRIMARY KEY  (not_null)
77
81
) ENGINE=MyISAM;
89
93
select count(*) from t1;
90
94
 
91
95
drop table t1;
 
96
#
 
97
# Bug #5733: Table handler error with self-join multi-table DELETE
 
98
#
 
99
 
 
100
create table t1 (a int not null auto_increment primary key, b char(32));
 
101
insert into t1 (b) values ('apple'), ('apple');
 
102
select * from t1;
 
103
delete t1 from t1, t1 as t2 where t1.b = t2.b and t1.a > t2.a;
 
104
select * from t1;
 
105
drop table t1;
92
106
 
93
107
#
94
108
# IGNORE option
103
117
--sorted_result
104
118
select * from t12;
105
119
select * from t2;
106
 
select * from t11;
107
 
--sorted_result
108
 
select * from t12;
109
 
select * from t11;
110
 
--sorted_result
111
 
select * from t12;
112
 
--error ER_SUBQUERY_NO_1_ROW
 
120
-- error 1242
 
121
delete t11.*, t12.* from t11,t12 where t11.a = t12.a and t11.b <> (select b from t2 where t11.a < t2.a);
 
122
select * from t11;
 
123
--sorted_result
 
124
select * from t12;
 
125
# PBXT: for some reason this returns 2 warnings instead of 1
 
126
delete ignore t11.*, t12.* from t11,t12 where t11.a = t12.a and t11.b <> (select b from t2 where t11.a < t2.a);
 
127
select * from t11;
 
128
--sorted_result
 
129
select * from t12;
 
130
insert into t11 values (2, 12);
 
131
-- error 1242
113
132
delete from t11 where t11.b <> (select b from t2 where t11.a < t2.a);
114
133
select * from t11;
115
 
 
116
 
# PBXT doesn't currently support DELETE IGNORE and turns it into plain DELETE
117
 
if (`select if (@@storage_engine = 'PBXT', 0, 1)`) { 
118
 
  delete ignore from t11 where t11.b <> (select b from t2 where t11.a < t2.a);
119
 
}
 
134
delete ignore from t11 where t11.b <> (select b from t2 where t11.a < t2.a);
120
135
select * from t11;
121
136
drop table t11, t12, t2;
122
137
 
126
141
 
127
142
create table t1 (a int, b int, unique key (a), key (b));
128
143
insert into t1 values (3, 3), (7, 7);
129
 
delete from t1 where a = 3;
 
144
delete t1 from t1 where a = 3;
130
145
check table t1;
131
146
select * from t1;
132
147
drop table t1;
143
158
DROP TABLE t1;
144
159
 
145
160
#
 
161
# Bug #21392: multi-table delete with alias table name fails with 
 
162
# 1003: Incorrect table name
 
163
#
 
164
 
 
165
create table t1 (a int);
 
166
delete `4.t1` from t1 as `4.t1` where `4.t1`.a = 5;
 
167
delete FROM `4.t1` USING t1 as `4.t1` where `4.t1`.a = 5;
 
168
drop table t1;
 
169
 
 
170
#
146
171
# Bug#17711: DELETE doesn't use index when ORDER BY, LIMIT and
147
172
#            non-restricting WHERE is present.
148
173
#
160
185
# BUG#30385 "Server crash when deleting with order by and limit"
161
186
CREATE TABLE t1 (
162
187
  `date` date ,
 
188
  `time` time ,
163
189
  `seq` int NOT NULL auto_increment,
164
190
  PRIMARY KEY  (`seq`),
165
191
  KEY `seq` (`seq`),
 
192
  KEY `time` (`time`),
166
193
  KEY `date` (`date`)
167
194
);
168
 
DELETE FROM t1 ORDER BY date ASC LIMIT 1;
 
195
DELETE FROM t1 ORDER BY date ASC, time ASC LIMIT 1;
169
196
drop table t1;
170
197
 
171
198
--echo End of 4.1 tests
172
199
 
173
200
#
 
201
# Test of multi-delete where we are not scanning the first table
 
202
#
 
203
 
 
204
CREATE TABLE t1 (a int not null,b int not null);
 
205
CREATE TABLE t2 (a int not null, b int not null, primary key (a,b));
 
206
CREATE TABLE t3 (a int not null, b int not null, primary key (a,b));
 
207
insert into t1 values (1,1),(2,1),(1,3);
 
208
insert into t2 values (1,1),(2,2),(3,3);
 
209
insert into t3 values (1,1),(2,1),(1,3);
 
210
select * from t1,t2,t3 where t1.a=t2.a AND t2.b=t3.a and t1.b=t3.b;
 
211
explain select * from t1,t2,t3 where t1.a=t2.a AND t2.b=t3.a and t1.b=t3.b;
 
212
delete t2.*,t3.* from t1,t2,t3 where t1.a=t2.a AND t2.b=t3.a and t1.b=t3.b;
 
213
# This should be empty
 
214
select * from t3;
 
215
drop table t1,t2,t3;
 
216
 
 
217
#
 
218
# Bug #8143: deleting '0000-00-00' values using IS NULL
 
219
#
 
220
 
 
221
create table t1(a date not null);
 
222
insert into t1 values (0);
 
223
select * from t1 where a is null;
 
224
delete from t1 where a is null;
 
225
select count(*) from t1;
 
226
drop table t1;
 
227
 
 
228
#
174
229
# Bug #26186: delete order by, sometimes accept unknown column
175
230
#
176
231
CREATE TABLE t1 (a INT); INSERT INTO t1 VALUES (1);
211
266
);
212
267
INSERT INTO db2.t1 (a) SELECT * FROM t2;
213
268
 
 
269
--error ER_PARSE_ERROR
 
270
DELETE FROM t1 alias USING t1, t2 alias WHERE t1.a = alias.a;
 
271
DELETE FROM alias USING t1, t2 alias WHERE t1.a = alias.a;
 
272
DELETE FROM t1, alias USING t1, t2 alias WHERE t1.a = alias.a;
 
273
--error ER_UNKNOWN_TABLE
 
274
DELETE FROM t1, t2 USING t1, t2 alias WHERE t1.a = alias.a;
 
275
--error ER_PARSE_ERROR
 
276
DELETE FROM db1.t1 alias USING db1.t1, db2.t1 alias WHERE db1.t1.a = alias.a;
 
277
DELETE FROM alias USING db1.t1, db2.t1 alias WHERE db1.t1.a = alias.a;
 
278
--error ER_UNKNOWN_TABLE
 
279
DELETE FROM db2.alias USING db1.t1, db2.t1 alias WHERE db1.t1.a = alias.a;
 
280
DELETE FROM t1 USING t1 WHERE a = 1;
214
281
SELECT * FROM t1;
215
282
--error ER_PARSE_ERROR
216
283
DELETE FROM t1 alias USING t1 alias WHERE a = 2;
248
315
CREATE TABLE t1 AS SELECT * FROM db2.t2;
249
316
CREATE TABLE t2 AS SELECT * FROM t1;
250
317
 
 
318
#
 
319
# Testing without a selected database
 
320
#
 
321
 
 
322
CREATE DATABASE db3;
 
323
USE db3;
 
324
DROP DATABASE db3;
 
325
--error ER_NO_DB_ERROR
 
326
SELECT * FROM t1;
 
327
 
 
328
# Detect missing table references
 
329
 
 
330
--error ER_NO_DB_ERROR
 
331
DELETE a1,a2 FROM db1.t1, db2.t2;
 
332
--error ER_NO_DB_ERROR
 
333
DELETE a1,a2 FROM db1.t1, db2.t2;
 
334
--error ER_NO_DB_ERROR
 
335
DELETE a1,a2 FROM db1.t1 AS a1, db2.t2;
 
336
--error ER_NO_DB_ERROR
 
337
DELETE a1,a2 FROM db1.t1, db2.t2 AS a2;
 
338
--error ER_NO_DB_ERROR
 
339
DELETE a1,a2 FROM db3.t1 AS a1, db4.t2 AS a2;
 
340
--error ER_NO_DB_ERROR
 
341
DELETE a1,a2 FROM db3.t1 AS a1, db4.t2 AS a2;
 
342
 
 
343
--error ER_NO_DB_ERROR
 
344
DELETE FROM a1,a2 USING db1.t1, db2.t2;
 
345
--error ER_NO_DB_ERROR
 
346
DELETE FROM a1,a2 USING db1.t1, db2.t2;
 
347
--error ER_NO_DB_ERROR
 
348
DELETE FROM a1,a2 USING db1.t1 AS a1, db2.t2;
 
349
--error ER_NO_DB_ERROR
 
350
DELETE FROM a1,a2 USING db1.t1, db2.t2 AS a2;
 
351
--error ER_NO_DB_ERROR
 
352
DELETE FROM a1,a2 USING db3.t1 AS a1, db4.t2 AS a2;
 
353
--error ER_NO_DB_ERROR
 
354
DELETE FROM a1,a2 USING db3.t1 AS a1, db4.t2 AS a2;
 
355
 
 
356
# Ambiguous table references
 
357
 
 
358
--error ER_NO_DB_ERROR
 
359
DELETE a1 FROM db1.t1 AS a1, db2.t2 AS a1;
 
360
--error ER_NO_DB_ERROR
 
361
DELETE a1 FROM db1.a1, db2.t2 AS a1;
 
362
--error ER_NO_DB_ERROR
 
363
DELETE a1 FROM a1, db1.t1 AS a1;
 
364
--error ER_NO_DB_ERROR
 
365
DELETE t1 FROM db1.t1, db2.t1 AS a1;
 
366
--error ER_NO_DB_ERROR
 
367
DELETE t1 FROM db1.t1 AS a1, db2.t1 AS a2;
 
368
--error ER_NO_DB_ERROR
 
369
DELETE t1 FROM db1.t1, db2.t1;
 
370
 
 
371
# Test all again, now with a selected database
 
372
 
 
373
USE test;
 
374
 
 
375
# Detect missing table references
 
376
 
 
377
--error ER_UNKNOWN_TABLE
 
378
DELETE a1,a2 FROM db1.t1, db2.t2;
 
379
--error ER_UNKNOWN_TABLE
 
380
DELETE a1,a2 FROM db1.t1, db2.t2;
 
381
--error ER_UNKNOWN_TABLE
 
382
DELETE a1,a2 FROM db1.t1 AS a1, db2.t2;
 
383
--error ER_UNKNOWN_TABLE
 
384
DELETE a1,a2 FROM db1.t1, db2.t2 AS a2;
 
385
--error ER_NO_SUCH_TABLE
 
386
DELETE a1,a2 FROM db3.t1 AS a1, db4.t2 AS a2;
 
387
--error ER_NO_SUCH_TABLE
 
388
DELETE a1,a2 FROM db3.t1 AS a1, db4.t2 AS a2;
 
389
 
 
390
--error ER_UNKNOWN_TABLE
 
391
DELETE FROM a1,a2 USING db1.t1, db2.t2;
 
392
--error ER_UNKNOWN_TABLE
 
393
DELETE FROM a1,a2 USING db1.t1, db2.t2;
 
394
--error ER_UNKNOWN_TABLE
 
395
DELETE FROM a1,a2 USING db1.t1 AS a1, db2.t2;
 
396
--error ER_UNKNOWN_TABLE
 
397
DELETE FROM a1,a2 USING db1.t1, db2.t2 AS a2;
 
398
--error ER_NO_SUCH_TABLE
 
399
DELETE FROM a1,a2 USING db3.t1 AS a1, db4.t2 AS a2;
 
400
--error ER_NO_SUCH_TABLE
 
401
DELETE FROM a1,a2 USING db3.t1 AS a1, db4.t2 AS a2;
 
402
 
 
403
# Ambiguous table references
 
404
 
 
405
--error ER_NONUNIQ_TABLE
 
406
DELETE a1 FROM db1.t1 AS a1, db2.t2 AS a1;
 
407
--error ER_NO_SUCH_TABLE
 
408
DELETE a1 FROM db1.a1, db2.t2 AS a1;
 
409
--error ER_NONUNIQ_TABLE
 
410
DELETE a1 FROM a1, db1.t1 AS a1;
 
411
--error ER_UNKNOWN_TABLE
 
412
DELETE t1 FROM db1.t1, db2.t1 AS a1;
 
413
--error ER_UNKNOWN_TABLE
 
414
DELETE t1 FROM db1.t1 AS a1, db2.t1 AS a2;
 
415
--error ER_UNKNOWN_TABLE
 
416
DELETE t1 FROM db1.t1, db2.t1;
 
417
 
 
418
# Test multiple-table cross database deletes
 
419
 
 
420
DELETE t1 FROM db1.t2 AS t1, db2.t2 AS t2 WHERE t2.a = 1 AND t1.a = t2.a;
 
421
SELECT ROW_COUNT();
 
422
DELETE a1, a2 FROM db2.t1 AS a1, t2 AS a2 WHERE a1.a = 2 AND a2.a = 2;
 
423
SELECT ROW_COUNT();
 
424
 
251
425
DROP DATABASE db1;
252
426
DROP DATABASE db2;
253
427
DROP TABLE t1, t2;