php5 mysqli 디비 접속 클래스 프로그램 및 사용법

PHP/PHP5 클래스 2012. 3. 20. 20:55
웹스크립트언어의 최강자 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'");
? >


MySql subquery left join

데이타베이스/MySql 2012. 3. 20. 13:49
mysql 4.1 이상 부터는 subquery가 지원된다.

그 중에 subquery 이면서 left join 과 같은 기능을 하는
쿼리 문에 대해 말할까 한다.

정말 괜찮은 방식 인것 같다

다음은 mysql 5.0 에서 테스트 했습니다.


@ [table] member
|+==================================================  
  uid 고유번호 | userid 아이디 | passwd 비밀번호
|+--------------------------------------------------
1      l testid         | testpasswd1234
|+--------------------------------------------------- 
2      l ddtest         | dddpd1234
|+---------------------------------------------------   

@ [table] member_info
|+===========================================================================================  
  member_uid 회원번호 |     name 이름       |        email 이메일                |               hp
|+-------------------------------------------------------------------------------------------
1      l     나당   | test@test.com                 |        010-1234-5678
|+------------------------------------------------------------------------------------------- 
                    2          l 멋쟁이       |     master@gmail.com          |       010-5256-7532
|+-------------------------------------------------------------------------------------------   
SELECT * 
FROM member m, (SELECT * FROM member_info WHERE member_uid=2) i 
WHERE m.uid = i.member_uid

@ 결과 /-------------------------------

array(

'uid'                  => 2,
'userid'             => 'ddtest',
'passwd'           => 'dddpd1234',
'member_uid'     => '2',
'name'              => '멋쟁이' ,
'email'              => 'master@gmail.com',
'hp'                  => '010-5256-7532'
);

안드로이드 프로그램 :: 동영상 파일에서 썸네일 이미지 추출하기

안드로이드/android 2012. 3. 16. 22:26

안드로이드 개발을 하다 보면
우리는 동영상 파일에서 썸네일 이미지를 추출 해야 할 때가 있다.

지원하지 않는다면 정말 멍멍이 고생 해야 하는데
덕분에 시간과 건강을 벌 수 있다

 
String[] videoFileList = {
   "/sdcard/Video/Android 2.0 Official Video_low.mp4",
   "/sdcard/Video/Android 2.2 Official Video_low.mp4"
 };

# Thumbnails.MICRO_KIND[작은 이미지 사이즈], Thumbnails.MINI_KIND[중간 이미지 사이즈]
Bitmap bmThumbnail;
bmThumbnail = ThumbnailUtils.createVideoThumbnail(videoFileList[0], Thumbnails.MICRO_KIND);

ImageView imageThumbnail = (ImageView)row.findViewById(R.id.Thumbnail);
imageThumbnail.setImageBitmap(bmThumbnail);

안드로이드 전원 버튼을 눌러서 화면을 끌때 내가 원하는 액션을 취해 보자

안드로이드/android 2012. 3. 16. 13:52
우리느 안드로이드 개발을 하다보면
원하던 원하지 않던 간에

하드웨어 이벤트가 일어날때 처리를 해줘야 할 때가 있습니다.

그 중의 하나가 전원 버튼 입니다.

동영상을 보고 있다가 갑자기
전원 버튼을 눌러 버렸을 경우 어떻게 처리 할 것인가 등을 결정 할때
유용하게 사용 할 수 있습니다.

@ java 소스 /======================
public class CameraPreview extends Activity 
{
	@Override
	public void onCreate(Bundle savedInstanceState)
	{
	    
	    //전원버튼
            IntentFilter offfilter = new IntentFilter (Intent.ACTION_SCREEN_OFF);
            registerReceiver(screenoff, offfilter);
	}

        @Override
	public void onDestroy(){
		unregisterBroadcast();//전원버튼
	}

	//전원버튼
	private void unregisterBroadcast() {
		unregisterReceiver(screenoff);
	}
    
	BroadcastReceiver screenoff = new BroadcastReceiver(){
		public static final String Screenoff = "android.intent.action.SCREEN_OFF";
		
		@Override
		public void onReceive(Context context, Intent intent){
			if(!intent.getAction().equals(Screenoff))return;
    		
			// 여기에 전원 버튼을 눌렸을때 
			// 어떠한 일을 할건지 결정하면됩니다
    		}
	 };
}

jquery json IE, Opera 등 parse error 발생 할때

js API/jquery 2012. 3. 15. 11:02
우리는 jquery 를 이용해서 서버와의 통신을 자주 하게 됩니다.
그런데 dataType : 'json'  으로 ajax 통신을 할때

크롬을 제외한 IE 등에서 parse error 를 발생합니다.
정말 난감할 뿐만 아니라 어처구니가 없는거죠

jquery 가 잘 만들어 졌지만 브라우저 마다 처리 방법들이 조금씩 다르다 보니
모두 호환 되도록 하는 방법 밖에 없는 것 같습니다.

그리하여 해결 방법은 이렇습니다.

@ Javascript /=====================================
< script >
function jsonAjax(uid)
{

   $.ajax({
    type: "post",
    url: "./test_json.php",
    cache: false,
    dataType :'text',
    data: {'uid':uid},
    success: function(data, status){
           var json = eval("(" + data + ")");
         // OR  var json =$.parseJSON(data);
           
	  if(typeof(json.result) != 'undefined')
	  {
		if(json.result != ''){
			alert(json.result);
		}else{
			$("#list_loop").empty(); //초기화
			$.each(json.msg, function(key,state) {
				$("#list_loop").append('
'+state["userid"]+' ('+state["name"]+')
'); }); } } }, error: onError }); return false; } function onError(data, status, errorThrown){ alert(data.responseText+' '+status+' '+errorThrown); } < /script >


@ PHP /============================================
<?php
# 회원정보 루프 배열 값
$loop[0] = array(
    'userid' => 'test1id',
    'name'  => '홍길동'
);

$loop[1] = array(
    'userid' => 'test1id',
    'name'  => '홍길동'
);


# json 최종결과
$args = array(
    'result' => 'ok',
    'msg'   => $loop
);

echo json_endcode($args);
exit;
?>

@ HTML /===========================================
< div id="list_loop"> 여기에 내용 결과 출력 < /div >



1. jquery를 이용한 ajax 통신을 할때 dataType 를 text 로 합니다.
2. text 값으로 받은 값을 eval 를 통해 json 데이타로 변환 한다.