| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138 | 
							- <?php
 
- defined('IN_PHPCMS') or exit('Access Denied');
 
- class access{
 
- 	var $querynum = 0;
 
- 	var $conn;
 
- 	var $insertid = 0;
 
- 	var $cursor = 0;
 
- 	//var $ADODB_FETCH_MODE = ADODB_FETCH_BOTH;
 
- 	/**
 
- 	 * 最近一次查询资源句柄
 
- 	 */
 
- 	public $lastqueryid = null;
 
- 	function connect($dbhost, $dbuser = '', $dbpw = '', $dbname = '', $pconnect = 0)
 
- 	{
 
- 		$this->conn = new com('adodb.connection');
 
- 		if(!$this->conn) return false;
 
-  		$this->conn->open("DRIVER={Microsoft Access Driver (*.mdb)};dbq=$dbhost;uid=$dbuser;pwd=$dbpw");
 
-  		if($this->conn->state == 0)
 
- 		{
 
- 			$this->conn->open("Provider=Microsoft.Jet.OLEDB.4.0; Data Source=$dbhost");
 
- 			if($this->conn->state == 0)	return false;;
 
- 		}
 
- 		define('NUM', 1);
 
- 		define('ASSOC', 2);
 
- 		define('BOTH', 3);
 
- 		return $this->conn->state;
 
- 	}
 
- 	function select_db($dbname)
 
- 	{
 
- 		return $this->conn->state;
 
- 	}
 
-  	
 
- 	function query($sql, $type = '', $expires = 3600, $dbname = '') {
 
- 		$this->querynum++;
 
- 		$sql = trim($sql);
 
- 		if(preg_match("/^(select.*)limit ([0-9]+)(,([0-9]+))?$/i", $sql, $matchs)){
 
-  			$sql = $matchs[1];
 
- 			$offset = $matchs[2];
 
- 			$pagesize = $matchs[4];
 
- 			$query = $this->conn->Execute($sql);
 
-  			return $this->limit($query, $offset, $pagesize);
 
- 		} else{
 
-  			return $this->conn->Execute($sql);
 
- 		}
 
- 	}
 
- 	function get_one($query) {
 
- 		$this->querynum++;
 
- 	    $rs = $this->conn->Execute($query);
 
-  		$r = $this->fetch_array($rs);
 
- 		$this->free_result($rs);
 
- 		return $r;
 
- 	}
 
- 	function fetch_array($rs, $result_type = 3) {
 
- 		if(is_array($rs)){
 
- 			return $this->cursor < count($rs) ? $rs[$this->cursor++] : FALSE;
 
- 		} else{
 
- 			if($rs->EOF) return FALSE;
 
- 			$array = array();
 
- 			for($i = 0; $i < $this->num_fields($rs); $i++){
 
- 				$fielddata = $rs->Fields[$i]->Value;
 
- 			    $array[$rs->Fields[$i]->Name] = $fielddata;
 
- 			}
 
- 			$rs->MoveNext();
 
- 			return $array;
 
- 		}
 
- 	}
 
- 	 
 
- 	
 
- 	function select($sql, $keyfield = ''){
 
- 		$array = array();
 
- 		$result = $this->query($sql);
 
- 		while($r = $this->fetch_array($result)){
 
- 			if($keyfield){
 
- 				$key = $r[$keyfield];
 
- 				$array[$key] = $r;
 
- 			}else{
 
- 				$array[] = $r;
 
- 			}
 
- 		}
 
- 		$this->free_result($result);
 
- 		return $array;
 
- 	}
 
- 	function num_rows($rs){
 
- 	    return is_array($rs) ? count($rs) : $rs->recordcount;
 
- 	}
 
- 	function num_fields($rs){
 
- 	    return $rs->Fields->Count;
 
- 	}
 
- 	function fetch_assoc($rs){
 
- 	    return $this->fetch_array($rs, ASSOC);
 
- 	}
 
- 	function fetch_row($rs){
 
- 	    return $this->fetch_array($rs, NUM);
 
- 	}
 
- 	function free_result($rs){
 
- 	    if(is_resource($rs)) $rs->close();
 
- 	}
 
- 	function error(){
 
- 	    return $this->conn->Errors[$this->conn->Errors->Count-1]->Number;
 
- 	}
 
- 	function errormsg(){
 
- 	    return $this->conn->Errors[$this->conn->Errors->Count-1]->Description;
 
- 	}
 
- 	function close(){
 
- 	    $this->conn->close();
 
- 	}
 
- 	function limit($rs, $offset, $pagesize = 0){
 
- 		if($pagesize > 0){
 
- 			$rs->Move($offset);
 
- 		}else{
 
- 			$pagesize = $offset;
 
- 		}
 
- 		$info = array();
 
- 		for($i = 0; $i < $pagesize; $i++){
 
- 			$r = $this->fetch_array($rs);
 
- 			if(!$r) break;
 
- 			$info[] = $r;
 
- 		}
 
- 		$this->free_result($rs);
 
- 		$this->cursor = 0;
 
- 		return $info;
 
- 	}
 
- }
 
- ?>
 
 
  |