홈으로 홈으로 | 무료회원가입 | 아이디/비번찾기 | 즐겨찾기
추천음악방송메인홈1대1상담음악방송청취
아리랑가요(무료음악채널)
뽕짝아가씨(무료음악채널)
okTrot(무료음악채널)
전통가요(무료음악채널)
미스트롯(무료음악채널)

온라이브스토어(앱다운로드)

환상의뽕짝파티 무료음악
명작트로트메들리 무료음악
트로트메들리관광 무료음악
동영상노래방
가사검색

POP Player
신나는 고스톱
컴퓨터 오목
작은 음악다방
자동러시 웹플레이어신청

보안∵서버∵쿠키
윈도우∵프레임
이미지∵배경
시간∵달력∵계산
상태바∵타이틀바
음악∵영상
폼∵전송∵테이블
키보드∵마우스
효과∵링크∵메뉴
Script∵php
기타
PHP 강좌
윈도우관련팁
웹관련팁
홈페이지제작팁
기본강좌
레지스트리
윈도우서버
리눅스서버
Android
php5 mysqli 디비 접속 클래스 프로그램 및 사용법
3년 전
웹스크립트언어의 최강자 PHP 프로그램입니다.

PHP를 사용하려면 반드시 알아야  할것이 디비접속을 하여 그 데이타를 추출할 줄 알아야
좋은 프로그램을 만들 수 있지요

PHP5 부터는 많음 클래스 들을 제공하는데
그 중에 하나가 mysqli 라는 클래스 입니다.

이 클래스 mysqli 를  그대로 상속받아
좀더 사용하기 쉽도록 mysqli 관련 클래스를 만들드록 하겠습니다.

하지만, 모든 언어가 그렇듯이
PHP도 반드시 mysql 에만 접속 해서 사용하라는 법이 없습니다.

다양한 데이타베이스에 접속해서 사용을 할 수 있죠

그렇지만 php 코딩은 갖습니다.
단 디비만 바뀌는 거죠 이렇게 디비만 바뀌면 되는데
디비를 접속하고 쿼리 날리고 저장하고 하는 일들에 대해
프로그램을 수정해야 한다면 정말 일이 많고 스트레스가 상승하게 됩니다.

이러한 불편한 작업들을 하지 않기 위해서
하나의 interface를 정의해 놓고
다른 여러 프로그래머들이 데이타 베이스 프로그램을 작성 할때
동일한 메소드들을 정의하고 사용하도록 규칙을 정합니다.

가장 많이 사용하는
query, insert, modify, delete 등이죠
최소한의 것을 정의해서 사용하는 겁니다.

더 많은 것들을 정의 할 수 있지만
우선 위의 것들을 정의한 interface 를 만들고 mysqli를 상속 받아
보다 사용하기 편리한 데이타베이스 클래스 파일을 만들어 보겠습니다.

@ interface : DbSwitch 클래스를 만들겠습니다.
< ?php
# purpose : 각종 SQL 관련 디비를 통일성있게  작성할 수 있도록 틀을 제공
interface DbSwitch
{
    public function query($query);                        # 쿼리
    public function insert($table);                        # 저장
    public function update($table,$where);        # 수정
    public function delete($table,$where);        # 삭제
    public function bindParams($query,$args=array());        #쿼리 문자 바인드효과
}
? >

@ 디비 접속 정보를 미리 설정해 놓겠습니다.
< ?php
define('_DB_HOST_','localhost');                #접속 경로
define('_DB_USER_','apmsoft');                        #접속 아이디
define('_DB_PASSWD_','password');                #접속 비밀번호
define('_DB_NAME_','apmsoft_db');                #접속 데이타베이스 명
? >


@ DbMySqli : [클래스1개] mysqli, [인터페이서 2개] DbSwitch, ArrayAccess 를 상속 받아 구현을 합니다.

