| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138 | <?phpdefined('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;	}}?>
 |