-- -- FLOAT4 -- CREATE EXTENSION sqlite_fdw; CREATE SERVER sqlite_svr FOREIGN DATA WRAPPER sqlite_fdw OPTIONS (database '/tmp/sqlitefdw_test_core.db'); CREATE FOREIGN TABLE FLOAT4_TBL(f1 float4 OPTIONS (key 'true')) SERVER sqlite_svr; INSERT INTO FLOAT4_TBL(f1) VALUES (' 0.0'); INSERT INTO FLOAT4_TBL(f1) VALUES ('1004.30 '); INSERT INTO FLOAT4_TBL(f1) VALUES (' -34.84 '); INSERT INTO FLOAT4_TBL(f1) VALUES ('1.2345678901234e+20'); INSERT INTO FLOAT4_TBL(f1) VALUES ('1.2345678901234e-20'); -- test for over and under flow INSERT INTO FLOAT4_TBL(f1) VALUES ('10e70'); ERROR: value out of range: overflow LINE 1: INSERT INTO FLOAT4_TBL(f1) VALUES ('10e70'); ^ INSERT INTO FLOAT4_TBL(f1) VALUES ('-10e70'); ERROR: value out of range: overflow LINE 1: INSERT INTO FLOAT4_TBL(f1) VALUES ('-10e70'); ^ INSERT INTO FLOAT4_TBL(f1) VALUES ('10e-70'); ERROR: value out of range: underflow LINE 1: INSERT INTO FLOAT4_TBL(f1) VALUES ('10e-70'); ^ INSERT INTO FLOAT4_TBL(f1) VALUES ('-10e-70'); ERROR: value out of range: underflow LINE 1: INSERT INTO FLOAT4_TBL(f1) VALUES ('-10e-70'); ^ -- bad input INSERT INTO FLOAT4_TBL(f1) VALUES (''); ERROR: invalid input syntax for type real: "" LINE 1: INSERT INTO FLOAT4_TBL(f1) VALUES (''); ^ INSERT INTO FLOAT4_TBL(f1) VALUES (' '); ERROR: invalid input syntax for type real: " " LINE 1: INSERT INTO FLOAT4_TBL(f1) VALUES (' '); ^ INSERT INTO FLOAT4_TBL(f1) VALUES ('xyz'); ERROR: invalid input syntax for type real: "xyz" LINE 1: INSERT INTO FLOAT4_TBL(f1) VALUES ('xyz'); ^ INSERT INTO FLOAT4_TBL(f1) VALUES ('5.0.0'); ERROR: invalid input syntax for type real: "5.0.0" LINE 1: INSERT INTO FLOAT4_TBL(f1) VALUES ('5.0.0'); ^ INSERT INTO FLOAT4_TBL(f1) VALUES ('5 . 0'); ERROR: invalid input syntax for type real: "5 . 0" LINE 1: INSERT INTO FLOAT4_TBL(f1) VALUES ('5 . 0'); ^ INSERT INTO FLOAT4_TBL(f1) VALUES ('5. 0'); ERROR: invalid input syntax for type real: "5. 0" LINE 1: INSERT INTO FLOAT4_TBL(f1) VALUES ('5. 0'); ^ INSERT INTO FLOAT4_TBL(f1) VALUES (' - 3.0'); ERROR: invalid input syntax for type real: " - 3.0" LINE 1: INSERT INTO FLOAT4_TBL(f1) VALUES (' - 3.0'); ^ INSERT INTO FLOAT4_TBL(f1) VALUES ('123 5'); ERROR: invalid input syntax for type real: "123 5" LINE 1: INSERT INTO FLOAT4_TBL(f1) VALUES ('123 5'); ^ -- special inputs BEGIN; DELETE FROM FLOAT4_TBL; INSERT INTO FLOAT4_TBL(f1) VALUES ('NaN'::float4); INSERT INTO FLOAT4_TBL(f1) VALUES ('nan'::float4); INSERT INTO FLOAT4_TBL(f1) VALUES (' NAN '::float4); INSERT INTO FLOAT4_TBL(f1) VALUES ('infinity'::float4); INSERT INTO FLOAT4_TBL(f1) VALUES (' -INFINiTY '::float4); SELECT * FROM FLOAT4_TBL; f1 ----------- Infinity -Infinity (5 rows) ROLLBACK; -- bad special inputs INSERT INTO FLOAT4_TBL(f1) VALUES ('N A N'::float4); ERROR: invalid input syntax for type real: "N A N" LINE 1: INSERT INTO FLOAT4_TBL(f1) VALUES ('N A N'::float4); ^ INSERT INTO FLOAT4_TBL(f1) VALUES ('NaN x'::float4); ERROR: invalid input syntax for type real: "NaN x" LINE 1: INSERT INTO FLOAT4_TBL(f1) VALUES ('NaN x'::float4); ^ INSERT INTO FLOAT4_TBL(f1) VALUES (' INFINITY x'::float4); ERROR: invalid input syntax for type real: " INFINITY x" LINE 1: INSERT INTO FLOAT4_TBL(f1) VALUES (' INFINITY x'::float4)... ^ BEGIN; DELETE FROM FLOAT4_TBL; INSERT INTO FLOAT4_TBL(f1) VALUES ('Infinity'::float4 + 100.0); INSERT INTO FLOAT4_TBL(f1) VALUES ('Infinity'::float4 / 'Infinity'::float4); INSERT INTO FLOAT4_TBL(f1) VALUES ('nan'::float4 / 'nan'::float4); INSERT INTO FLOAT4_TBL(f1) VALUES ('nan'::numeric::float4); SELECT * FROM FLOAT4_TBL; f1 ---------- Infinity (4 rows) ROLLBACK; SELECT '' AS five, * FROM FLOAT4_TBL; five | f1 ------+------------- | 0 | 1004.3 | -34.84 | 1.23457e+20 | 1.23457e-20 (5 rows) SELECT '' AS four, f.* FROM FLOAT4_TBL f WHERE '1004.3' >= f.f1; four | f1 ------+------------- | 0 | 1004.3 | -34.84 | 1.23457e-20 (4 rows) SELECT '' AS four, f.* FROM FLOAT4_TBL f WHERE f.f1 <= '1004.3'; four | f1 ------+------------- | 0 | 1004.3 | -34.84 | 1.23457e-20 (4 rows) SELECT '' AS three, f.f1, f.f1 * '-10' AS x FROM FLOAT4_TBL f WHERE f.f1 > '0.0'; three | f1 | x -------+-------------+-------------- | 1004.3 | -10043 | 1.23457e+20 | -1.23457e+21 | 1.23457e-20 | -1.23457e-19 (3 rows) SELECT '' AS three, f.f1, f.f1 + '-10' AS x FROM FLOAT4_TBL f WHERE f.f1 > '0.0'; three | f1 | x -------+-------------+------------- | 1004.3 | 994.3 | 1.23457e+20 | 1.23457e+20 | 1.23457e-20 | -10 (3 rows) SELECT '' AS three, f.f1, f.f1 / '-10' AS x FROM FLOAT4_TBL f WHERE f.f1 > '0.0'; three | f1 | x -------+-------------+-------------- | 1004.3 | -100.43 | 1.23457e+20 | -1.23457e+19 | 1.23457e-20 | -1.23457e-21 (3 rows) SELECT '' AS three, f.f1, f.f1 - '-10' AS x FROM FLOAT4_TBL f WHERE f.f1 > '0.0'; three | f1 | x -------+-------------+------------- | 1004.3 | 1014.3 | 1.23457e+20 | 1.23457e+20 | 1.23457e-20 | 10 (3 rows) -- test divide by zero SELECT '' AS bad, f.f1 / '0.0' from FLOAT4_TBL f; ERROR: division by zero SELECT '' AS five, * FROM FLOAT4_TBL; five | f1 ------+------------- | 0 | 1004.3 | -34.84 | 1.23457e+20 | 1.23457e-20 (5 rows) -- test the unary float4abs operator SELECT '' AS five, f.f1, @f.f1 AS abs_f1 FROM FLOAT4_TBL f; five | f1 | abs_f1 ------+-------------+------------- | 0 | 0 | 1004.3 | 1004.3 | -34.84 | 34.84 | 1.23457e+20 | 1.23457e+20 | 1.23457e-20 | 1.23457e-20 (5 rows) UPDATE FLOAT4_TBL SET f1 = FLOAT4_TBL.f1 * '-1' WHERE FLOAT4_TBL.f1 > '0.0'; SELECT '' AS five, * FROM FLOAT4_TBL; five | f1 ------+-------------- | 0 | -1004.3 | -34.84 | -1.23457e+20 | -1.23457e-20 (5 rows) DROP FOREIGN TABLE FLOAT4_TBL; DROP SERVER sqlite_svr; DROP EXTENSION sqlite_fdw CASCADE;