0

所以我有一个表格,可以搜索公司列表以查看该特定公司是否已在网站上注册。

当公司名称是三个或更少的字符并且我可以看到它在数据库中时,结果不会显示。

例如,如果公司名称是“ABB Eutech”并且搜索的是 ABB,则搜索返回 0。

但是,如果您搜索 Eutech,则搜索会返回结果。

这是我正在使用的代码:

    <?php 
        $out = '';
        if ((isset($_POST['companysearch-name'])) && ($_POST['companysearch-name']==NULL)) {
            $out .= '<h3>No matches. Please enter a company name.</h3>';
        } else if (isset($_POST['companysearch-name'])) {
            $queryString = htmlspecialchars($_POST['companysearch-name'],ENT_QUOTES);                   
            if(strlen($queryString) >0) {
                $query = $wpdb->get_results("SELECT DISTINCT (company_name) FROM wp_companies WHERE MATCH (company_name) AGAINST ('$queryString')");
                $searchStr = "%" . $queryString . "%";
                $searchStr = str_replace(" ","%",$searchStr);
                $numresults = count($query);
                if($query) {
                    $out .= '<div><ul>';
                    foreach($query as $result):

                    $out .= '<li>'.$result->company_name.'</li>';
                    endforeach;
                    $out .= '</ul></div>';
                    $out .= "<p>Is your company on this list? If YES, your company already has the scheme in place and you can setup a donation right now.</p>";
                    $out .= '<a class="button" href="/donate/"><span>Start Giving</span><b></b></a>';
                } else {
                    $out .= '<h3>No matches found.</h3>';
                    $out .= "<p>Can't find your employer? They may have only just signed up - <a href='/contact-us/'>contact us</a> and we'll check it out for you.</p>";
                }
            }
        }
    ?>

大大收到任何帮助!……温柔点,我是第一次。

4

1 回答 1

4

默认情况下,MySQL 中的全文索引会省略包含三个或更少字符的单词。

要索引的单词的最小和最大长度由 ft_min_word_len 和 ft_max_word_len 系统变量定义。(请参阅第 5.1.3 节,“服务器系统变量”。)默认最小值是四个字符;默认最大值取决于版本。如果更改任一值,则必须重建 FULLTEXT 索引。例如,如果您想搜索三个字符的单词,您可以通过将以下行放入选项文件中来设置 ft_min_word_len 变量: [mysqld] ft_min_word_len=3

然后重新启动服务器并重建 FULLTEXT 索引。请特别注意此列表后面的说明中有关 myisamchk 的注释。

http://dev.mysql.com/doc/refman/5.0/en/fulltext-fine-tuning.html

于 2012-07-10T17:36:43.067 回答