最新公告
  • 欢迎您光临站长模版网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 帝国cms 多条件查询之IN查询

    正文概述 管理员   2024-04-10   17

    帝国cms中,偶然需要用到in查询,也就是多条件查询中的:

    在使用这个的时候,发现IN查询并不能查询到我的结果,于是翻找PHP代码,发现下面的函数里需要修改!

    function SearchDoKeyboard($f,$hh,$keyboard){
    	// print_r($keyboard);echo "<br>";
    	$where='';
    	$keyboard=SearchDoKeyboardVar($keyboard);
    
    	if(empty($keyboard))
    	{
    		return "";
    	}
    	if(!empty($hh))
    	{
    		if($hh=='LT')//小于
    		{
    			$where=$f."<'".$keyboard."'";
    		}
    		elseif($hh=='GT')//大于
    		{
    			$where=$f.">'".$keyboard."'";
    		}
    		elseif($hh=='EQ')//等于
    		{
    			$where=$f."='".$keyboard."'";
    		}
    		elseif($hh=='LE')//小于等于
    		{
    			$where=$f."<='".$keyboard."'";
    		}
    		elseif($hh=='GE')//大于等于
    		{
    			$where=$f.">='".$keyboard."'";
    		}
    		elseif($hh=='NE')//不等于
    		{
    			$where=$f."<>'".$keyboard."'";
    		}
    		elseif($hh=='IN')//包含
    		{
    			
    			$kr=explode(' ',$keyboard);
    			$kcount=count($kr);
    			$kbs='';
    			$dh='';
    			
    			for($i=0;$i<$kcount;$i++)
    			{
    				$kr[$i]=(float)$kr[$i];
    				// print_r($kr[$i]);echo "<br>";
    				if(empty($kr[$i]))
    				{
    					continue;
    				}
    				if($kbs)
    				{
    					$dh=',';
    				}
    				$kbs.=$dh."'".$kr[$i]."'";
    			}
    			if($kbs)
    			{
    				$where=$f." IN (".$kbs.")";
    			}
    			else
    			{
    				return '';
    			}
    		}
    		elseif($hh=='BT')//范围
    		{
    			$keyboard=ltrim($keyboard);
    			if(!strstr($keyboard,' '))
    			{
    				return '';
    			}
    			$kr=explode(' ',$keyboard);
    			$kr[0]=(float)$kr[0];
    			$kr[1]=(float)$kr[1];
    			if(!trim($kr[0])||!trim($kr[1]))
    			{
    				return '';
    			}
    			$where=$f." BETWEEN '".$kr[0]."' and '".$kr[1]."'";
    		}
    		else//相似
    		{
    			$where=$f." LIKE '%".$keyboard."%'";
    		}
    	}
    	else
    	{
    		$where=$f." LIKE '%".$keyboard."%'";
    	}
    	return $where;
    }

    只需要将下面代码注释掉即可:

    $kr[$i]=(float)$kr[$i];

    这个代码会将字符串类转换为/ target=_blank class=infotextkey>转换为浮点类型,导致接下来的数据判断为空,所以只需要注释掉这行代码即可

    直接搜索,搜索到删掉这行或者注释就行

     


    站长模版网 » 帝国cms 多条件查询之IN查询

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    支付宝支付
    余额支付
    ×
    微信扫码支付 0 元