qy-platform/Application/Home/Logic/BaseLogic.class.php

96 lines
2.6 KiB
PHTML

<?php
// +----------------------------------------------------------------------
// | OneThink [ WE CAN DO IT JUST THINK IT ]
// +----------------------------------------------------------------------
// | Copyright (c) 2013 http://www.onethink.cn All rights reserved.
// +----------------------------------------------------------------------
// | Author: 麦当苗儿 <zuojiazi@vip.qq.com> <http://www.zjzit.cn>
// +----------------------------------------------------------------------
namespace Home\Logic;
use Think\Model;
/**
* 文档模型逻辑层公共模型
* 所有逻辑层模型都需要继承此模型
*/
class BaseLogic extends Model{
/**
* 构造函数用于这是Logic层的表前缀
* @param string $name 模型名称
* @param string $tablePrefix 表前缀
* @param mixed $connection 数据库连接信息
*/
public function __construct($name = '', $tablePrefix = '', $connection = '') {
/* 设置默认的表前缀 */
$this->tablePrefix = C('DB_PREFIX') . 'document_';
/* 执行构造方法 */
parent::__construct($name, $tablePrefix, $connection);
}
/**
* 获取模型详细信息
* @param integer $id 文档ID
* @return array 当前模型详细信息
*/
public function detail($id){
$data = $this->field(true)->find($id);
if(!$data){
$this->error = '获取详细信息出错!';
return false;
}
return $data;
}
/**
* 获取段落列表
* @param array $ids 要获取的段落ID列表
* @return array 段落数据列表
*/
public function lists($ids){
$map = array();
if(1 === count($ids)){
$map['id'] = $ids[0];
} else {
$map['id'] = array('in', $ids);
}
$data = $this->field(true)->where($map)->select();
$list = array();
foreach ($data as $value) {
$list[$value['id']] = $value;
}
return $list;
}
/**
* 新增或添加模型数据
* @param number $id 文章ID
* @return boolean true-操作成功false-操作失败
*/
public function update($id = 0) {
/* 获取数据 */
$data = $this->create();
if ($data === false) {
return false;
}
if (empty($data['id'])) {//新增数据
$data['id'] = $id;
$id = $this->add($data);
if (!$id) {
$this->error = '新增数据失败!';
return false;
}
} else { //更新数据
$status = $this->save($data);
if (false === $status) {
$this->error = '更新数据失败!';
return false;
}
}
return true;
}
}