~vcs-imports/mammoth-replicator/trunk

« back to all changes in this revision

Viewing changes to src/test/regress/sql/float8.sql

  • Committer: alvherre
  • Date: 2005-12-16 21:24:52 UTC
  • Revision ID: svn-v4:db760fc0-0f08-0410-9d63-cc6633f64896:trunk:1
Initial import of the REL8_0_3 sources from the Pgsql CVS repository.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
--
 
2
-- FLOAT8
 
3
--
 
4
 
 
5
CREATE TABLE FLOAT8_TBL(f1 float8);
 
6
 
 
7
INSERT INTO FLOAT8_TBL(f1) VALUES ('    0.0   ');
 
8
INSERT INTO FLOAT8_TBL(f1) VALUES ('1004.30  ');
 
9
INSERT INTO FLOAT8_TBL(f1) VALUES ('   -34.84');
 
10
INSERT INTO FLOAT8_TBL(f1) VALUES ('1.2345678901234e+200');
 
11
INSERT INTO FLOAT8_TBL(f1) VALUES ('1.2345678901234e-200');
 
12
 
 
13
-- test for underflow and overflow handling
 
14
SELECT '10e400'::float8;
 
15
SELECT '-10e400'::float8;
 
16
SELECT '10e-400'::float8;
 
17
SELECT '-10e-400'::float8;
 
18
 
 
19
-- bad input
 
20
INSERT INTO FLOAT8_TBL(f1) VALUES ('     ');
 
21
INSERT INTO FLOAT8_TBL(f1) VALUES ('xyz');
 
22
INSERT INTO FLOAT8_TBL(f1) VALUES ('5.0.0');
 
23
INSERT INTO FLOAT8_TBL(f1) VALUES ('5 . 0');
 
24
INSERT INTO FLOAT8_TBL(f1) VALUES ('5.   0');
 
25
INSERT INTO FLOAT8_TBL(f1) VALUES ('    - 3');
 
26
INSERT INTO FLOAT8_TBL(f1) VALUES ('123           5');
 
27
 
 
28
-- special inputs
 
29
SELECT 'NaN'::float8;
 
30
SELECT 'nan'::float8;
 
31
SELECT '   NAN  '::float8;
 
32
SELECT 'infinity'::float8;
 
33
SELECT '          -INFINiTY   '::float8;
 
34
-- bad special inputs
 
35
SELECT 'N A N'::float8;
 
36
SELECT 'NaN x'::float8;
 
37
SELECT ' INFINITY    x'::float8;
 
38
 
 
39
SELECT 'Infinity'::float8 + 100.0;
 
40
SELECT 'Infinity'::float8 / 'Infinity'::float8;
 
41
SELECT 'nan'::float8 / 'nan'::float8;
 
42
 
 
43
SELECT '' AS five, FLOAT8_TBL.*;
 
44
 
 
45
SELECT '' AS four, f.* FROM FLOAT8_TBL f WHERE f.f1 <> '1004.3';
 
46
 
 
47
SELECT '' AS one, f.* FROM FLOAT8_TBL f WHERE f.f1 = '1004.3';
 
48
 
 
49
SELECT '' AS three, f.* FROM FLOAT8_TBL f WHERE '1004.3' > f.f1;
 
50
 
 
51
SELECT '' AS three, f.* FROM FLOAT8_TBL f WHERE  f.f1 < '1004.3';
 
52
 
 
53
SELECT '' AS four, f.* FROM FLOAT8_TBL f WHERE '1004.3' >= f.f1;
 
54
 
 
55
SELECT '' AS four, f.* FROM FLOAT8_TBL f WHERE  f.f1 <= '1004.3';
 
56
 
 
57
SELECT '' AS three, f.f1, f.f1 * '-10' AS x 
 
58
   FROM FLOAT8_TBL f
 
59
   WHERE f.f1 > '0.0';
 
60
 
 
61
SELECT '' AS three, f.f1, f.f1 + '-10' AS x
 
62
   FROM FLOAT8_TBL f
 
63
   WHERE f.f1 > '0.0';
 
64
 
 
65
SELECT '' AS three, f.f1, f.f1 / '-10' AS x
 
66
   FROM FLOAT8_TBL f
 
67
   WHERE f.f1 > '0.0';
 
68
 
 
69
SELECT '' AS three, f.f1, f.f1 - '-10' AS x
 
70
   FROM FLOAT8_TBL f
 
71
   WHERE f.f1 > '0.0';
 
72
 
 
73
SELECT '' AS one, f.f1 ^ '2.0' AS square_f1
 