< ?php
# Parent : MySqli
# Parent : DBSwitch
# purpose : mysqli을 활용해 확장한다
class DbMySqli extends mysqli implements DbSwitch,ArrayAccess
{
        private $params = array();
        
        # dsn : host:dbname = localhost:dbname
    public function __construct($dsn='',$user='',$passwd='',$chrset='utf8')
        {
                # 데이타베이스 접속
                if(!empty($dsn)){
                        $dsn_args = explode(':',$dsn);
                        parent::__construct($dsn_args[0],$user,$passwd,$dsn_args[1]);
                }else{//config.inc.php --> config.db.php
                        parent::__construct(_DB_HOST_,_DB_USER_,_DB_PASSWD_,_DB_NAME_);
                }
        
        if (mysqli_connect_error()){
                throw new ErrorException(mysqli_connect_error(),mysqli_connect_errno());
        }

                # 문자셋
                $chrset_is = parent::character_set_name();
                if(strcmp($chrset_is,$chrset)) parent::set_charset($chrset);
    }
        
        #@ interface : ArrayAccess
        # 사용법 : $obj["two"] = "A value";
    public function offsetSet($offset, $value) {
        $this->params[$offset] = parent::real_escape_string($value);
    }
    
    #@ interface : ArrayAccess
    # 사용법 : isset($obj["two"]); -> bool(true)
        public function offsetExists($offset) {
        return isset($this->params[$offset]);
    }
    
    #@ interface : ArrayAccess
    # 사용법 : unset($obj["two"]); -> bool(false)
        public function offsetUnset($offset) {
        unset($this->params[$offset]);
    }
    
    #@ interface : ArrayAccess
   # 사용법 : $obj["two"]; -> string(7) "A value"
        public function offsetGet($offset) {
        return isset($this->params[$offset]) ? $this->params[$offset] : null;
    }
        
        # @ interface : DBSwitch
        # :s1 -> :[문자타입]+[변수]
        # :s[문자], :d[정수], :f[소수], :b[바이너리]
        # 변수타입, :s1,:sa,:sA, :d1, :d2, :dA 어떻게든 상관없음
        # 단 :s1, :s1 이렇게 중복 되어서는 안됨        
        # where 구문만 변경
        // ("SELECT * FROM `TABLE` WHERE name=':s1' and age=':d2'",array('php',26,'나','ㅈㄷ',22));
        public function bindParams($query,$args=array()){
                if(strpos($query,':') !==false){
                        preg_match_all("/(\:[s|d|f|b])+[0-9]+/s",$query,$matches);
                        if(is_array($matches))
                        {
                                foreach($matches[0] as $n => $s)
                                {
                                        # 문자타입과 값이 일치하는지 체크
                                        $bindtype = substr($s,1,1);
                                        $bvmatched = false;
                                        switch($bindtype){
                                                case 's': if(is_string($args[$n])) $bvmatched = true; break;
                                                case 'd': if(is_int($args[$n])) $bvmatched = true; break;
                                                case 'f': if(is_float($args[$n])) $bvmatched = true; break;
                                                case 'b': if(is_binary($args[$n])) $bvmatched = true; break;
                                        }
                                        if($bvmatched){
                                                $query = str_replace($s,'%'.$bindtype,$query);
                                                $query = sprintf("{$query}",parent::real_escape_string($args[$n]));
                                        }else{
                                                $query = false;
                                                break;
                                        }
                                }
                        }
                }
        return $query;
        }

        #@ return int
        # 총게시물 갯수 추출
        public function get_total_record($table, $where="", $field='*'){
                $wh = ($where) ? " WHERE ".$where : '';
                if($result = parent::query('SELECT count('.$field.') FROM `'.$table.'`'.$wh)){
                        $row = $result->fetch_row();
                        return $row[0];
                }
        return 0;
        }

        // 하나의 레코드 값을 가져오기
        public function get_record($field, $table, $where){
                $where = ($where) ? " WHERE ".$where : '';
                $qry = "SELECT ".$field." FROM `".$table."` ".$where;
                if($result = $this->query($qry)){
                        $row = $result->fetch_assoc();
                        return $row;
                }
        return false;
        }

