<?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; } }