0

そのため、複数のカテゴリが関連付けられたアイテムのテーブルがあります。私は問題にぶつかり続けます。これが私のコードの抜粋です:

    <form class="forms" action="form.php" method="get">
    <fieldset>
    <legend>Sort by Category</legend>
    <select name="tags">
    <option value="business" title="Business">Business</option>
    <option value="environmental" title="Environmental">Environmental</option>
    <option value="hospitality" title="Hospitality">Hospitality</option>
    </select><input type="submit" class="inputButton" value="Select Category" />
    </fieldset>
    </form>

    <?php
    $tags = $_GET['tags'];


    $connection = mysql_connect($local,$user,$pass) or die (mysql_errno().' : '.mysql_error().'<br />');
    mysql_select_db($db);
    $query = 'SELECT * FROM awards WHERE active=1 ORDER BY name';
    $result = mysql_query($query);
    $num = mysql_num_rows($result);

    while ($row = mysql_fetch_array($result)) 
    {
        if ($tags == 'business')
        {
            $where = "SELECT * FROM awards WHERE active=1 AND
tags LIKE '%business%' ORDER BY name";
}
    else if ($tags == 'environmental')
    {
        $where = "SELECT * FROM awards WHERE active=1 AND 
tags LIKE '%environmental%' ORDER BY name";
}
    else if ($tags == 'hospitality')
    {
        $where = "SELECT * FROM awards WHERE active=1 AND 
tags LIKE '%hospitality%' ORDER BY name";
    }
        else
        {
            $where = 'SELECT * FROM awards WHERE active=1 ORDER BY name';
            $title = 'Awards in Alphabetical Order';
        }
    }
    include 'conn.php';
    $connection = mysql_connect($local,$user,$pass) or die (mysql_errno().' : '.mysql_error().'<br />');
    mysql_select_db($db);
    $query = 'SELECT * FROM awards $where';
    $result = mysql_query($query);
    $num = mysql_num_rows($result);
?>

その後、問題ないエコーなど。欲しいレコードだけを引っ張ってもらうことができないようです。私はこれを間違った方法で行っていますか?テーブルの行「タグ」には、複数のコンマ区切り値があります。したがって、誰かが「ビジネス」を選択した場合、タグの1つとして「ビジネス」を持たないレコードをプルするべきではありません。代わりに、「タグ」を別々の行として使用する必要がありますか?

4

1 に答える 1

0
<?php
    $tags = $_GET['tags'];

if ($tags == 'business' || $tags == 'environmental' || $tags == 'hospitality')
{
            $where = "SELECT * FROM awards WHERE active=1 AND
tags LIKE '%$tags%' ORDER BY name";
}
else
{
     $where = 'SELECT * FROM awards WHERE active=1 ORDER BY name';
            $title = 'Awards in Alphabetical Order';
}

include 'conn.php';
$connection = mysql_connect($local,$user,$pass) or die (mysql_errno().' : '.mysql_error().'<br />');
mysql_select_db($db);
$result = mysql_query($where);
$num = mysql_num_rows($result);
while ($row = mysql_fetch_array($result)){
    //echo here whatever u want from the rows fetched with matching tags
}

ここで使用されている方法はまもなく廃止されるため、データベース アクセスには PHP PDO の使用を開始する必要があります。

PDO マニュアル リンク

于 2012-08-04T03:38:25.530 に答える