词条信息

admin
admin
超级管理员
最近编辑者 发短消息   

相关词条

热门词条

更多>>
什么是端口?到底是做什么的呢?
端口一般指两种,一种是硬件比如路由器或者交换机的插网线的端口,一种是软件的逻辑的概念,比如http的80端口!...
7种进阶方法让你快速测试端口连通性
Ping是Windows、Linux和Unix系统下的一个检查网络连通性的命令工具,对于大部分互联网用户来说很...
电脑开机,总需要按F1,是什么原因造成的?
一.主板掉电这个说法是行业内的叫法了,一般是主板的CMOS电池没电了导致的。也是最常见的一种提示你按F1的提示...
社保降费对个人有什么影响?
下调城镇职工基本养老保险单位缴费比例是政府给企业发的一个大红包,特别是对于企业来说是一个利好,但是对个人来说有...
车辆“出险”对下年保费的影响,到底有多大?
【出险对交强险的影响】【出险对商业险的影响】车辆“出险”对下年保费的影响,到底有多大?这里有必要先提下车险第三...

精选图集

更多>>
简易百科旧版 >>所属分类 >> 程序开发    HDWIKI   

如何让HDWiki支持模糊搜索

标签: HDWiki 模糊搜索 网站开发 程序开发

顶[1] 发表评论(0) 编辑词条

  让HDWiki支持模糊搜索:

  修改安装目录下的\model\search.class.php文件

  将其中的join_sql方法替换成以下方法:


function join_sql($element){

                $keywords = $element['keyword'];

                $searchtitle=($_ENV['doc']->get_total_num() < $this->base->setting['search_num'])?0:1;

                if($searchtitle){

                        $sqlkeywords .="d.title LIKE '$keywords%'";

                        $element['author']="";

                        $element['categoryid'][0]='all';

                }else{

                        $arraylist = split(" ",$keywords); //将查询关键字通过空格进行分解

                        $sqlkeywords .= "(";

                        for($i=0; $i<count($arraylist); $i++) //把它们全部输出来

                        {

                                $keyword = $arraylist[$i];

                                $sqlkeywords .="d.".$element['searchtype']." LIKE '%$keyword%' and ";

                        }

                        $strleng = strlen($sqlkeywords);

                        $temp =  substr($sqlkeywords, 0, $strleng-4);

                        $temp .= ") or (";

                        for($i=0; $i<count($arraylist); $i++) //把它们全部输出来

                        {

                                $keyword = $arraylist[$i];

                                $temp .="d.content LIKE '%$keyword%' and ";

                        }

                        $templeng = strlen($temp);

                        $temp =  substr($temp, 0, $templeng-4);

                        $temp .= ")";

                        $sqlkeywords = $temp;

                        //$sqlkeywords .="d.".$element['searchtype']." LIKE '%$keywords%' or d.content LIKE '%$keywords%' ";

                        //echo $sqlkeywords;

                }        
                $sqladd=(trim($sqlkeywords)!='')?' AND ('.$sqlkeywords.")":"";

                $sqladd .=(bool)$element['author']?" AND d.author='".$element['author']."' ":"";

                $sqladd .=('all'!=$element['categoryid'][0])?' AND d.cid in ('.implode(',',$element['categoryid']).') ':'';

                if(0!=$element['timelimited']){

                        $sqladd .=('within'==$element['withinbefore'])?" AND d.`time` > '".($this->base->time-$element['timelimited'])."'" :" AND d.`time` < '".($this->base->time-$element['timelimited'])."'";

                }

                $order=" ORDER BY d.".$element['ordertype']." ".$element['ascdesc']."";

                $result['sql']='SELECT d.did,d.tag,d.title,d.author,d.authorid,d.time,d.summary,d.edits, d.views,d.comments FROM '.DB_TABLEPRE.'doc d  WHERE 1 '.$sqladd.$order;

                $result['dsql']='SELECT COUNT(*) as num FROM '.DB_TABLEPRE.'doc d WHERE 1 '.$sqladd;

                return $result;

        }


 

 

附件列表


按字母顺序浏览:A B C D E F G H I J K L M N O P Q R S T U V W X Y Z

→我们致力于为广大网民解决所遇到的各种电脑技术问题
 如果您认为本词条还有待完善,请 编辑词条

上一篇keywords分号改逗号的解决办法
下一篇32位系统和64位系统的区别

1
1. 本站部分内容来自互联网,如有任何版权侵犯或其他问题请与我们联系,我们将立即删除或处理。
2. 本站内容仅供参考,如果您需要解决具体问题,建议您咨询相关领域专业人士。
3. 如果您没有找到需要的百科词条,您可以到百科问答提问或创建词条,等待高手解答。

关于本词条的提问

查看全部/我要提问>>