php/mysql对某些查询不返回结果

mf98qq94  于 2021-06-24  发布在  Mysql
关注(0)|答案(1)|浏览(325)

我知道这不是一个新问题,但在使用不同参数运行相同查询时,结果不一致:
问题始于此查询(从脚本日志粘贴的副本):

SELECT id 
FROM Resources 
WHERE group_id IN (2,3,1) 
AND MATCH (title, body) AGAINST ('diseño' IN NATURAL LANGUAGE MODE) 
LIMIT 10

它不输出任何内容,num\u rows为0,任何解析它的尝试都会失败。奇怪的是,如果我将同一个查询粘贴到phpmyadmin中,它将返回9个结果。
现在,这是来自完全相同的函数和过程的工作查询:

SELECT id 
FROM Resources 
WHERE group_id IN (2,3,1) 
AND MATCH (title, body) AGAINST ('moda' IN NATURAL LANGUAGE MODE) 
LIMIT 10

这样就可以输出10个结果并正常工作。
这是我的密码:

public function loadFromSearch($searchStr, $resourceGroupIdList){
    //$searchStr2 = NaturalLanguageHelper::mb_replace('n', 'ñ', $searchStr);

    $dbConn = new DbConnection();
    $query = $dbConn->escapeQuery("SELECT {$this->DB_ID} FROM {$this->DB_TABLE_NAME} WHERE {$this->DB_GROUP_ID} IN ({$resourceGroupIdList}) AND MATCH ({$this->DB_FULLTEXT_INDEX}) AGAINST ('%s' IN NATURAL LANGUAGE MODE) LIMIT 10", $searchStr);

    Log::echo("\n". $query . "\n\n");

    $result = $dbConn->newQuery($query);
    return $this->fillArrayFromResult($result, array('title'));
}

这将调用此函数:

protected function fillArrayFromResult($result, $column_list_array = false) {
        Log::echo("\nnum rows: {$result->num_rows}\n\n");
        if($result->num_rows == 0)return false;
        while($row = $result->fetch_array(MYSQLI_NUM)){

            Log::echo("\n\nGot Row! Creating instance of ".$this->class."...\n");

            $instance = new $this->class();

            Log::echo("\n\n Instance OK\n");

            if(!is_array($column_list_array))
                $instance->loadFromDb($row[0]);
            else
                $instance->loadFromDbPartial($column_list_array, $row[0]);

            array_push($this->collection, $instance);
        }
        $result->free();
        return true;
    }

下面是查询函数:

public function newQuery($query){
        if ($result = $this->mysqli->query($query))
            return $result;
        else
            ErrorHandler::throwError("MySQL Query Error: (" . $this->mysqli->errno . ") " . $this->mysqli->error);
    }

知道怎么回事吗?提前谢谢!

6ie5vjzr

6ie5vjzr1#

正如许多人指出的那样,这是一个编码问题,数据库是拉丁文1,代码是utf8,在发送之前在查询中使用utf\u解码解决了我的问题。
谢谢大家!

相关问题