首頁 > 後端開發 > php教程 > 解决mysql FIND_IN_SET 查询不到数据

解决mysql FIND_IN_SET 查询不到数据

PHP中文网
發布: 2023-02-28 11:26:01
原創
2510 人瀏覽過


$con = mysql_connect("localhost","root","root");

//$dbname = "weixin";

function selectMsg($str)
{
    $rows = array();
    $msgArr = array();
    $like = array();
    $arr = array();

    $sql = "SELECT * FROM weixin.weixin_msg WHERE FIND_IN_SET('".$str."',Title)";
    $result = mysql_query($sql); 
    while($rows = mysql_fetch_array($result, MYSQL_ASSOC))
    {
        $msgArr[] = $rows;
    }
    if (!empty($msgArr)) {
        
        return $msgArr;

    }else{

        $sqlstr = "SELECT * FROM weixin.weixin_msg WHERE Title LIKE '%".$str."%' order by id desc";

        $like = mysql_query($sqlstr);

        while($arr = mysql_fetch_array($like, MYSQL_ASSOC))
        {
          $msgArr[] = $arr;
        }
            return $msgArr;
    }
        
}


function cityName($keyword)
{

    $sql = "SELECT * FROM weixin.weixin_cityname WHERE FIND_IN_SET('".$keyword."',CityNameCn)";
    $result = mysql_fetch_array(mysql_query($sql), MYSQL_ASSOC);
    print_r($result);

}

cityName("北京");

$res= selectMsg("123");
echo "<pre class="brush:php;toolbar:false">";
print_r($res);
登入後複製

selectMsg那个函数可以输出,
但是下面城市的就不行,检查了一下不是表名之类的问题.字段也是utf8

这样查询也可以
解决mysql FIND_IN_SET 查询不到数据


解决了,在链接数据库后加入以下代码

header("Content-Type: text/html;charset=utf-8");
//连接数据库
$con = mysql_connect("localhost","root","root");

mysql_query("set character set 'utf8'");//读库  
mysql_query("set names 'utf8'");//写库
登入後複製

1 个回答

直接把SQL拿到数据库里面跑一下

类似这种

select * from city where FIND_IN_SET(city_name , '3213222222333,123'); 

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板