JDBC-데이터 유형
JDBC 드라이버는 데이터베이스로 보내기 전에 Java 데이터 유형을 적절한 JDBC 유형으로 변환합니다. 대부분의 데이터 유형에 대해 기본 매핑을 사용합니다. 예를 들어, Java int는 SQL INTEGER로 변환됩니다. 드라이버 간의 일관성을 제공하기 위해 기본 매핑이 만들어졌습니다.
다음 표는 PreparedStatement 또는 CallableStatement 오브젝트의 setXXX () 메소드 또는 ResultSet.updateXXX () 메소드를 호출 할 때 Java 데이터 유형이 변환되는 기본 JDBC 데이터 유형을 요약합니다.
SQL | JDBC / 자바 | setXXX | updateXXX |
---|---|---|---|
VARCHAR | java.lang.String | setString | updateString |
숯 | java.lang.String | setString | updateString |
LONGVARCHAR | java.lang.String | setString | updateString |
비트 | 부울 | setBoolean | updateBoolean |
숫자 | java.math.BigDecimal | setBigDecimal | updateBigDecimal |
TINYINT | 바이트 | setByte | updateByte |
SMALLINT | 짧은 | setShort | updateShort |
정수 | int | setInt | updateInt |
BIGINT | 긴 | setLong | updateLong |
레알 | 흙손 | setFloat | updateFloat |
흙손 | 흙손 | setFloat | updateFloat |
더블 | 더블 | setDouble | updateDouble |
VARBINARY | 바이트 [] | setBytes | updateBytes |
바이너리 | 바이트 [] | setBytes | updateBytes |
데이트 | java.sql.Date | setDate | 업데이트 날짜 |
시각 | java.sql.Time | setTime | updateTime |
타임 스탬프 | java.sql.Timestamp | setTimestamp | updateTimestamp |
CLOB | java.sql.Clob | setClob | updateClob |
얼룩 | java.sql.Blob | setBlob | updateBlob |
정렬 | java.sql.Array | setARRAY | updateARRAY |
REF | java.sql.Ref | SetRef | updateRef |
구조 | java.sql.Struct | SetStruct | updateStruct |
JDBC 3.0은 BLOB, CLOB, ARRAY 및 REF 데이터 유형에 대한 지원을 강화했습니다. 이제 ResultSet 객체에는 서버의 각 데이터를 직접 조작 할 수있는 updateBLOB (), updateCLOB (), updateArray () 및 updateRef () 메서드가 있습니다.
setXXX () 및 updateXXX () 메소드를 사용하면 특정 Java 유형을 특정 JDBC 데이터 유형으로 변환 할 수 있습니다. setObject () 및 updateObject () 메소드를 사용하면 거의 모든 Java 유형을 JDBC 데이터 유형에 매핑 할 수 있습니다.
ResultSet 오브젝트는 열 값을 검색하기 위해 각 데이터 유형에 해당하는 getXXX () 메소드를 제공합니다. 각 방법은 열 이름 또는 서수 위치와 함께 사용할 수 있습니다.
SQL | JDBC / 자바 | setXXX | getXXX |
---|---|---|---|
VARCHAR | java.lang.String | setString | getString |
숯 | java.lang.String | setString | getString |
LONGVARCHAR | java.lang.String | setString | getString |
비트 | 부울 | setBoolean | getBoolean |
숫자 | java.math.BigDecimal | setBigDecimal | getBigDecimal |
TINYINT | 바이트 | setByte | getByte |
SMALLINT | 짧은 | setShort | getShort |
정수 | int | setInt | getInt |
BIGINT | 긴 | setLong | getLong |
레알 | 흙손 | setFloat | getFloat |
흙손 | 흙손 | setFloat | getFloat |
더블 | 더블 | setDouble | getDouble |
VARBINARY | 바이트 [] | setBytes | getBytes |
바이너리 | 바이트 [] | setBytes | getBytes |
데이트 | java.sql.Date | setDate | getDate |
시각 | java.sql.Time | setTime | getTime |
타임 스탬프 | java.sql.Timestamp | setTimestamp | getTimestamp |
CLOB | java.sql.Clob | setClob | getClob |
얼룩 | java.sql.Blob | setBlob | getBlob |
정렬 | java.sql.Array | setARRAY | getARRAY |
REF | java.sql.Ref | SetRef | getRef |
구조 | java.sql.Struct | SetStruct | getStruct |
날짜 및 시간 데이터 유형
java.sql.Date 클래스는 SQL DATE 유형에 매핑되고 java.sql.Time 및 java.sql.Timestamp 클래스는 각각 SQL TIME 및 SQL TIMESTAMP 데이터 유형에 매핑됩니다.
다음 예제는 날짜 및 시간 클래스가 SQL 데이터 유형 요구 사항과 일치하도록 표준 Java 날짜 및 시간 값을 형식화하는 방법을 보여줍니다.
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
이제 위의 예를 다음과 같이 컴파일 해 보겠습니다.
C:\>javac SqlDateTime.java
C:\>
당신이 달릴 때 JDBCExample, 다음 결과를 생성합니다-
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:\>
NULL 값 처리
SQL의 NULL 값 사용과 Java의 null 사용은 다른 개념입니다. 따라서 Java에서 SQL NULL 값을 처리하기 위해 사용할 수있는 세 가지 전술이 있습니다.
원시 데이터 유형을 리턴하는 getXXX () 메소드를 사용하지 마십시오.
원시 데이터 유형에 랩퍼 클래스를 사용하고 ResultSet 객체의 wasNull () 메소드를 사용하여 getXXX () 메소드가 반환 한 값을 수신 한 랩퍼 클래스 변수가 null로 설정되어야하는지 여부를 테스트합니다.
원시 데이터 유형과 ResultSet 객체의 wasNull () 메서드를 사용하여 getXXX () 메서드에서 반환 된 값을 수신 한 기본 변수가 NULL을 나타내도록 선택한 허용 가능한 값으로 설정되어야하는지 여부를 테스트합니다.
다음은 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;
}