2

所以这是我关于 stackoverflow 的第一个问题,我已经搜索了一天但找不到我正在寻找的结果。我不是在找人为我编写代码,因为我更喜欢自己弄清楚,但我正在寻找一些帮助来寻找如何去做。

我的问题是我不知道如何用我的搜索来寻找我正在寻找的东西,这就是我想要做的。我希望能够使用诸如“U10 Mustangs”之类的关键字来搜索 MySQL 数据库,其中 U10 将是名为“divisions”的行中的数据,而 Mustangs 将是名为“club”的行中的数据,我知道我可以使用或这样的声明

(`division` LIKE '%".$query."%') OR (`club` LIKE '%".$query."%')

但这仅允许我按部门或俱乐部搜索,而不是两者。所以基本上我正在寻找一个教程来向我展示如何通过多个关键字进行搜索。我确定我的措辞是错误的,这就是为什么我无法找到我想要的。

我是 MySQL 和 PHP 的新手,所以如果这没有意义,请理解!

*更新* 这是我的搜索代码:

    <body>
<?php include 'menu.php';?>
<br/><br/><br/>
<div id="searchcontainer" style="width: 55%; height: 132px;">
<fieldset style="width: 330px"><legend>Search Criteria</legend>
<form action="search.php" method="POST">
<td>Enter Search</td><td>&nbsp; <input type="text" name="query"/></td><td>  <input type="submit" name="submit" id="table_button" value="Search" action="search.php"/></td>
<br />
</form>
</fieldset><br/>
<fieldset><legend>Search Results</legend>
<?php
        include 'connect/local_connect.php';

    $query = $_POST['query']; 
    // gets value sent over search form

   // $min_length = 3;
   // you can set minimum length of the query if you want

   // if(strlen($query) >= $min_length){ // if query length is more or equal minimum length then

        $query = htmlspecialchars($query); 
        // changes characters used in html to their equivalents, for example: < to &gt;

        $query = mysql_real_escape_string($query);
        // makes sure nobody uses SQL injection

        $raw_results = mysql_query("SELECT * FROM players
            WHERE (`team_name` LIKE '%".$query."%' AND `division` LIKE '%".$query."%') OR (`last_name` LIKE '%".$query."%') OR (`division` LIKE '%".$query."%') ORDER by id ASC") or die(mysql_error());

        // * means that it selects all fields, you can also write: `id`, `first_name`, `any`
        // players is the name of our table



        if(mysql_num_rows($raw_results) > 0){ // if one or more rows are returned do following

        }
        else{ // if there is no matching rows do following
            echo "<font color=red>No Results!</font>";
      ?><br/><br/>
      <?php

    }
   // else{ // if query length is less than minimum
   //     echo "Minimum length is ".$min_length;
   // }


        // Define $color=1 
        $color="1";
        echo '<table width="100%" border="1" align="center" cellpadding="0" cellspacing="0">';
        echo '<th>ID</th><th>Club</th><th>Last Name</th><th>First Name</th><th>Division</th>';
        while($rows = mysql_fetch_array($raw_results)){

        echo "<tr bgcolor='#fff000'>
        <td><center>".$rows['id']."</td></center><td><center>".$rows['club']."</center></td><td><center>".$rows['last_name']."</td></center><td><center>".$rows['first_name']."</center></td></td><td><center>".$rows['division']."</center></td></td></tr>";       
        }




        echo '</table>';
        mysql_close();
        ?>

</fieldset>
</div>
</body>
4

3 回答 3

0

你在找concat吗

where CONCAT(`division`,' ',`club`) like '%".$query."%'
于 2013-07-29T04:38:42.433 回答
0

我会建议像这样创建一个关于分区和俱乐部的全文索引,FULLTEXT (club,division) 并使用这样的查询进行搜索

SELECT * FROM db
WHERE MATCH (club,division)
AGAINST ('search');
于 2013-07-29T04:39:54.853 回答
0

“……但这只能让我按部门或俱乐部搜索,不能同时搜索……”

您可以将搜索字符串拆分为单词,然后使用这样的条件

SELECT * 
  FROM table1
 WHERE (division LIKE '%U10%' AND club LIKE '%Mustang%')
    OR (division LIKE '%Mustang%' AND club LIKE '%U10%')

这是SQLFiddle演示

于 2013-07-29T04:41:15.603 回答