cf-platform/Application/Home/Model/AdvModel.class.php

101 lines
3.0 KiB
PHTML

<?php
// +----------------------------------------------------------------------
// | OneThink [ WE CAN DO IT JUST THINK IT ]
// +----------------------------------------------------------------------
// | Copyright (c) 2013 http://www.onethink.cn All rights reserved.
// +----------------------------------------------------------------------
// | Author: huajie <banhuajie@163.com>
// +----------------------------------------------------------------------
namespace Home\Model;
use Think\Model;
/**
* 文档基础模型
*/
class AdvModel extends Model{
/* 自动验证规则 */
protected $_validate = array(
);
/* 自动完成规则 */
protected $_auto = array(
array('start_time', 'strtotime', self::MODEL_INSERT, 'function'),
array('end_time', 'strtotime', self::MODEL_INSERT, 'function'),
);
/**
* 构造函数
* @param string $name 模型名称
* @param string $tablePrefix 表前缀
* @param mixed $connection 数据库连接信息
*/
public function __construct($name = '', $tablePrefix = '', $connection = '') {
/* 设置默认的表前缀 */
$this->tablePrefix ='tab_';
/* 执行构造方法 */
parent::__construct($name, $tablePrefix, $connection);
}
/**
*获取广告信息
*/
public function adv_lists($name,$sort,$limit){
$map['tab_adv.status'] = 1;
$map['tab_adv_pos.name'] = $name;
$map['start_time'] = array(array('lt',time()),array('eq',0),'or');
$map['end_time'] = array(array('gt',time()),array('eq',0),'or');
$data = $this->field("tab_adv.*,tab_adv_pos.name")
->join("tab_adv_pos on tab_adv.pos_id = tab_adv_pos.id")
->where($map)
->limit($limit)
->order($sort)
->select();
return $data;
}
public function adv_lists2($name,$sort,$limit){
$map['tab_adv.status'] = 1;
$map['tab_adv_pos.name'] = $name;/*array('in',array('7','8'))*/
$data = $this->field("tab_adv.*,tab_adv_pos.name")
->join("tab_adv_pos on tab_adv.pos_id = tab_adv_pos.id")
->where($map)
->limit($limit)
->order('tab_adv.sort desc')
->select();
return $data;
}
public function lists($name,$limit=20,$sort='a.sort desc',$field='a.title,a.data,a.url,a.target') {
if (empty($name) || !is_string($name)) {return '';}
$map['a.status']=1;
$map['p.name']=$name;
$map['start_time']=array(array('eq',0),array('egt',time()),'or');
$map['end_time']=array(array('eq',0),array('egt',time()),'or');
$data = $this->alias('a')->field($field)
->join('tab_adv_pos as p on a.pos_id = p.id')
->where($map)
->limit($limit)
->order($sort?$sort:'sort desc')
->select();
return $data;
}
}