    # @ interface : DBSwitch
        public function query($query){
                $result = parent::query($query);
        if( !$result ){
                throw new ErrorException(mysqli_error(&$this).' '.$query,mysqli_errno(&$this));
        }
    return $result;
    }

        # @ interface : DBSwitch
        # args = array(key => value)
        # args['name'] = 1, args['age'] = 2;
        public function insert($table){
                $fieldk = '';
                $datav        = '';
                if(count($this->params)<1) return false;
                foreach($this->params as $k => $v){
                        $fieldk .= sprintf("`%s`,",$k);
                        $datav .= sprintf("'%s',", parent::real_escape_string($v));
                }
                $fieldk        = substr($fieldk,0,-1);
                $datav        = substr($datav,0,-1);
                $this->params = array(); #변수값 초기화
                
                $query        = sprintf("INSERT INTO `%s` (%s) VALUES (%s)",$table,$fieldk,$datav);
                $this->query($query);
        }
    
        # @ interface : DBSwitch
        public function update($table,$where)
        {
                $fieldkv = '';
                
                if(count($this->params)<1) return false;
                foreach($this->params as $k => $v){
                        $fieldkv .= sprintf("`%s`='%s',",$k,parent::real_escape_string($v));
                }
                $fieldkv = substr($fieldkv,0,-1);
                $this->params = array(); #변수값 초기화
                
                $query        = sprintf("UPDATE `%s` SET %s WHERE %s",$table,$fieldkv,$where);
                $this->query($query);
        }

        # @ interface : DBSwitch
    public function delete($table,$where){
            $query = sprintf("DELETE FROM `%s` WHERE %s",$table,$where);
            $this->query($query);
    }
    
        # 상속한 부모 프라퍼티 값 포함한 가져오기
        public function __get($propertyName){
                if(property_exists(__CLASS__,$propertyName)){
                        return $this->{$propertyName};
                }
        }
    
    # db close
    public function __destruct(){
            parent::close();
    }
}
? >

여기서 부터는
member 테이블이 있다고 가정하고
uid : 회원고유번호 userid : 아이디 name : 이름 passwd : 비밀번호 email : 이메일 정보 hp : 휴대폰

1. 데이타 입력
2. 데이타 쿼리
3. 데이타 수정
4. 데이타 삭제  예문을 보겠습니다.

1.  insert 디비 저장 /-------------------
< ?php
# 클래스 선언
$db = new DbMySqli();

# 디비 저장
$db['uid']                = 1;
$db['userid']        = 'apmsoft';
$db['passwd']        = 'pwd1004';
$db['name']                = '멋쟁이';
$db['email']        = 'apmsoft@test.com';
$db['hp']                = '010-3456-9876';

$db->insert();
? >

2. query  디비 쿼리 /---------------------------
/**
  일반적인 복수의 데이타 쿼리문
*/
< ?php
# 디비 선언
$db = new DbMySqli();

# 쿼리
$result = $db->query("SELECT * FROM `member` WHERE uid='1'");
while( $row = $result->fetch_assoc() )
{
       echo $row['uid'];
       echo $row['userid'];
       echo $row['name'];
}
? >

/**
    단순 데이타 쿼리문
*/
< ?php
# 디비 선언
$db = new DbMySqli();

# 쿼리
$row = $db->get_record('*', 'member',  "uid='1'");

echo $row['uid'];
echo $row['userid'];
echo $row['name'];
? >

3. update 디비 정보 수정 /----------------------------------
< ?php
# 디비선언
$db = new DbMySqli();

# 디비정보 수정
$db['name']                = '홍길동';
$db['email']        = 'ddd@gmail.com';

$db->update('member', "uid='1'");
? >


4. delete 디비 삭제 /----------------------------------------
< ?php
# 디비선언
$db = new DbMySqli();

