V9如何调用全站模型的数据

本文介绍如何在PHPCMS中优化全站最新内容的查询功能,通过修改model.class.php和content_tag.class.php文件,实现高效的内容检索,并提供前端调用示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在phpcms\libs\classes\model.class.php增加以下程序:

* @param string $sql 查询条件
*/
	final public function count_sql($sql) {
		$this->query($sql);
		$res = $this->db->fetch_next();
		$this->db->free_result();
		return $res['num'];
	}

在phpcms\modules\content\classes\content_tag.class.php增加

/**
	 * 全站最新内容
	 */
	public function newcontent($data){
		$page = $data['page'] ? intval($data['page']) : 1;
		$pagesize = intval($data['limit']) ? intval($data['limit']) : '10';
		$maxnum = $data['maxnum'] ? intval($data['maxnum']) : 100;
		$setpages = $data['setpages'] ? intval($data['setpages']) : 10;
		$models = getcache('model', 'commons');
		$sql = 'select * from (';
		$count_sql = 'select sum(tmpcount) as num from (';
		$i = 1;
		foreach($models as $m){			
			$sql .= '(select id,catid,typeid,title,style,thumb,keywords,description,url,inputtime from '.$this->db->db_tablepre.$m['tablename'].' where status=99 and catid in(22,7,8,9)) ';
			if($i < count($models)) $sql .= 'union ';
			//获取总数
			$count_sql .= '(select count(*) as tmpcount from '.$this->db->db_tablepre.$m['tablename'].' where status=99 and catid in(22,7,8,9))';
			if($i < count($models)) $count_sql .= 'union all ';
			$i++;
		}
		$count_sql .=') as a';
		$this->number = $this->db->count_sql($count_sql);
		$this->number = $this->number > $maxnum ? $maxnum : $this->number;
		$page = max(intval($page), 1);
		$offset = $pagesize*($page-1);
		$this->pages = pages($this->number, $page, $pagesize, $data['urlrule'], $array, $setpages);
		$sql .= 'order by inputtime desc,id desc limit '.$maxnum.') as a limit '.$offset.', '.$pagesize;
		$this->db->query($sql);	
		$res = $this->db->fetch_array();
		return $res;
	}

前台调用:

  {pc:content action="newcontent" num="100" return="data"}
                            {loop $data $r}
                这里是要显示的数据内容
                    {/loop}
    {/pc}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值