织梦教程开始 1、在前台模板搜索框代码内加入一行代码 input type = hidden name = channeltype value = 1 例如 form name=formsearch action={dede:global.cfg_cmspath/}/plus/search.php !-- 必须要指定搜索哪个模型 value=模型id -- input type=hidden name=channeltype value=1 !-- 必须要指定搜索哪个模型 value=模型id -- /f […]
1、在前台模板搜索框代码内加入一行代码
例如
2、打开 /include/arc.searchview.class.php 找到 大概在 54 行
var $Sphinx;复制
在它下面加入
var $addJoin;复制
1
继续找到
$hascode = md5($cquery);复制
在它上面加入
if($this->ChannelType > 0)
{
$this->AddSql = join(' AND ',$ksqls) . " AND ( CONCAT(addf.body,arc.title) LIKE '%{$this->Keyword}%') ";
$row = $this->dsql->GetOne("SELECT addtable FROM `58pic_channeltype` WHERE id={$this->ChannelType}");
$addtable = trim($row['addtable']);
$this->addJoin = " LEFT JOIN `{$addtable}` addf ON arc.id=addf.aid ";
$cquery = "SELECT arc.*,addf.* FROM `{$this->AddTable}` arc {$this->addJoin} WHERE ".$this->AddSql;
}
注意:上面中的 addf.body 就是文章内容字段,如果你要搜索其他字段,改成你的自定义字段名称
继续找到
WHERE {$this->AddSql} $ordersql LIMIT $limitstart,$row";
在它下面加入
if($this->ChannelType > 0)
{
$query = "SELECT arc.*,act.typedir,act.typename,act.isdefault,act.defaultname,act.namerule,
act.namerule2,act.ispart,act.moresite,act.siteurl,act.sitepath,addf.*
FROM `{$this->AddTable}` arc LEFT JOIN `58pic_arctype` act ON arc.typeid=act.id {$this->addJoin}
WHERE {$this->AddSql} $ordersql LIMIT $limitstart,$row";
}
完成
说点什么吧
全部评论(0)
最新
最早
还没有评论,快来抢沙发吧!