Apache Derby: funkcja LOCATE
Opis
Wyszukuje łańcuch znaków w obrębie łańcucha znaków.
Składnia
LOCATE(val1, val2 [, val3])
Ograniczenia
- ‘val1’ to łańcuch znaków do wyszukania
- ‘val2’ to łańcuch znaków, w którym wyszukiwana jest ‘val1’
- ‘val3’ – opcjonalna – pozycja w ‘val2’ od której należy zacząć wyszukiwanie. Jeśli nie jest podana wyszukiwanie zaczyna się od 1, czyli od początku
- Funkcja zwraca 0 – jeśli ‘val1’ nie została zlokalizowana, lub pozycję pierwszego wystąpienia ‘val1’ w ‘val2’
- Jeśli ‘val1’ jest pustym łańcuchem znaków “” zwraca wartość ‘val3’ jeśli została podana albo 1 jeśli ‘val3’ nie została podana
- Jeśli ‘val1’ lub ‘val2’ jest NULL – wynik jest NULL
Przykład w klasie R079_LOCATE:
package aderby.functions.strings; import aderby.DerbyUtil; import java.io.*; import java.sql.*; public class R079_LOCATE { private static final String baza = "C:/Przyklady/r079_locate"; private static final String skrypt = "aderby/src/resources/sqls/daty.sql"; static final String selectsql1 = "SELECT data, zdarzenie, LOCATE('y', zdarzenie) FROM daty"; 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(selectsql1); while (rs.next()) { System.out.println(rs.getDate(1) + " '" + rs.getString(2) + "'" + rs.getInt(3)); } } 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 daty.sql
CREATE TABLE daty( id INTEGER NOT NULL PRIMARY KEY GENERATED ALWAYS AS IDENTITY( START WITH 1, INCREMENT BY 1), data DATE, zdarzenie VARCHAR(64) ); CREATE INDEX i_data ON daty (data ASC); INSERT INTO daty VALUES (DEFAULT, '1952-6-4', 'Urodziny'); INSERT INTO daty VALUES (DEFAULT, '6/4/1968', 'Ukończenie szkoły podstawowej'); INSERT INTO daty VALUES (DEFAULT, '26.6.1972', 'Ukończenie liceum'); INSERT INTO daty VALUES (DEFAULT, '1977-6-25', 'dyplom magistra biologii');
Wynik
1952-06-04 'Urodziny'8 1968-06-04 'Ukończenie szkoły podstawowej'17 1972-06-26 'Ukończenie liceum'0 1977-06-25 'dyplom magistra biologii'2
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.