首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Ajax Livesearch搜索分两列

Ajax Livesearch搜索分两列
EN

Stack Overflow用户
提问于 2015-08-07 23:04:00
回答 1查看 105关注 0票数 1

我在这里使用ajax的生活搜索:Ajax Livesearch

我想让用户在数据库中搜索城市,到目前为止,它工作得很好。当我输入一个字母时,它会显示城市和邮政编码。现在,我尝试使相同的搜索框也工作使用密码,以便城市将显示,如果用户搜索邮政编码。但我完全被卡住了。也许有人有一些搜索框的经验,可以帮助我。

config.php中,我定义了搜索列:

代码语言:javascript
复制
const USER_TABLE = 'cities';
const SEARCH_COLUMN = 'Name';

要从数据库中获取结果,我有以下代码:

代码语言:javascript
复制
$db = DB::getConnection();

    // get the number of total result
    $stmt = $db->prepare('SELECT COUNT(id) FROM ' . Config::USER_TABLE . ' WHERE ' . Config::SEARCH_COLUMN . ' LIKE :query');
    $search_query = $query.'%';
    $stmt->bindParam(':query', $search_query, PDO::PARAM_STR);
    $stmt->execute();
    $number_of_result = $stmt->fetch(PDO::FETCH_COLUMN);

    // initialize variables
    $HTML = '';
    $number_of_pages = 1;

    if ( (int) $number_of_result !== 0)
    {
        if ($items_per_page === 0)
        {
            // show all
            $stmt = $db->prepare('SELECT * FROM ' . Config::USER_TABLE . ' WHERE ' . Config::SEARCH_COLUMN . ' LIKE :query ORDER BY ' .Config::SEARCH_COLUMN);
            $search_query = $query.'%';
            $stmt->bindParam(':query', $search_query, PDO::PARAM_STR);
        }
        else
        {
            /*
             * pagination
             *
             * calculate total pages
             */
            if ($number_of_result < $items_per_page)
                $number_of_pages = 1;
            elseif ($number_of_result > $items_per_page)
                $number_of_pages = floor($number_of_result / $items_per_page) + 1;
            else
                $number_of_pages = $number_of_result / $items_per_page;

            /*
             * pagination
             *
             * calculate start
             */
            $start = ($current_page > 0 ) ? ($current_page - 1) * $items_per_page : 0;

            $stmt = $db->prepare('SELECT * FROM ' . Config::USER_TABLE . ' WHERE ' . Config::SEARCH_COLUMN . ' LIKE :query ORDER BY '.Config::SEARCH_COLUMN.' LIMIT ' . $start . ', ' . $items_per_page);
            $search_query = $query.'%';
            $stmt->bindParam(':query', $search_query, PDO::PARAM_STR);
        }

        // run the query and get the result
        $stmt->execute();
        $results = $stmt->fetchAll(PDO::FETCH_ASSOC);

这将在我的网站上显示结果:

代码语言:javascript
复制
foreach($results as $result)
        {
            $HTML .= "<tr><td>{$result['Name']}</td><td>{$result['Postal_Code']}</td></tr>";
        }

因此,如果我输入字母,它也会给出'Postal_Code‘列中的正确邮政编码。但我猜也可以用另一种方式,我输入数字,它会显示城市和邮政编码?在config.php中,我只能定义一列

代码语言:javascript
复制
const SEARCH_COLUMN = 'Name';

也许可以使用第二个const,比如:

代码语言:javascript
复制
const SEARCH_COLUMN2 = 'Postal_Code';

?但是我如何在db查询中使用它呢?对我来说解释我的问题有点困难,所以我希望你能以任何方式理解我:)谢谢

EN

回答 1

Stack Overflow用户

发布于 2015-08-07 23:08:11

如果您在配置中添加了另一个常量,则只需在查询中添加一个OR子句:

代码语言:javascript
复制
' WHERE ' . Config::SEARCH_COLUMN . ' LIKE :query OR '. Config::SEARCH_COLUMN2 . ' LIKE :query'
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31880982

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档