PHPデータオブジェクトマッピングモードの実例分析

3157 ワード

この例では、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プログラム設計に役立つことを願っています.