JDBC - typy danych

Sterownik JDBC konwertuje typ danych Java na odpowiedni typ JDBC przed wysłaniem go do bazy danych. Używa domyślnego mapowania dla większości typów danych. Na przykład int Java jest konwertowana na SQL INTEGER. Utworzono domyślne mapowania, aby zapewnić spójność między sterownikami.

Poniższa tabela zawiera podsumowanie domyślnego typu danych JDBC, na który konwertowany jest typ danych Java po wywołaniu metody setXXX () obiektu PreparedStatement lub CallableStatement albo metody ResultSet.updateXXX ().

SQL JDBC / Java setXXX updateXXX
VARCHAR java.lang.String setString updateString
ZWĘGLAĆ java.lang.String setString updateString
LONGVARCHAR java.lang.String setString updateString
KAWAŁEK boolean setBoolean updateBoolean
NUMERYCZNE java.math.BigDecimal setBigDecimal updateBigDecimal
TINYINT bajt setByte updateByte
SMALLINT krótki setShort updateShort
LICZBA CAŁKOWITA int setInt updateInt
BIGINT długo setLong updateLong
REAL pływak setFloat updateFloat
PŁYWAK pływak setFloat updateFloat
PODWÓJNIE podwójnie setDouble updateDouble
VARBINARY bajt [] setBytes updateBytes
DWÓJKOWY bajt [] setBytes updateBytes
DATA java.sql.Date ustawić datę updateDate
CZAS java.sql.Time setTime czas aktualizacji
ZNAK CZASU java.sql.Timestamp setTimestamp updateTimestamp
CLOB java.sql.Clob setClob updateClob
KROPELKA java.sql.Blob setBlob updateBlob
SZYK java.sql.Array setARRAY updateARRAY
REF java.sql.Ref SetRef updateRef
STRUKTURA java.sql.Struct SetStruct updateStruct

JDBC 3.0 ma ulepszoną obsługę typów danych BLOB, CLOB, ARRAY i REF. Obiekt ResultSet ma teraz metody updateBLOB (), updateCLOB (), updateArray () i updateRef (), które umożliwiają bezpośrednie manipulowanie odpowiednimi danymi na serwerze.

Metody setXXX () i updateXXX () umożliwiają konwersję określonych typów Java do określonych typów danych JDBC. Metody setObject () i updateObject () umożliwiają odwzorowanie prawie każdego typu Java na typ danych JDBC.

Obiekt ResultSet udostępnia odpowiednią metodę getXXX () dla każdego typu danych w celu pobrania wartości kolumny. Każda metoda może być używana z nazwą kolumny lub jej pozycją porządkową.

SQL JDBC / Java setXXX getXXX
VARCHAR java.lang.String setString getString
ZWĘGLAĆ java.lang.String setString getString
LONGVARCHAR java.lang.String setString getString
KAWAŁEK boolean setBoolean getBoolean
NUMERYCZNE java.math.BigDecimal setBigDecimal getBigDecimal
TINYINT bajt setByte getByte
SMALLINT krótki setShort getShort
LICZBA CAŁKOWITA int setInt getInt
BIGINT długo setLong getLong
REAL pływak setFloat getFloat
PŁYWAK pływak setFloat getFloat
PODWÓJNIE podwójnie setDouble getDouble
VARBINARY bajt [] setBytes getBytes
DWÓJKOWY bajt [] setBytes getBytes
DATA java.sql.Date ustawić datę getDate
CZAS java.sql.Time setTime uzyskać czas
ZNAK CZASU java.sql.Timestamp setTimestamp getTimestamp
CLOB java.sql.Clob setClob getClob
KROPELKA java.sql.Blob setBlob getBlob
SZYK java.sql.Array setARRAY getARRAY
REF java.sql.Ref SetRef getRef
STRUKTURA java.sql.Struct SetStruct getStruct

Typy danych daty i godziny

Klasa java.sql.Date jest odwzorowywana na typ SQL DATE, a klasy java.sql.Time i java.sql.Timestamp odwzorowują odpowiednio typy danych SQL TIME i SQL TIMESTAMP.

Poniższy przykład pokazuje, jak klasy Data i godzina formatują standardowe wartości daty i godziny języka Java, aby były zgodne z wymaganiami dotyczącymi typu danych SQL.

import java.sql.Date;
import java.sql.Time;
import java.sql.Timestamp;
import java.util.*;

public class SqlDateTime {
   public static void main(String[] args) {
      //Get standard date and time
      java.util.Date javaDate = new java.util.Date();
      long javaTime = javaDate.getTime();
      System.out.println("The Java Date is:" + 
             javaDate.toString());

      //Get and display SQL DATE
      java.sql.Date sqlDate = new java.sql.Date(javaTime);
      System.out.println("The SQL DATE is: " + 
             sqlDate.toString());

      //Get and display SQL TIME
      java.sql.Time sqlTime = new java.sql.Time(javaTime);
      System.out.println("The SQL TIME is: " + 
             sqlTime.toString());
      //Get and display SQL TIMESTAMP
      java.sql.Timestamp sqlTimestamp =
      new java.sql.Timestamp(javaTime);
      System.out.println("The SQL TIMESTAMP is: " + 
             sqlTimestamp.toString());
     }//end main
}//end SqlDateTime

Teraz skompilujmy powyższy przykład w następujący sposób -

C:\>javac SqlDateTime.java
C:\>

Kiedy biegasz JDBCExample, daje następujący wynik -

C:\>java SqlDateTime
The Java Date is:Tue Aug 18 13:46:02 GMT+04:00 2009
The SQL DATE is: 2009-08-18
The SQL TIME is: 13:46:02
The SQL TIMESTAMP is: 2009-08-18 13:46:02.828
C:\>

Obsługa wartości NULL

Używanie wartości NULL w języku SQL i używanie w języku Java wartości null to różne koncepcje. Tak więc, aby obsłużyć wartości NULL SQL w Javie, możesz użyć trzech taktyk -

  • Unikaj używania metod getXXX (), które zwracają pierwotne typy danych.

  • Użyj klas opakowania dla prymitywnych typów danych i użyj metody wasNull () obiektu ResultSet, aby sprawdzić, czy zmienna klasy opakowania, która otrzymała wartość zwróconą przez metodę getXXX (), powinna mieć wartość null.

  • Użyj pierwotnych typów danych i metody wasNull () obiektu ResultSet, aby sprawdzić, czy zmienna pierwotna, która otrzymała wartość zwróconą przez metodę getXXX (), powinna być ustawiona na akceptowalną wartość, która została wybrana do reprezentowania wartości NULL.

Oto jeden przykład obsługi wartości NULL -

Statement stmt = conn.createStatement( );
String sql = "SELECT id, first, last, age FROM Employees";
ResultSet rs = stmt.executeQuery(sql);

int id = rs.getInt(1);
if( rs.wasNull( ) ) {
   id = 0;
}