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;
	}
}



Class.forName() 을 static 으로 감싸준 이유는 클래스를 만들때 마다가 아닌, 단 한번만 load 해 주기 위해서 입니다.


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;
	}



sqlite 는 read 인 경우에는 transaction 이 걸리지 않는다고 되어 있습니다.
즉, 읽기만 할 경우라면 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 를 이용하기 때문에 크게 어려울게 없으실 겁니다.
간략히 이쯤에서 마치도록 하겠습니다.



신고