# 디비정보 삭제하기
$db->delete('member', "uid='1'");
? >
추천추천 : 267 추천 목록
번호 제목
3,016
 우클릭 완벽차단 스크립트
3,015
 iframe 높이 100% 맞추기
3,014
 curl 함수를 이용한 HTTP REFERER 변경
3,013
 윈도우10 시스템 파일 및 Dism 검사
3,012
 텍스트 줄바꿈, 글자자르기 CSS
3,011
 jQuery Mobile에서 유용한 코드 10가지.
3,010
 [PHP] dirname()함수와 $_SERVER 관련 상수들
3,009
 [PHP] 파일 크기, 사이즈 불러오는 함수, filesize()
3,008
 [jQuery] jQuery Quick API
3,007
 [ transition ] 링크 hover 색상 변화 속도 조절
3,006
 PHP 5.3.0 에서 사라진 함수들 대체
3,005
 어떤 파일들이 include 나 require 되었는지 확인하는 함수(get_included_files)
3,004
 PHP 날짜 형식 및 계산하기(날짜 더하고 빼기)
3,003
 jQuery Mobile에서 유용한 코드 10가지.
3,002
 값이 배열 안에 존재하는지 확인하는 in_array함수
3,001
 사용자가 웹브라우저에서 뒤로가기를 했을때 감지하는 방법
3,000
 [jQuery]버튼 활성화, 비활성화
2,999
 jQuery show() / hide() / toggle() 사용법
2,998
 jquery 여러가지 이벤트
2,997
 border-radius 속성
2,996
 네이버 오픈API 음성합성 API 사용하는 PHP 샘플코드
2,995
 UTF8 한글 자르기..
2,994
 iconv 에러 발생시 계속 처리하기 옵션
2,993
 [PHP] 현재 페이지의 도메인 , URL 정보 알아내기.
2,992
 [PHP] 막강 기능 배열..
2,991
 [CSS] - Input clear `X ` 버튼 제거 ( IE, Chrome, Firefox )
2,990
 [Mobile] - 모바일웹 Href 태그속성들
2,989
 [JqueryMobile] - 현재화면의 가로세로 사이즈 구하기
2,988
 [JqueryMobile] - 화면의 가로, 세로 사이즈 구하는 방법
2,987
 jquery로 가로 넓이(width), 세로 높이(height) 자동 조절
2,986
 iframe 높이 jquery로 자동조절하기
2,985
 jQuery 오른쪽 영역의 높이를 왼쪽 영역의 높이와 동일하게 하기
2,984
 jquery에서 테이블 짝수, 홀수 번째 TR 배경색 변경하기
2,983
 jquery에서 테이블에 마우스 오버시 해당 행의 배경색상 변경하기
2,982
 jquery 스크립트내 특정값 확인하기 (디버깅)
목록
인기절정뽕짝파티
인기트로트모음
지루박디스코메들리
밤무대애창곡
전자올겐경음악
세월따라노래따라
가슴시린트로트
트로트쌍쌍파티
7080추억속으로
종합성인가요방
못잊을옛날노래
카바레 음악
트롯디스코팡팡
관광 메들리
트롯카페
가요감상실
추억의옛노래
스페셜가요광장
BillBoard Free
추천가요모음
경음악.전자올겐
스페셜음악여행
WOLRD POPs
K-POP\BillBoard
JP\CN
POP TOP BEST
K.R.노래방

최신인기가요특집
추천가요\인기
F뮤직 인기\발라드
F뮤직 애창\트로트
트로트성인가요
인기가요
프리미엄 POP
경음악\기타
프리미엄 최신가요
프리미엄 성인가요
가요축제\트롯1번지
댄스\메들리\리믹스
카페\명상\경음악\기타
뮤직트로트 부산광역시부산진구 가야동 ㅣ 개인정보취급방침
Copyright (C) musictrot All rights reserved.