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

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

    在帝国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];

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

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

     


    站长源码网 » 帝国cms 多条件查询之IN查询

    发表评论

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

    联系作者

    请选择支付方式

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