链式调用封装MySQL类
代码
<?php /*Created By RexLee **PHP file MySQL.php 2012-12-19 */ class MySQL { private $host; private $name; private $password; private $dbname; //数据库名 private $link; private $errlog=array(); public $errreport=true;//开启错误报告 private $runStat;//运行状态,记录当前运行的成员 private $value;//结果 public function __construct($server,$dbuser,$psw){//连接主机 $this->host=$server; $this->name=$dbuser; $this->password=$psw; $this->link=@mysql_connect($this->host,$this->name,$this->password) or die('<font color="red">ERROR: <b><em>数据库主机连接失败!<em></b></font><br/>'); $this->runStat="init";//定义为初始化 $this->fn=0; } public function to2DArray(){//构造二维数组 /////////////检测////////////////// if(!is_resource($this->value)){ array_push($this->errlog, "ERROR: <em>运行错误,在<font color=\"red\"><b>to2DArray</b></font>层调用错误的方法<em><br/>"); $this->runStat="error";//将运行状态设置为错误 return $this; } $this->runStat="to2DArray"; ///////////////////////////////////// $_2DArray=Array(); while($row=@mysql_fetch_array($this->value)){//直接取value值,此时的value应当为resource类型 $keyarr=array_keys($row); foreach ($keyarr as $key) { if (is_int($key)) { unset($row[$key]);//去掉以数组为键名的数组元素 }; } array_push($_2DArray, $row); } $this->value=$_2DArray ; return $this; } public function db($database,$charset){//连接数据库 /////////////检测////////////////// if(!is_resource($this->link)){ array_push($this->errlog, "ERROR: <em>运行错误,在<font color=\"red\"><b>db</b></font>层调用错误的方法<em><br/>"); $this->runStat="error";//将运行状态设置为错误 return $this; } $this->runStat="db"; ///////////////////////////////////// $this->dbname=$database; mysql_query("set names ".$charset);//设置字符集 $this->value=mysql_select_db($this->dbname,$this->link); if (!$this->value) { echo "<font color=\"blue\"><b>ERROR:打开数据库错误!</b></font><br/>"; $this->runStat="error"; } return $this; } public function query($sql) { /////////////检测////////////////// if(!is_string($sql)){ array_push($this->errlog,"ERROR: <em>运行错误,在<font color=\"red\"><b>query</b></font>层调用错误的方法<em><br/>"); $this->runStat="error";//将运行状态设置为错误 return $this; } $this->runStat="query"; ///////////////////////////////////// $sql=addslashes($sql);//防注入 $result=mysql_query($sql); if (!$result) { array_push($this->errlog,"ERROR: <em><b style=\"color:red;\">语句运行错误!</b></em></br>"); $this->runStat="sqlerror"; } $this->value=$result; return $this; } function value() { $this->runStat="init"; if ($this->errreport) { foreach ($this->errlog as $value) { echo $value; } } $this->errlog=array();//clean $result=$this->value; $this->value=null;//clean return $result; } public function __call($f,$v){//错误方法吸收 echo "<font color=\"red\"><b>ERROR</b></font>: 不存在".$f."()方法. <br/>"; return $this; } } $db=new MySQL("localhost", "root", "lijun"); //$db->errreport=false; $h=$db->db("students", 'utf8'); var_dump($db->db("ip", 'utf8')->to2DArray()->query("select * from ip limit 0,2")->to2DArray()->value()); var_dump($h->query("seslect * from nuser limit 10,2")->to2DArray()->value()); var_dump($db->db("ip", 'utf8')->query("SELECT * FROM ip LIMIT 0 , 2")->to2DArray()->value()); ?>
ログイン後にコピー
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事
R.E.P.O.説明されたエネルギー結晶と彼らが何をするか(黄色のクリスタル)
2週間前
By 尊渡假赌尊渡假赌尊渡假赌
スプリットフィクションを打ち負かすのにどれくらい時間がかかりますか?
1 か月前
By DDD
R.E.P.O.ファイルの保存場所:それはどこにあり、それを保護する方法は?
1 か月前
By DDD
R.E.P.O.最高のグラフィック設定
2週間前
By 尊渡假赌尊渡假赌尊渡假赌
アサシンのクリードシャドウズ:シーシェルリドルソリューション
1週間前
By DDD

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック
Gmailメールのログイン入り口はどこですか?
7388
15


Java チュートリアル
1630
14


CakePHP チュートリアル
1357
52


Laravel チュートリアル
1267
25


PHP チュートリアル
1216
29

