검색결과 리스트
글
Java 에서 SQLite 를 사용하는 방법에 대해서 살펴보도록 하겠습니다.
sqlite 의 JDBC 를 사용하기 위해서는 라이브러리를 다운로드 받아야 합니다.
저의 경우 보시는것 처럼 maven 을 사용하고 있기 때문에 손쉽게 검색해서 추가시켰습니다.
maven 을 쓰고 계시지 않는 소규모 프로젝트인 경우는 직접 다운로드 받아서 라이브러리를 추가시켜 주시면 됩니다.
sqlite-jdbc 는 아래 사이트에서 받으실 수 있습니다.
http://www.xerial.org/trac/Xerial/wiki/SQLiteJDBC#Download
jar 파일 위치 주소는 아래입니다.(현재 최신버젼)
http://www.xerial.org/maven/repository/artifact/org/xerial/sqlite-jdbc/3.5.7/
sqlite-jdbc-3.5.7.jar 만 받으시면 되겠죠?
아시다시피 다운로드 받으신 뒤에, 프로젝트 속성에서 'Add External JARs' 를 통해서 추가시켜 주시면 됩니다.
이제 코드를 살펴 봅시다.
일일이 설명 드릴 필요가 없을 것 같아 코드 단위로 설명 드리겠습니다.
먼저 Import 해야 하는 것들인데, 이클립스 사용자라면 아시다시피.. Ctrl + Shift + O 를 누르면 자동으로 들어갑니다.
하지만 여건상 안되는 분들을 위해서 말씀드리면 아래와 같습니다.
(다만 sqlite 를 쓰는데 불필요한 import 가 있을지도 모릅니다 ㅎ - 그냥 통째로 붙여 넣은거라서...)
import java.io.ByteArrayInputStream;
import java.io.File;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.sqlite.SQLiteConfig;
sqlite-jdbc.jar 를 추가시키고, import 를 하였다고 해서 끝난건 아닙니다.
한가지가 남았습니다. :)
sqlite-jdbc 의 클래스를 동적으로 loading 해 주어야 합니다.
Class.forName() 을 이용하면 되겠네요.
기본적인 클래스의 틀은 아래와 같습니다.
public class DataReader {
private Connection connection;
private String dbFileName;
private boolean isOpened = false;
private final static String QUERY_SELECT_BY_NAME = "SELECT * FROM media WHERE FilePath=?;";
private final static String QUERY_SELECT_BY_NAME_HASHCODE = "SELECT * FROM media WHERE FilePath=? AND CheckSum=?;";
private final static String QUERY_SELECT_THUMBNAIL = "SELECT Thumbnail FROM media WHERE FilePath=?;";
public final static String DATABASE = "crystalcube.db";
static {
try {
Class.forName("org.sqlite.JDBC");
} catch(Exception e) { e.printStackTrace(); }
}
public DataReader(String databaseFileName) {
this.dbFileName = databaseFileName;
}
}
DB 열고 닫기
public boolean open() {
try {
// 읽기 전용
SQLiteConfig config = new SQLiteConfig();
config.setReadOnly(true);
this.connection = DriverManager.getConnection("jdbc:sqlite:/" + this.dbFileName, config.toProperties());
} catch(SQLException e) { e.printStackTrace(); return false; }
isOpened = true;
return true;
}
public boolean close() {
if(this.isOpened == false) { return true; }
try {
this.connection.close();
} catch(SQLException e) { e.printStackTrace(); return false; }
return true;
}
즉, 읽기만 할 경우라면 read 전용으로 설정해 주는것이 좋겠지요.
위에 open() 메소드를 보시면 읽기 전용으로 open 한 것을 보실 수 있습니다.
읽는 방법은 아래와 같습니다.
public boolean readMeta(String filePath, String hashCode, PCloudItem item) throws SQLException {
if(this.isOpened == false) { return false; }
boolean result = false;
String query = "SELECT * FROM media WHERE FilePath=? AND CheckSum=?;";
PreparedStatement prep =
this.connection.prepareStatement(query);
prep.setString(1, filePath);
prep.setString(2, hashCode);
ResultSet row = prep.executeQuery();
if(row.next()) {
row.getString(1); // index 로 가져오기
row.getString("FileSize"); // field 이름으로 가져오기
result = true;
}
row.close();
prep.close();
return result;
}
컬럼명으로 값을 가져올 수도 있고, index 로도 가져올 수 있습니다.
사실 java 는 JDBC 를 이용하기 때문에 크게 어려울게 없으실 겁니다.
간략히 이쯤에서 마치도록 하겠습니다.
'Database > SQLite' 카테고리의 다른 글
SQLite 의 모든 것 (3부) - C++ 에서 사용하기 (1) | 2011.11.30 |
---|---|
SQLite 의 모든 것 (2부) - Download & Build (7) | 2011.11.27 |
SQLite 의 모든 것 (1부) - 소개 및 FAQ (2) | 2011.11.27 |
RECENT COMMENT