Zielony Smok - logo witryny

JdbcRowSet należy do podłączonych zbiorów rzędów (connected rowsets). To oznacza, że cały czas musi być połączony z baza danych. Dlatego też jedynym źródłem danych dla JdbcRowSet może być baza danych. Zbiór rzędów (rowset) jest zawsze dwukierunkowo przewijalny (bidirectional scrollable) i zawsze aktualizowalny (updatable) nawet jeżeli ResultSet, po którym dziedziczy, takich możliwości nie ma.
Wszystkie poniższe klasy są opisane w treści klasy.

Wybieranie danych SELECT

Klasa R130A_SELECT.java
package aderby.jdbcs.rowsets.b_jdbcrowset;

import javax.sql.rowset.JdbcRowSet;
import javax.sql.rowset.RowSetFactory;
import javax.sql.rowset.RowSetProvider;
import java.sql.SQLException;

public class R130A_SELECT {
    private static final String url = "jdbc:derby:C:/Przyklady/frazy2_db";
    private static final String user = "jacek";
    private static final String password = "placek";
    private static final String sqlQuery = "SELECT * FROM frazy WHERE frazaID<?";

    public static void main(String[] args) {
        try {
            //uruchomienie fabryki
            RowSetFactory factory = RowSetProvider.newFactory();
            //utworzenie pustego zbioru rzędów w konstrukcji try-with-resources
            try (JdbcRowSet jdbcRs = factory.createJdbcRowSet()) {
                //ustawienie parametrów połączenia
                jdbcRs.setUrl(url);
                jdbcRs.setUsername(user);
                jdbcRs.setPassword(password);
                //wstawienie zapytania
                jdbcRs.setCommand(sqlQuery);
                //ustawienie parametru zapytania, wyszukamy wpisy z frazaID < 21
                jdbcRs.setInt(1, 21);
                //Uruchomienie zapytania
                jdbcRs.execute();
                //wydruk zapytania
                while (jdbcRs.next()) {
                    int id = jdbcRs.getInt("frazaID");
                    String esp = jdbcRs.getString("esp");
                    String pol = jdbcRs.getString("pol");
                    System.out.println("Nr: " + id);
                    System.out.println("ES: " + esp);
                    System.out.println("PL: " + pol);
                    System.out.println();
                }
            }
            //Po wyjściu z try-with-resources JdbcRowset implementujący AutoCloseable zostaje
            //automatycznie zamknięty
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
}

Po uruchomieniu klasy na konsoli zobaczymy:

Nr: 1
ES: (ir) por partes
PL: powoli, systematycznie (coś robić), po kolei

Nr: 2
ES: (ya) está bien de ...
PL: już wystarczy ...

Nr: 3
ES: A Dios disgusta de los muertos maldecir, a los maldecidores en vida los hace punir.
PL: O umarłych albo dobrze, albo wcale nie mówić.

Nr: 4
ES: A buen entendedor, breve hablador.
PL: Mądrej głowie dość dwie słowie.

Nr: 5
ES: A buen hambre no hay pan duro.
PL: Na dobry głód żaden chleb nie twardy.

Nr: 6
ES: A buena hambre no hay falta salsa.
PL: Głód najlepszą przyprawą.

Nr: 7
ES: A buey viejo no le cates abrigo.
PL: Nie ucz drwala rąbać drwa.

Nr: 8
ES: A caballo regalado, no hay que mirarle el diente.
PL: Darowanemu koniowi nie zagląda się w zęby.

Nr: 9
ES: A cada pajarillo le gusta su nidillo.
PL: Każdemu ptakowi swoje gniazdko miłe.

Nr: 10
ES: A cada puerco le llega su San Martín.
PL: Przyszła kryska na Matyska.

Nr: 11
ES: A días claros, oscuros nublados.
PL: Kto się rano śmieje, wieczorem płacze.

Nr: 12
ES: A gran prisa, gran vagar.
PL: Śpiesz się powoli.

Nr: 13
ES: A gran subida, gran caída.
PL: Kto wysoko lata, ten nisko upada. Kto wysoko lata, ten z wysoka spada.

Nr: 14
ES: A la mala hilandera, la rueca le hace dentera.
PL: Kiepskiej tanecznicy, to i rąbek u spódnicy przeszkadza.

Nr: 15
ES: A la ocasión la pintan en calva.
PL: Nie zasypiać gruszek w popiele.

Nr: 16
ES: A las tres va la vencida.
PL: Do trzech razy sztuka.

Nr: 17
ES: A los bobos se les aparece la Madre de Dios.
PL: Głupim szczęście sprzyja.

Nr: 18
ES: A mal tiempo, buena cara.
PL: Robić dobrą minę do złej gry.

Nr: 19
ES: A menos bultos, más claridad.
PL: Baba z wozu, koniom lżej.

Nr: 20
ES: A perro flaco todo son pulgas.
PL: Biednemu zawsze wiatr w oczy.

Dodawanie rzędu INSERT

<

Klasa R130B_INSERT.java
package aderby.jdbcs.rowsets.b_jdbcrowset;

import javax.sql.rowset.JdbcRowSet;
import javax.sql.rowset.RowSetFactory;
import javax.sql.rowset.RowSetProvider;
import java.sql.SQLException;

public class R130B_INSERT {
    private static final String url = "jdbc:derby:C:/Przyklady/frazy2_db";
    private static final String user = "jacek";
    private static final String password = "placek";
    private static final String sqlQuery = "SELECT * FROM frazy";

    public static void main(String[] args) {
        try {
            //uruchomienie fabryki
            RowSetFactory factory = RowSetProvider.newFactory();
            //utworzenie pustego zbioru rzedów
            try (JdbcRowSet jdbcRs = factory.createJdbcRowSet()) {
                //ustawienie parametrów połączenia
                jdbcRs.setUrl(url);
                jdbcRs.setUsername(user);
                jdbcRs.setPassword(password);
                //wstawienie zapytania
                jdbcRs.setCommand(sqlQuery);
                //Uruchomienie zapytanie
                jdbcRs.execute();
                //przejście do ostatniego rzędu
                jdbcRs.moveToInsertRow();
                //Wpisanie wartości
                jdbcRs.updateString("esp", "Matar la gallina de los huevos de oro.");
                jdbcRs.updateString("pol", "Zarżnąć kurę, która złote jaja znosi.");
                //wstawienie rzędu
                jdbcRs.insertRow();
                //Przejście z powrotem do bieżącego rzędu
                jdbcRs.moveToCurrentRow();
            }
            //Po wyjściu z try-with-resources JdbcRowset implementujący AutoCloseable zostaje
            //automatycznie zamknięty
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
}

Po uruchomieniu klasy dodany został jeden rekord. Rekordy są ułożone alfabetycznie.

Aktualizacja rzędu UPDATE

Klasa R130C_UPDATE.java
package aderby.jdbcs.rowsets.b_jdbcrowset;

import javax.sql.rowset.JdbcRowSet;
import javax.sql.rowset.RowSetFactory;
import javax.sql.rowset.RowSetProvider;
import java.sql.SQLException;

public class R130C_UPDATE {
    private static final String url = "jdbc:derby:C:/Przyklady/frazy2_db";
    private static final String user = "jacek";
    private static final String password = "placek";
    private static final String sqlQuery = "SELECT * FROM frazy";

    public static void main(String[] args) {
        try {
            //uruchomienie fabryki
            RowSetFactory factory = RowSetProvider.newFactory();
            //utworzenie pustego zbioru rzedów
            try (JdbcRowSet jdbcRs = factory.createJdbcRowSet()) {
                //ustawienie parametrów połączenia
                jdbcRs.setUrl(url);
                jdbcRs.setUsername(user);
                jdbcRs.setPassword(password);
                //wstawienie zapytania
                jdbcRs.setCommand(sqlQuery);
                //Uruchomienie zapytanie
                jdbcRs.execute();
                //przejście do 6 rzędu
                jdbcRs.absolute(6);
                //Wpisanie wartości
                jdbcRs.updateString("pol", "Głód najlepszą przyprawą. Dosł. Prawdziwie głodnemu nie brakuje sosu.");
                //aktualizacja rzędu
                jdbcRs.updateRow();
                //Przejście z powrotem do bieżącego rzędu
                jdbcRs.moveToCurrentRow();
            }
            //Po wyjściu z try-with-resources JdbcRowset implementujący AutoCloseable zostaje
            //automatycznie zamknięty
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
}

Po uruchomieniu klasy dane w kolumnie ‘pol’ rekordu nr 6 zostaną zaktualizowane (poprawione).

Usuwanie rzędu DELETE

Klasa R130D_DELETE
package aderby.jdbcs.rowsets.b_jdbcrowset;

import javax.sql.rowset.JdbcRowSet;
import javax.sql.rowset.RowSetFactory;
import javax.sql.rowset.RowSetProvider;
import java.sql.SQLException;

public class R130D_DELETE {
    private static final String url = "jdbc:derby:C:/Przyklady/frazy2_db";
    private static final String user = "jacek";
    private static final String password = "placek";
    private static final String sqlQuery = "SELECT * FROM frazy";

    public static void main(String[] args) {
        try {
            //uruchomienie fabryki
            RowSetFactory factory = RowSetProvider.newFactory();
            //utworzenie pustego zbioru rzedów
            try (JdbcRowSet jdbcRs = factory.createJdbcRowSet()) {
                //ustawienie parametrów połączenia
                jdbcRs.setUrl(url);
                jdbcRs.setUsername(user);
                jdbcRs.setPassword(password);
                //wstawienie zapytania
                jdbcRs.setCommand(sqlQuery);
                //Uruchomienie zapytanie
                jdbcRs.execute();
                //przejście do ostatniego rzędu
                jdbcRs.last();
                //wydruk zapytania
                int id = jdbcRs.getInt("frazaID");
                String esp = jdbcRs.getString("esp");
                String pol = jdbcRs.getString("pol");
                System.out.println("Nr: " + id);
                System.out.println("ES: " + esp);
                System.out.println("PL: " + pol);
                System.out.println();
                //aktualizacja rzędu
                jdbcRs.deleteRow();
                //Przejście z powrotem do bieżącego rzędu
                jdbcRs.moveToCurrentRow();
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
}

Po uruchomieniu klasy na konsoli zobaczymy rekord, który został usunięty z bazy danych. Jest to ostatni rekord.

Nr: 1232
ES: Matar la gallina de los huevos de oro.
PL: Zarżnąć kurę, która złote jaja znosi.