PHPデータオブジェクトマッピングモードの実例分析
3157 ワード
この例では、PHPデータオブジェクトマッピングモードについて説明します.皆さんの参考にしてください.具体的には以下の通りです.
オブジェクトとデータストレージをマッピングし、1つのオブジェクトに対する操作をデータストレージに対する操作にマッピングします.
たとえば、コード内の
コードでデータ・オブジェクト・マッピング・モードを実装し、複雑なSQL文をオブジェクト・プロパティにマッピングするORMクラスを実装します.工場モデルと登録モデルを組み合わせて使用
例1
【例1】
データベースtest、userテーブル構造:
Common\User.php:
Common\Databases\MySQLi.php
入口ファイルphp
PHPについてもっと兴味のある読者は、「phpオブジェクト向けプログラミング入門チュートリアル」、「PHP配列(Array)操作テクニック大全」、「PHP基本文法入門チュートリアル」、「PHP演算と演算子用法総括」、「php文字列(string)用法総括」、「php+mysqlデータベース操作入門チュートリアル」および「php一般データベース操作テクニック要約」
ここで述べたことが皆さんのPHPプログラム設計に役立つことを願っています.
オブジェクトとデータストレージをマッピングし、1つのオブジェクトに対する操作をデータストレージに対する操作にマッピングします.
たとえば、コード内の
new
のオブジェクトは、配列オブジェクトマッピングモードを使用してオブジェクトのいくつかの操作、例えばいくつかのプロパティを設定すると、自動的にデータベースに保存され、データベーステーブルのレコードに対応します.コードでデータ・オブジェクト・マッピング・モードを実装し、複雑なSQL文をオブジェクト・プロパティにマッピングするORMクラスを実装します.工場モデルと登録モデルを組み合わせて使用
例1
【例1】
データベースtest、userテーブル構造:
CREATE TABLE `user` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(32) CHARACTER SET utf8 DEFAULT NULL,
`mobile` varchar(11) CHARACTER SET utf8 DEFAULT NULL,
`regtime` timestamp NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=latin1;
Common\User.php:
db = new Database\MySQLi();
$conn = $this->db->connect('127.0.0.1', 'root', '', 'test');
$res = $this->db->query("select * from user where id = {$id} limit 1");
$data = $res->fetch_assoc();
$this->id = $data['id'];
$this->name = $data['name'];
$this->mobile = $data['mobile'];
$this->regtime = $data['regtime'];
}
//
function __destruct() {
$this->db->query("update user set name = '{$this->name}', mobile = '{$this->mobile}', regtime = '{$this->regtime}' where id = {$this->id} limit 1");
}
}
Common\Databases\MySQLi.php
conn = $conn;
}
function query($sql){
$res = mysqli_query($this->conn, $sql);
return $res;
}
function close(){
mysqli_close($this->conn);
}
}
入口ファイルphp
';
/*
*
*/
$user = new Common\User(1);
//
var_dump($user->id, $user->mobile, $user->name, $user->regtime);exit();
$user->mobile = '13800138000';
$user->name = 'Arshavin';
$user->regtime = date("Y-m-d H:i:s",time());
PHPについてもっと兴味のある読者は、「phpオブジェクト向けプログラミング入門チュートリアル」、「PHP配列(Array)操作テクニック大全」、「PHP基本文法入門チュートリアル」、「PHP演算と演算子用法総括」、「php文字列(string)用法総括」、「php+mysqlデータベース操作入門チュートリアル」および「php一般データベース操作テクニック要約」
ここで述べたことが皆さんのPHPプログラム設計に役立つことを願っています.