|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
终于理解了数据库的概念,而且让你兴奋不已的是你终于可以通过PHP来连接数据库了,这期间你是怎么学会的,我们不去考证了,但是事实证明,你已经可以了。 - <?php /** * MySQL 数据库操作东西
类, 便利
数据库操作. * 示例见底部正文
. * @author: http://www.ideawu.net/blog/ */ class Mysql{ var $conn; var $query_list = array(); public $query_count = 0; public function __construct($c){ if(!isset($c['port'])){ $c['port'] = '3306'; } $server = $c['host'] . ':' . $c['port']; $this->conn = mysql_connect($server, $c['username'], $c['password'], true) or die('connect db error'); mysql_select_db($c['dbname'], $this->conn) or die('select db error'); if($c['charset']){ mysql_query("set names " . $c['charset'], $this->conn); } } /** * 履行
mysql_query 并前往
其了局
. */ public function query($sql){ $stime = microtime(true); $result = mysql_query($sql, $this->conn); $this->query_count ++; if($result === false){ throw new Exception(mysql_error($this->conn)." in SQL: $sql"); } $etime = microtime(true); $time = number_format(($etime - $stime) * 1000, 2); $this->query_list[] = $time . ' ' . $sql; return $result; } /** * 履行
SQL 语句, 前往
了局
的第一笔记
录(是一个对象). */ public function get($sql){ $result = $this->query($sql); if($row = mysql_fetch_object($result)){ return $row; }else{ return null; } } /** * 前往
查询了局
集, 以 key 为键组织成联系关系
数组, 每个
元素是一个对象. * 假如
key 为空, 则将了局
组织成通俗
的数组. */ public function find($sql, $key=null){ $data = array(); $result = $this->query($sql); while($row = mysql_fetch_object($result)){ if(!empty($key)){ $data[$row->{$key}] = $row; }else{ $data[] = $row; } } return $data; } public function last_insert_id(){ return mysql_insert_id($this->conn); } /** * 履行
一条带有了局
集计数的 count SQL 语句, 并返该计数. */ public function count($sql){ $result = $this->query($sql); if($row = mysql_fetch_array($result)){ return (int)$row[0]; }else{ return 0; } } /** * 入手下手
一个事务. */ public function begin(){ mysql_query('begin'); } /** * 提交一个事务. */ public function commit(){ mysql_query('commit'); } /** * 回滚一个事务. */ public function rollback(){ mysql_query('rollback'); } /** * 获得
指定编号的纪录
. * @param int $id 要获得
的纪录
的编号. * @param string $field 字段名, 默许
为'id'. */ function load($table, $id, $field='id'){ $sql = "select * from `{$table}` where `{$field}`='{$id}'"; $row = $this->get($sql); return $row; } /** * 保留
一笔记
录, 挪用
后, id被设置. * @param object $row */ function save($table, &$row){ $sqlA = ''; foreach($row as $k=>$v){ $sqlA .= "`$k` = '$v',"; } $sqlA = substr($sqlA, 0, strlen($sqlA)-1); $sql = "insert into `{$table}` set $sqlA"; $this->query($sql); if(is_object($row)){ $row->id = $this->last_insert_id(); }else if(is_array($row)){ $row['id'] = $this->last_insert_id(); } } /** * 更新$arr[id]所指定的纪录
. * @param array $row 要更新的纪录
, 键名为id的数组项的值唆使
了所要更新的纪录
. * @return int 影响的行数. * @param string $field 字段名, 默许
为'id'. */ function update($table, &$row, $field='id'){ $sqlA = ''; foreach($row as $k=>$v){ $sqlA .= "`$k` = '$v',"; } $sqlA = substr($sqlA, 0, strlen($sqlA)-1); if(is_object($row)){ $id = $row->{$field}; }else if(is_array($row)){ $id = $row[$field]; } $sql = "update `{$table}` set $sqlA where `{$field}`='$id'"; return $this->query($sql); } /** * 删除一笔记
录. * @param int $id 要删除的纪录
编号. * @return int 影响的行数. * @param string $field 字段名, 默许
为'id'. */ function remove($table, $id, $field='id'){ $sql = "delete from `{$table}` where `{$field}`='{$id}'"; return $this->query($sql); } function escape(&$val){ if(is_object($val) is_array($val)){ $this->escape_row($val); } } function escape_row(&$row){ if(is_object($row)){ foreach($row as $k=>$v){ $row->$k = mysql_real_escape_string($v); } }else if(is_array($row)){ foreach($row as $k=>$v){ $row[$k] = mysql_real_escape_string($v); } } } function escape_like_string($str){ $find = array('%', '_'); $replace = array('\%', '\_'); $str = str_replace($find, $replace, $str); return $str; } } ?>
复制代码 利用例子:
- <?php // 保留
$db->save('table_1', $row); // 更新 $db->update('table_1', $row); // 删除 $db->remove('table_1', 1); // 查询 $rows = $db->find($sql, 'id') ?>
复制代码 理解动态语言的概念,运做机制,熟悉PHP语法 |
|