[함수] SQLite 와 php 의 연동

2017.04.26 21:07

졸리운_곰 조회 수:58

[함수] SQLite 와 php 의 연동

 

####################################################
### PHP 에서 SQLite DB 사용하기
### 2003/10/28 권기성 : nonots@hanmail.net
####################################################

1. 개요

SQLite 의 특징이라면, 설치및 사용이 간단하다는점
작고 빠르다는 점, SQL92 라는 표준을 따르므로 다른 DBMS 와 유사한
SQL 문을 사용한다는점, 별도의 데몬 프로세스가 떠있지 않다는 점,
PHP 5 부터 적극 지원된다는점,, 등을 들 수 있습니다.

아직 지원되지 않는 기능은 http://sqlite.org/omitted.html 에 있습니다.
이중에서도 Alter table 이 안된다는게 참 불편하군요..

간단하게 제가 사용해본 SQLite 의 사용법을 보여드리겠습니다.


2. SQLite 설치

- 경로 : http://sqlite.org/download.html - 여기 가면 윈도우용, 리눅스용이 있습니다.
- 제경우 리눅스용 sqlite-2.8.6 과 sqlite-devel-2.8.6 RPM 을 다운 받아
설치했습니다.. 환경설정파일 같은 것도 없고. 데몬을 띄우는 것도 필요 없습니다.
그냥 rpm 으로 깔면 끝입니다.
- 아래는 간단한 사용례 입니다.


$ sqlite test_db
SQLite version 2.8.6
Enter ".help" for instructions
sqlite>
쉘에서 이렇게만 하면 현재 디렉토리에 test_db 라는 파일이 하나 만들어집니다.
이 파일(DB)을 php에서 사용하려면 당연히 웹서버가 읽고 쓸수 있는 권한이 있어야
합니다.

sqlite> create table test_tb ( id int PRIMARY KEY, name varchar(30));
테이블 test_tb 를 만듭니다.
sqlite> .tables //테이블목록 보기
test_tb
sqlite> .schema test_tb // 테이블의 구조를 봅니다.
create table test_tb ( id int PRIMARY KEY, name varchar(30));
sqlite> insert into test_tb values ( 1,'권기성');
// AUTO_INCREMENT 기능하는 INSERT
sqlite> insert into test_tb values((SELECT max(id) FROM test_tb)+1,'권기성2');
sqlite> select * from test_tb;
1|권기성
2|권기성2

sqlite> create index name_idx on test_tb (name) ; //인덱스 만들기

sqlite> begin ; //트랜잭션도 가능
sqlite> insert into test_tb values ( 3,'김기성');
sqlite> select * from test_tb;
1|권기성
2|권기성2
3|김기성
sqlite> rollback; //롤백
sqlite> select * from test_tb;
1|권기성
2|권기성2

sqlite> .output backup.txt //다음줄 select 의 결과가 backup.txt 파일로 저장됨
sqlite> select * from test_tb ;
sqlite> .exit //종료

// 쉘에서 test_db 를 dump 받아서 압축함 ( mysqldump 와 비슷 )
$ echo '.dump' | sqlite test_db | gzip -c > test_db.dump.gz //백업하기
$ zcat test_db.dump.gz | sqlite test_db //복원하기



3. PHP 에서 모듈설치

- PHP 5 베타 : --with-sqlite 옵션을 주고 컴파일합니다.
(참고로 php 5 에서는 mysql 을 사용하려면 반드시 --with-mysql 을 줘야합니다.)
컴파일후 pearDB 를 사용하려면 이 경우도
# pear install SQLite 명령어로 sqlite 패키지를 설치해야할겁니다.(아마)

- PHP 4.3.3 : 제경우 4.3.3 에서 테스트 했습니다. 최소 가능 버전이 얼마인지는 모르겠습니다.
이경우 php 의 최초 컴파일시 --with-sqlite 라는 옵션자체가 없습니다.
그러므로 일반적으로 php 컴파일 해서 설치한 후 나중에
PEAR 패키지로 따로 설치를 해야합니다. 리눅스 쉘에서 루트 권한으로

# pear install SQLite

라고 하면 패키지를 자동으로 다운 받아서 소스 풀고 한참 컴파일 합니다.
결과적으로 {PHP설치위치}/extensions/no-debug-non-zts-20020429 와 같은 디렉토리에
sqlite.so 라는 so 파일이 하나생깁니다.
이파일을 {PHP설치위치}/extensions/ 로 복사한후
php.ini 파일에서

extension=sqlite.so

와 같이 동적 모듈을 사용하도록 수정합니다.
조심할 점은 php.ini 에서 extension_dir 이 제대로 설정되거나 아니면 주석처리되어
디폴트 위치를 찾도록 해야합니다.

이렇게 한후 웹서버를 재시작하고, phpinfo() 로 봤을때 sqlite 항목이 나오면 제대로
설치가 된겁니다.

- PEAR DB
위에서 pear install SQLite 명령시 pear 패키지로 자동 설치하며
{PHP설치위치}/php/DB/sqlite.php 라는 파일로 저장됩니다.
이 파일을 통해서 sqlite 도 PEAR DB 에서 간편하게 사용가능합니다.



