5
CREATE TABLE FLOAT8_TBL(f1 float8);
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');
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;
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');
31
SELECT ' NAN '::float8;
32
SELECT 'infinity'::float8;
33
SELECT ' -INFINiTY '::float8;
35
SELECT 'N A N'::float8;
36
SELECT 'NaN x'::float8;
37
SELECT ' INFINITY x'::float8;
39
SELECT 'Infinity'::float8 + 100.0;
40
SELECT 'Infinity'::float8 / 'Infinity'::float8;
41
SELECT 'nan'::float8 / 'nan'::float8;
43
SELECT '' AS five, FLOAT8_TBL.*;
45
SELECT '' AS four, f.* FROM FLOAT8_TBL f WHERE f.f1 <> '1004.3';
47
SELECT '' AS one, f.* FROM FLOAT8_TBL f WHERE f.f1 = '1004.3';
49
SELECT '' AS three, f.* FROM FLOAT8_TBL f WHERE '1004.3' > f.f1;
51
SELECT '' AS three, f.* FROM FLOAT8_TBL f WHERE f.f1 < '1004.3';
53
SELECT '' AS four, f.* FROM FLOAT8_TBL f WHERE '1004.3' >= f.f1;
55
SELECT '' AS four, f.* FROM FLOAT8_TBL f WHERE f.f1 <= '1004.3';
57
SELECT '' AS three, f.f1, f.f1 * '-10' AS x
61
SELECT '' AS three, f.f1, f.f1 + '-10' AS x
65
SELECT '' AS three, f.f1, f.f1 / '-10' AS x
69
SELECT '' AS three, f.f1, f.f1 - '-10' AS x
73
SELECT '' AS one, f.f1 ^ '2.0' AS square_f1
74
FROM FLOAT8_TBL f where f.f1 = '1004.3';
77
SELECT '' AS five, f.f1, @f.f1 AS abs_f1
81
SELECT '' AS five, f.f1, %f.f1 AS trunc_f1
85
SELECT '' AS five, f.f1, f.f1 % AS round_f1
89
select ceil(f1) as ceil_f1 from float8_tbl f;
90
select ceiling(f1) as ceiling_f1 from float8_tbl f;
93
select floor(f1) as floor_f1 from float8_tbl f;
96
select sign(f1) as sign_f1 from float8_tbl f;
99
SELECT sqrt(float8 '64') AS eight;
101
SELECT |/ float8 '64' AS eight;
103
SELECT '' AS three, f.f1, |/f.f1 AS sqrt_f1
108
SELECT power(float8 '144', float8 '0.5');
110
-- take exp of ln(f.f1)
111
SELECT '' AS three, f.f1, exp(ln(f.f1)) AS exp_ln_f1
116
SELECT ||/ float8 '27' AS three;
118
SELECT '' AS five, f.f1, ||/f.f1 AS cbrt_f1 FROM FLOAT8_TBL f;
121
SELECT '' AS five, FLOAT8_TBL.*;
124
SET f1 = FLOAT8_TBL.f1 * '-1'
125
WHERE FLOAT8_TBL.f1 > '0.0';
127
SELECT '' AS bad, f.f1 * '1e200' from FLOAT8_TBL f;
129
SELECT '' AS bad, f.f1 ^ '1e200' from FLOAT8_TBL f;
131
SELECT '' AS bad, ln(f.f1) from FLOAT8_TBL f where f.f1 = '0.0' ;
133
SELECT '' AS bad, ln(f.f1) from FLOAT8_TBL f where f.f1 < '0.0' ;
135
SELECT '' AS bad, exp(f.f1) from FLOAT8_TBL f;
137
SELECT '' AS bad, f.f1 / '0.0' from FLOAT8_TBL f;
139
SELECT '' AS five, FLOAT8_TBL.*;
141
-- test for over- and underflow
142
INSERT INTO FLOAT8_TBL(f1) VALUES ('10e400');
144
INSERT INTO FLOAT8_TBL(f1) VALUES ('-10e400');
146
INSERT INTO FLOAT8_TBL(f1) VALUES ('10e-400');
148
INSERT INTO FLOAT8_TBL(f1) VALUES ('-10e-400');
150
-- maintain external table consistency across platforms
151
-- delete all values and reinsert well-behaved ones
153
DELETE FROM FLOAT8_TBL;
155
INSERT INTO FLOAT8_TBL(f1) VALUES ('0.0');
157
INSERT INTO FLOAT8_TBL(f1) VALUES ('-34.84');
159
INSERT INTO FLOAT8_TBL(f1) VALUES ('-1004.30');
161
INSERT INTO FLOAT8_TBL(f1) VALUES ('-1.2345678901234e+200');
163
INSERT INTO FLOAT8_TBL(f1) VALUES ('-1.2345678901234e-200');
165
SELECT '' AS five, FLOAT8_TBL.*;