Apache Derby - Perbarui Data

Pernyataan UPDATE digunakan untuk memperbarui data dalam tabel. Apache Derby menyediakan dua jenis pembaruan (sintaks) yaitusearched memperbarui dan positioned memperbarui.

Pernyataan UPDATE yang dicari memperbarui semua kolom tertentu dari sebuah tabel.

Sintaksis

Berikut ini adalah sintaks dari kueri UPDATE -

ij> UPDATE table_name
 SET column_name = value, column_name = value, ...
 WHERE conditions;

Klausa WHERE dapat menggunakan operator perbandingan seperti =,! =, <,>, <=, Dan> =, serta operator ANTARA dan LIKE.

Contoh

Misalkan Anda memiliki tabel Employee di database dengan 4 record seperti di bawah ini -

ID |NAME |SALARY |LOCATION
----------------------------------------------------------
1 |Amit |30000 |Hyderabad
2 |Kalyan |40000 |Vishakhapatnam
3 |Renuka |50000 |Delhi
4 |Archana |15000 |Mumbai

Pernyataan SQL UPDATE berikut memperbarui lokasi dan gaji karyawan yang bernama Kaylan.

ij> UPDATE Employees SET Location = 'Chennai', Salary = 43000 WHERE Name =
'Kalyan';
1 rows inserted/updated/deleted

Jika Anda mendapatkan konten tabel karyawan, Anda bisa mengamati perubahan yang dilakukan oleh kueri UPDATE.

ij> select * from Employees;
ID |NAME |SALARY |LOCATION
----------------------------------------------------------
1 |Amit |30000 |Hyderabad 
2 |Kalyan |43000 |Chennai
3 |Renuka |50000 |Delhi
4 |Archana |15000 |Mumbai
4 rows selected

Perbarui Data menggunakan program JDBC

Bagian ini menjelaskan cara memperbarui record tabel yang ada di database Apache Derby menggunakan aplikasi JDBC.

Jika Anda ingin meminta server jaringan Derby menggunakan klien jaringan, pastikan bahwa server aktif dan berjalan. Nama kelas untuk driver klien Jaringan adalah org.apache.derby.jdbc.ClientDriver dan URL-nya adalah jdbc: derby: // localhost: 1527 /DATABASE_NAME; buat = true; pengguna =USER_NAME; passw ord =PASSWORD"

Ikuti langkah-langkah yang diberikan di bawah ini untuk memperbarui catatan tabel yang ada di Apache Derby.

Langkah 1: Daftarkan driver

Untuk berkomunikasi dengan database, pertama-tama, Anda perlu mendaftarkan driver. ItuforName() metode kelas Classmenerima nilai String yang mewakili nama kelas memuatnya ke memori, yang secara otomatis mendaftarkannya. Daftarkan driver menggunakan metode ini.

Langkah 2: Dapatkan koneksi

Secara umum, langkah pertama yang kita lakukan untuk berkomunikasi dengan database adalah menghubungkannya. Kelas koneksi mewakili koneksi fisik dengan server database. Anda dapat membuat objek koneksi dengan menjalankangetConnection() metode dari DriverManagerkelas. Buat koneksi menggunakan metode ini.

Langkah 3: Buat objek pernyataan

Anda perlu membuat file Statement atau PreparedStatement or, CallableStatementobjek untuk mengirim pernyataan SQL ke database. Anda dapat membuatnya menggunakan metodecreateStatement(), prepareStatement() dan, prepareCall()masing-masing. Buat salah satu dari objek ini menggunakan metode yang sesuai.

Langkah 4: Jalankan kueri

Setelah membuat pernyataan, Anda perlu menjalankannya. ItuStatement kelas menyediakan berbagai metode untuk mengeksekusi kueri seperti execute()metode untuk mengeksekusi pernyataan yang mengembalikan lebih dari satu kumpulan hasil. ItuexecuteUpdate()metode mengeksekusi query seperti INSERT, UPDATE, DELETE. ItuexecuteQuery()metode mengembalikan data. Gunakan salah satu dari metode ini dan jalankan pernyataan yang dibuat sebelumnya.

Contoh

Contoh JDBC berikut menunjukkan cara memperbarui catatan tabel yang ada di Apache Derby menggunakan program JDBC. Di sini, kami menghubungkan ke database bernama sampleDB (akan dibuat jika tidak ada) menggunakan driver tertanam.

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
public class UpdateData {
   public static void main(String args[]) throws Exception {
      //Registering the driver
      Class.forName("org.apache.derby.jdbc.EmbeddedDriver");
      //Getting the Connection object
      String URL = "jdbc:derby:sampleDB;create=true";
      Connection conn = DriverManager.getConnection(URL);

      //Creating the Statement object
      Statement stmt = conn.createStatement();

      //Creating a table and populating it
      String query = "CREATE TABLE Employees("
         + "Id INT NOT NULL GENERATED ALWAYS AS IDENTITY, "
         + "Name VARCHAR(255), Salary INT NOT NULL, "
         + "Location VARCHAR(255), "
         + "PRIMARY KEY (Id))";
      String query = "INSERT INTO Employees("
         + "Name, Salary, Location) VALUES "
         + "('Amit', 30000, 'Hyderabad'), "
         + "('Kalyan', 40000, 'Vishakhapatnam'), "
         + "('Renuka', 50000, 'Delhi'), "
         + "('Archana', 15000, 'Mumbai'), "
         + "('Trupthi', 45000, 'Kochin'), "
         + "('Suchatra', 33000, 'Pune'), "
         + "('Rahul', 39000, 'Lucknow'), "
         + "('Trupti', 45000, 'Kochin')";
      //Executing the query
      String query = "UPDATE Employees SET Location = 'Chennai', Salary = 43000 WHERE
         Name = 'Kalyan'";
      int num = stmt.executeUpdate(query);
      System.out.println("Number of records updated are: "+num);
   }
}

Keluaran

Saat menjalankan program di atas, Anda akan mendapatkan output berikut -

Number of records updated are: 1