74
   FROM FLOAT8_TBL f where f.f1 = '1004.3';
 
75
 
 
76
-- absolute value 
 
77
SELECT '' AS five, f.f1, @f.f1 AS abs_f1 
 
78
   FROM FLOAT8_TBL f;
 
79
 
 
80
-- truncate 
 
81
SELECT '' AS five, f.f1, %f.f1 AS trunc_f1
 
82
   FROM FLOAT8_TBL f;
 
83
 
 
84
-- round 
 
85
SELECT '' AS five, f.f1, f.f1 % AS round_f1
 
86
   FROM FLOAT8_TBL f;
 
87
 
 
88
-- ceil / ceiling
 
89
select ceil(f1) as ceil_f1 from float8_tbl f;
 
90
select ceiling(f1) as ceiling_f1 from float8_tbl f;
 
91
 
 
92
-- floor
 
93
select floor(f1) as floor_f1 from float8_tbl f;
 
94
 
 
95
-- sign
 
96
select sign(f1) as sign_f1 from float8_tbl f;
 
97
 
 
98
-- square root 
 
99
SELECT sqrt(float8 '64') AS eight;
 
100
 
 
101
SELECT |/ float8 '64' AS eight;
 
102
 
 
103
SELECT '' AS three, f.f1, |/f.f1 AS sqrt_f1
 
104
   FROM FLOAT8_TBL f
 
105
   WHERE f.f1 > '0.0';
 
106
 
 
107
-- power
 
108
SELECT power(float8 '144', float8 '0.5');
 
109
 
 
110
-- take exp of ln(f.f1) 
 
111
SELECT '' AS three, f.f1, exp(ln(f.f1)) AS exp_ln_f1
 
112
   FROM FLOAT8_TBL f
 
113
   WHERE f.f1 > '0.0';
 
114
 
 
115
-- cube root 
 
116
SELECT ||/ float8 '27' AS three;
 
117
 
 
118
SELECT '' AS five, f.f1, ||/f.f1 AS cbrt_f1 FROM FLOAT8_TBL f;
 
119
 
 
120
 
 
121
SELECT '' AS five, FLOAT8_TBL.*;
 
122
 
 
123
UPDATE FLOAT8_TBL
 
124
   SET f1 = FLOAT8_TBL.f1 * '-1'
 
125
   WHERE FLOAT8_TBL.f1 > '0.0';
 
126
 
 
127
SELECT '' AS bad, f.f1 * '1e200' from FLOAT8_TBL f;
 
128
 
 
129
SELECT '' AS bad, f.f1 ^ '1e200' from FLOAT8_TBL f;
 
130
 
 
131
SELECT '' AS bad, ln(f.f1) from FLOAT8_TBL f where f.f1 = '0.0' ;
 
132
 
 
133
SELECT '' AS bad, ln(f.f1) from FLOAT8_TBL f where f.f1 < '0.0' ;
 
134
 
 
135
SELECT '' AS bad, exp(f.f1) from FLOAT8_TBL f;
 
136
 
 
137
SELECT '' AS bad, f.f1 / '0.0' from FLOAT8_TBL f;
 
138
 
 
139
SELECT '' AS five, FLOAT8_TBL.*;
 
140
 
 
141
-- test for over- and underflow 
 
142
INSERT INTO FLOAT8_TBL(f1) VALUES ('10e400');
 
143
 
 
144
INSERT INTO FLOAT8_TBL(f1) VALUES ('-10e400');
 
145
 
 
146
INSERT INTO FLOAT8_TBL(f1) VALUES ('10e-400');
 
147
 
 
148
INSERT INTO FLOAT8_TBL(f1) VALUES ('-10e-400');
 
149
 
 
150
-- maintain external table consistency across platforms
 
151
-- delete all values and reinsert well-behaved ones
 
152
 
 
153
DELETE FROM FLOAT8_TBL;
 
154
 
 
155
INSERT INTO FLOAT8_TBL(f1) VALUES ('0.0');
 
156
 
 
157
INSERT INTO FLOAT8_TBL(f1) VALUES ('-34.84');
 
158
 
 
159
INSERT INTO FLOAT8_TBL(f1) VALUES ('-1004.30');
 
160
 
 
161
INSERT INTO FLOAT8_TBL(f1) VALUES ('-1.2345678901234e+200');
 
162
 
 
163
INSERT INTO FLOAT8_TBL(f1) VALUES ('-1.2345678901234e-200');
 
164
 
 
165
SELECT '' AS five, FLOAT8_TBL.*;
 
166