4. PHP 소스

- 간단한 사용법은 아래와 같습니다. DB 연결부분은 쉽게 이해가 가실겁니다.
- 실패하기 제일 쉬운 이유는 DB 인 test_db 라는 파일의 경로가 제대로 설정되어야하고
웹서버가 읽고 쓸수 있는 권한이 주어져야합니다.

<?php
// PEAR DB 연결
require_once 'DB.php';
require_once 'DB/sqlite.php';

// DSN 정의 - DB 파일의 경로와 퍼미션 주의
$dsn = array (
'phptype' => "sqlite", 'database' => "./test_db",
'mode' => 0644
);
$db = &new DB_sqlite();
$db->connect($dsn, array('persistent'=> true) );
$table = 'test_tb'; // 테이블명

//입력
$result = $db->query("INSERT INTO $table VALUES (9,'아무개');");

printf("affectedRows:\t\t%s\n<br>", $db->affectedRows() );
printf("getLastInsertId:\t%s\n<br>", $db->getLastInsertId() );
$result = $db->query("SELECT * FROM $table;" );
while($row = $db->fetchrow($result)){
print_r($row ); echo "<br>";
}
$db->disconnect();
?>



5. 기타

- http://www.sqlite.org 와 그곳에 있는 링크들의 정보를 참조하세요..

- sqlite 관리툴은 sf.net 에서 sqlite 라는 검색어로 찾아보면 몇개 있습니다.
http://sourceforge.net/projects/sqlite-admin/ 이것은 phpMyadmin 비슷한 php 관리툴인데
단점은 php5 가 필요합니다.
http://sourceforge.net/projects/sqlitebrowser/ 이것은 Qt 로된 리눅스용 GUI 입니다.

- 위의 사용예에서 보인 pear DB 를 사용하지 않고 ,그냥 php 의 sqlite 함수를 이용하려면
http://kr.php.net/manual/kr/ref.sqlite.php 이곳을 참조하세요..

 

경축! 아무것도 안하여 에스천사게임즈가 새로운 모습으로 재오픈 하였습니다.
어린이용이며, 설치가 필요없는 브라우저 게임입니다.
https://s1004games.com

 

[출처] https://www.phpschool.com/gnuboard4/bbs/board.php?bo_table=tipntech&wr_id=23961

본 웹사이트는 광고를 포함하고 있습니다.
광고 클릭에서 발생하는 수익금은 모두 웹사이트 서버의 유지 및 관리, 그리고 기술 콘텐츠 향상을 위해 쓰여집니다.
번호 제목 글쓴이 날짜 조회 수
89 PHP Composer 설치 및 사용법 졸리운_곰 2018.09.27 288
88 [PHP] PhpStorm IDE 사용하기 file 졸리운_곰 2018.07.19 119
87 phpStorm 원격 서버 연결 및 배포 (Deployment) file 졸리운_곰 2018.07.18 152
86 php 세션 저장소를 redis 로 바꾸어 본 후기. file 졸리운_곰 2018.05.05 413
85 아이오닉과 php 그리고 mysql 연동 : Using PHP and MySQL with Ionic file 졸리운_곰 2018.01.14 340
84 CKEditor 4 설치와 PHP 연동 하기 file 졸리운_곰 2018.01.14 234
83 5가지 조미료같은 워드프레스 플러그인 file 졸리운_곰 2018.01.14 52
82 wordpress 한시간만에 만들기 졸리운_곰 2017.10.26 63
81 PHP 프레임 새로고침할 때 페이지 유지하기 입니다. 졸리운_곰 2017.09.17 365
80 How to install composer on Wamp file 졸리운_곰 2017.09.10 104
79 Install Composer on Windows and WAMP Server file 졸리운_곰 2017.09.10 46
78 php로 하둡 다루기 : Using Hadoop And PHP 졸리운_곰 2017.08.03 213
77 php로 빅데이터 다루기 : BIG DATA IN PHP file 졸리운_곰 2017.08.03 47
76 PHP-ML - Machine Learning library for PHP 머신러닝 file 가을의곰 2017.06.18 267
75 xampp+php+mssql file 가을의곰 2017.06.10 142
74 Build An Automated PHP Gallery System In Minutes file 가을의곰 2017.06.10 181
73 xampp+php+mssql file 가을의곰 2017.06.04 98
72 PHP - AJAX and PHP file 졸리운_곰 2017.05.06 47
71 PhpStorm 으로 라라벨 개발 하기 졸리운_곰 2017.05.05 408
70 WordPress Development using PhpStorm 졸리운_곰 2017.05.05 457
대표 김성준 주소 : 경기 용인 분당수지 U타워 등록번호 : 142-07-27414
통신판매업 신고 : 제2012-용인수지-0185호 출판업 신고 : 수지구청 제 123호 개인정보보호최고책임자 : 김성준 sjkim70@stechstar.com
대표전화 : 010-4589-2193 [fax] 02-6280-1294 COPYRIGHT(C) stechstar.com ALL RIGHTS RESERVED