程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> php使用反射插入對象示例

php使用反射插入對象示例

編輯:關於PHP編程

     這篇文章主要介紹了php使用反射插入對象示例,需要的朋友可以參考下

     代碼如下: /**       * 插入insertModel(),利用反射,效率稍差      * @param class $model 對象     * @param bool $is_returnLastInsertId 是否返回添加ID      * @return int 默認返回成功與否,$is_returnLastInsertId 為true,返回添加ID      */      public function insertModel($model,$is_returnLastInsertId=FALSE) {         try {             require_once dirname(dirname(__FILE__)).'ModelsBaseModel.php';             if(!is_subclass_of($model, "BaseModel")){                 exit($this->getError(__FUNCTION__, __LINE__));             }             $className=get_class($model);             $tName = $this->formatTabName($className);             $reflectionClass=new ReflectionClass($className);             $properties=$reflectionClass->getProperties();             unset($properties[0]);             $fields="";             $vals="";             foreach ($properties as $property) {                 $pName=$property->getName();                 $fields.=$pName.",";                 $vals.='''.$model->$pName.'''.',';             }             $fields=rtrim($fields,',');             $vals=rtrim($vals,',');             $this->sql = "insert into {$tName} ({$fields}) values ({$vals})";             if($is_returnLastInsertId){                 $this->conn->exec($this->sql);                 $lastId = (int)$this->conn->lastInsertId();                   return $lastId;             }  else {                 $row = $this->conn->exec($this->sql);                   return $row;             }         } catch (Exception $exc) {             echo $exc->getMessage();         }     }  
    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved