<?php 
 | 
/** 
 | 
 * PhalApi_Model模型接口 
 | 
 * 
 | 
 * - 提供基于“表数据入口”模式的数据库接口 
 | 
 * - 提供基于主键(id, etc)的基本操作,其中应对CLOB的ext_data字段的转换 
 | 
 * - 为了支持数据库分表存储,实现类应该根据数据库配置读取相应的表名 
 | 
 * 
 | 
 * <br>使用示例:<br> 
 | 
``` 
 | 
 *     class Model_User extends PhalApi_Model_NotORM { 
 | 
 *  
 | 
 *         protected function getTableName($id) { 
 | 
 *             return 'user'; 
 | 
 *         } 
 | 
 *     } 
 | 
 *  
 | 
 *     $model = new Model_User(); 
 | 
 *  
 | 
 *     // 获取 
 | 
 *  $rs = $model->get($userId); 
 | 
 *   
 | 
 *  // 插入 
 | 
 *  $model->insert(array('name' => 'whatever', 'from' => 'somewhere')); 
 | 
 *   
 | 
 *  // 更新 
 | 
 *  $model->update(1, array('name' => 'dogstar huang')); 
 | 
 *   
 | 
 *  // 删除 
 | 
 *  $model->delete(1); 
 | 
``` 
 | 
 *  
 | 
 * @package     PhalApi\Model 
 | 
 * @license     http://www.phalapi.net/license GPL 协议 
 | 
 * @link        http://www.phalapi.net/ 
 | 
 * @author      dogstar <chanzonghuang@gmail.com> 2015-02-22 
 | 
 */ 
 | 
  
 | 
interface PhalApi_Model { 
 | 
     
 | 
    /** 
 | 
     * 根据主键读取纪录 
 | 
     *  
 | 
     * @param long $id 纪录主键 
 | 
     * @param string/array $fields 需要获取的表字段,可以为字符串(如:name,from)或数组(如:array('name', 'from')) 
 | 
     * @return array 数据库表纪录 
 | 
     */ 
 | 
    public function get($id, $fields = '*'); 
 | 
  
 | 
    /** 
 | 
     * 插入新纪录 
 | 
     * 这里看起来有点奇怪,但如果我们需要进行分表存储,这里的参考主键是需要的 
 | 
     *  
 | 
     * @param array $data 待插入的数据,可以包括ext_data字段 
 | 
     * @param $id 分表参考主键 
 | 
     * @return long 新插入纪录的主键值 
 | 
     */ 
 | 
    public function insert($data, $id = NULL); 
 | 
  
 | 
    /** 
 | 
     * 根据主键更新纪录 
 | 
     * 
 | 
     * @param long $id 主键 
 | 
     * @param array $data 待更新的数据,可以包括ext_data字段 
 | 
     * @return TRUE/FALSE 
 | 
     */ 
 | 
    public function update($id, $data); 
 | 
  
 | 
    /** 
 | 
     * 根据主键删除纪录 
 | 
     */ 
 | 
    public function delete($id); 
 | 
} 
 |