Apache Derby: funkcja DOUBLE
Opis
Funkcja rzutująca i parsująca. Zwraca wartość typu DOUBLE dla liczby podanej jako łańcuch znaków lub liczby będącej innego typu numerycznego.
Składnia
DOUBLE(wartość)
Ograniczenia
Podany łańcuch znaków po zignorowaniu ewentualnych białych znaków z początku i końca łańcucha musi być poprawną liczbą DOUBLE
Podanie liczby innego typu ma skutek taki sam jak próba wpisania tej liczby do kolumny typu DOUBLE
(zobacz opis typu)
Klasa R078_DOUBLE.java
package aderby.functions.cast; import aderby.DerbyUtil; import java.io.*; import java.sql.*; public class R078_DOUBLE { private static final String baza = "C:/Przyklady/r078_double"; private static final String skrypt = "aderby/src/resources/sqls/mathdata4.sql"; private static final String selectsql = "SELECT val, DOUBLE(val) FROM mathdata"; public static void main(String[] args) { DerbyUtil.startDerbyEngine(DerbyUtil.embdriver); Connection con = DerbyUtil.connectEmbeddedDB(baza, ";create=true"); DerbyUtil.jdbcRunScript(skrypt, con); Statement stat = null; ResultSet rs = null; try { stat = con.createStatement(); rs = stat.executeQuery(selectsql); while (rs.next()) { System.out.println(rs.getString(1) + " " + rs.getDouble(2)); } } catch (SQLException e) { e.printStackTrace(); } DerbyUtil.close(stat); DerbyUtil.close(con); DerbyUtil.close(rs); DerbyUtil.shutdownEmbeddedDB(baza); DerbyUtil.shutdownDerbyEngine(); DerbyUtil.dropDatabase(new File(baza)); } }
Plik mathdata4.sql
CREATE TABLE mathdata(
id INTEGER NOT NULL PRIMARY KEY GENERATED ALWAYS AS
IDENTITY(START WITH 1, INCREMENT BY 1),
val VARCHAR(20)
);
CREATE INDEX i_val ON mathdata (val ASC);
INSERT INTO mathdata (id, val) VALUES (DEFAULT, ’1.234′);
INSERT INTO mathdata (id, val) VALUES (DEFAULT, ’23.45′);
INSERT INTO mathdata (id, val) VALUES (DEFAULT, ’345.6′);
INSERT INTO mathdata (id, val) VALUES (DEFAULT, ’4567.0′);
Wynik
1.234 1.234 23.45 23.45 345.6 345.6 4567.0 4567.0
Pliki do ściągnięcia
Aktualny (tworzony narastająco) plik module-info.java
Aktualny (tworzony narastająco) plik DerbyUtil.java
Pliki tworzone narastająco zastępują poprzednie pliki o tej samej nazwie i działają dla wszystkich wcześniej opublikowanych przykładów we wszystkich wpisach w projekcie. W przypadku pliku module-info.java
może być potrzebne skreślenie niepotrzebnych wpisów.