~ubuntu-branches/ubuntu/precise/mysql-5.1/precise

« back to all changes in this revision

Viewing changes to mysql-test/t/metadata.test

  • Committer: Bazaar Package Importer
  • Author(s): Norbert Tretkowski
  • Date: 2010-03-17 14:56:02 UTC
  • Revision ID: james.westby@ubuntu.com-20100317145602-x7e30l1b2sb5s6w6
Tags: upstream-5.1.45
ImportĀ upstreamĀ versionĀ 5.1.45

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
#
 
2
# Test metadata
 
3
#
 
4
 
 
5
--disable_warnings
 
6
drop table if exists t1,t2;
 
7
--enable_warnings
 
8
--enable_metadata
 
9
# PS protocol gives slightly different metadata
 
10
--disable_ps_protocol
 
11
 
 
12
#
 
13
# First some simple tests
 
14
#
 
15
 
 
16
select 1, 1.0, -1, "hello", NULL;
 
17
 
 
18
create table t1 (a tinyint, b smallint, c mediumint, d int, e bigint, f float(3,2), g double(4,3), h decimal(5,4), i year, j date, k timestamp, l datetime, m enum('a','b'), n set('a','b'), o char(10));
 
19
select * from t1;
 
20
select a b, b c from t1 as t2;
 
21
drop table t1;
 
22
 
 
23
#
 
24
# Test metadata from ORDER BY (Bug #2654)
 
25
#
 
26
 
 
27
CREATE TABLE t1 (id tinyint(3) default NULL, data varchar(255) default NULL);
 
28
INSERT INTO t1 VALUES (1,'male'),(2,'female');
 
29
CREATE TABLE t2 (id tinyint(3) unsigned default NULL, data char(3) default '0');
 
30
INSERT INTO t2 VALUES (1,'yes'),(2,'no');
 
31
 
 
32
select t1.id, t1.data, t2.data from t1, t2 where t1.id = t2.id;
 
33
select t1.id, t1.data, t2.data from t1, t2 where t1.id = t2.id order by t1.id;
 
34
select t1.id from t1 union select t2.id from t2;
 
35
drop table t1,t2;
 
36
 
 
37
#
 
38
# variables union and derived tables metadata test
 
39
#
 
40
create table t1 ( a int, b varchar(30), primary key(a));
 
41
insert into t1 values (1,'one');
 
42
insert into t1 values (2,'two');
 
43
set @arg00=1 ;
 
44
select @arg00 FROM t1 where a=1 union distinct select 1 FROM t1 where a=1;
 
45
select * from (select @arg00) aaa;
 
46
select 1 union select 1;
 
47
select * from (select 1 union select 1) aaa;
 
48
drop table t1;
 
49
 
 
50
--disable_metadata
 
51
 
 
52
#
 
53
# Bug #11688: Bad mysql_info() results in multi-results
 
54
#
 
55
--enable_info
 
56
delimiter //;
 
57
create table t1 (i int);
 
58
insert into t1 values (1),(2),(3);
 
59
select * from t1 where i = 2;
 
60
drop table t1;//
 
61
delimiter ;//
 
62
--disable_info
 
63
 
 
64
#
 
65
# Bug #20191: getTableName gives wrong or inconsistent result when using VIEWs
 
66
#
 
67
--enable_metadata
 
68
create table t1 (id int(10));
 
69
insert into t1 values (1);
 
70
CREATE  VIEW v1 AS select t1.id as id from t1;
 
71
CREATE  VIEW v2 AS select t1.id as renamed from t1;
 
72
CREATE  VIEW v3 AS select t1.id + 12 as renamed from t1;
 
73
select * from v1 group by id limit 1;
 
74
select * from v1 group by id limit 0;
 
75
select * from v1 where id=1000 group by id;
 
76
select * from v1 where id=1 group by id;
 
77
select * from v2 where renamed=1 group by renamed;
 
78
select * from v3 where renamed=1 group by renamed;
 
79
drop table t1;
 
80
drop view v1,v2,v3;
 
81
--disable_metadata
 
82
 
 
83
# End of 4.1 tests
 
84
 
 
85
#
 
86
# Bug #28492: subselect returns LONG in >5.0.24a and LONGLONG in <=5.0.24a
 
87
#
 
88
--enable_metadata
 
89
select a.* from (select 2147483648 as v_large) a;
 
90
select a.* from (select 214748364 as v_small) a;
 
91
--disable_metadata
 
92
 
 
93
#
 
94
# Bug #28898: table alias and database name of VIEW columns is empty in the
 
95
# metadata of # SELECT statement where join is executed via temporary table.
 
96
#
 
97
 
 
98
CREATE TABLE t1 (c1 CHAR(1));
 
99
CREATE TABLE t2 (c2 CHAR(1));
 
100
CREATE VIEW v1 AS SELECT t1.c1 FROM t1;
 
101
CREATE VIEW v2 AS SELECT t2.c2 FROM t2;
 
102
INSERT INTO t1 VALUES ('1'), ('2'), ('3');
 
103
INSERT INTO t2 VALUES ('1'), ('2'), ('3'), ('2');
 
104
 
 
105
--enable_metadata
 
106
SELECT v1.c1 FROM v1 JOIN t2 ON c1=c2 ORDER BY 1;
 
107
SELECT v1.c1, v2.c2 FROM v1 JOIN v2 ON c1=c2;
 
108
SELECT v1.c1, v2.c2 FROM v1 JOIN v2 ON c1=c2 GROUP BY v1.c1;
 
109
SELECT v1.c1, v2.c2 FROM v1 JOIN v2 ON c1=c2 GROUP BY v1.c1 ORDER BY v2.c2;
 
110
--disable_metadata
 
111
 
 
112
DROP VIEW v1,v2;
 
113
DROP TABLE t1,t2;
 
114
 
 
115
#
 
116
# Bug #39283: Date returned as VARBINARY to client for queries
 
117
#             with COALESCE and JOIN
 
118
#
 
119
 
 
120
CREATE TABLE t1 (i INT, d DATE);
 
121
INSERT INTO t1 VALUES (1, '2008-01-01'), (2, '2008-01-02'), (3, '2008-01-03');
 
122
 
 
123
--enable_metadata
 
124
--sorted_result
 
125
SELECT COALESCE(d, d), IFNULL(d, d), IF(i, d, d),
 
126
       CASE i WHEN i THEN d ELSE d END, GREATEST(d, d), LEAST(d, d)
 
127
  FROM t1 ORDER BY RAND(); # force filesort
 
128
--disable_metadata
 
129
 
 
130
DROP TABLE t1;
 
131
 
 
132
--echo End of 5.0 tests