NodeJS 에서 sqlite 3 로 파일 형태 데이터베이스 사용 방법 - Whitmem
NodeJS 에서 sqlite 3 로 파일 형태 데이터베이스 사용 방법
NodeJS 개발
2025-06-25 21:57 게시 2a13b7a391738e38e658

0
0
3
이 페이지는 외부 공간에 무단 복제할 수 없으며 오직 있는 그대로 게시되며 부정확한 내용을 포함할 수 있습니다. 법률이 허용하는 한 가이드 라인에 맞춰 게시 내용을 인용하거나 출처로 표기할 수 있습니다.
This page is not to be distributed to external services; it is provided as is and may contain inaccuracies.
Sqlite3 는 파일 형태로 관리할 수 있는 초소형 데이터 베이스 서비스로 Public Domain 으로 배포된다.
Public Domain 은 누구나 사용할 수 있고 제약이 없는 라이선스로, https://sqlite.org/copyright.html 를 참고하면 된다. 다만 인사/재산권 팀에서 라이선스 등을 요구하는 기업등을 위해서 증서 형태의 SQLite 라이선스를 판매하고 있다고 한다.
아무튼 NodeJS 에서 sqlite3 를 설치하기 위해서 다음 명령어면 충분하다.
npm install sqlite3
이렇게 sqlite3를 설치했으면 본격적으로 사용할 준비가 완료되었다.
우선 필자는 Module 형태로 임포트를 할 것이기 때문에 NodeJS 의 프로젝트를 module 형태로 지정한다.
NodeJS 내 package.json 파일의 type 을 변경해주면 된다.
기본 파일 정의 방법
import sqlite3 from "sqlite3"; const Database = sqlite3.Database; const database = new Database("./test.db", (error)=>{ if(error) console.log("[Err] " + error); } );
위 코드로 기본적인 데이터 베이스 파일을 생성할 수 있다. 해당 경로에 파일 생성에 실패하면 오류 메시지를 같이 띄운다.
기본적으로 위 테스트 데이터 베이스가 생성된 것을 확인할 수 있다.
사용법은 어렵지 않다. 위 처럼 생성된 database 변수를 통해 prepare 및 statement 질의를 수행할 수 있다.
위 statement 에 테이블을 생성하는 명령 질의문을 넣고, statement를 생성한다. 그리고 해당 statement 를 run 하여 질의를 수행하면 된다.
외부 도구 사용
특히 이렇게 생성된 데이터 베이스 파일은 외부 도구를 사용해서 열 수 있는데 여기서는 HeidiSQL 라는 소프트웨어를 사용해서 열어본다.
세션 관리자를 열고, 네트워크 유형을 SQLite 로 선택후, 데이터 베이스 파일명에 파일 경로를 입력하면 된다.
그렇게 연결을 하면 서버에 연결된 것 처럼 데이터 베이스 파일이 열리는 것을 확인할 수 있다. 기본 질의로 생성한 테이블이 존재하는 것을 확인할 수 있다.
데이터 삽입
const statement2 = database.prepare(` INSERT INTO test(test) values( ?); `); statement2.run("test",(error)=>{ if(error) console.log(error); });
prepare에 INSERT 구문을 넣어 데이터를 삽입할 수 있다. 다만 어떤 파라메터 형식으로 데이터를 삽입하거나 관리해야 하는 경우에는 ? 로 인자를 대신하여 run 시 같이 넘길 수 있다.
제대로 삽입된 것을 확인할 수 있다. Delete 도 마찬가지로 prepare 문으로 사용하면 된다.
SELECT 방법
const statement2 = database.prepare(` SELECT * from test `); statement2.all((error, rows)=>{ if(!error){ console.log(rows); } });
all 구문을 사용하면 된다. all 구문은 실행 결과를 콜백으로 rows도 같이 넘겨준다.
즉 오류가 없을 땐 rows를 출력하면 아래와 같이 출력된다.
즉 한 행씩 가져오려면 forEach를 사용하면 된다.
rows.forEach((row)=>{console.log(row)});
댓글 0개
댓글을 작성하는 경우 댓글 처리 방침에 동의하는 것으로 간주됩니다. 댓글을 작성하면 일회용 인증키가 발급되며, 해당 키를 분실하는 경우 댓글을 제거할 수 없습니다. 댓글을 작성하면 사용자 IP가 영구적으로 기록 및 부분 공개됩니다.
확인
Whitmemit 개인 일지 블로그는 개인이 운영하는 정보 공유 공간으로 사용자의 민감한 개인 정보를 직접 요구하거나 요청하지 않습니다. 기본적인 사이트 방문시 처리되는 처리 정보에 대해서는 '사이트 처리 방침'을 참고하십시오. 추가적인 기능의 제공을 위하여 쿠키 정보를 사용하고 있습니다. Whitmemit 에서 처리하는 정보는 식별 용도로 사용되며 기타 글꼴 및 폰트 라이브러리에서 쿠키 정보를 사용할 수 있습니다.
이 자료는 모두 필수 자료로 간주되며, 사이트 이용을 하거나, 탐색하는 경우 동의로 간주합니다.