0

食肉包装データベースを検索するマルチフォーム検索ボックスを作成しています。検索は、ユーザーが特定されている場合にのみ機能します。特定のオプションを選択しなくてもデータベースを検索できるようにしたいと考えています。フォーム ボックスのうち 3 つは、ユーザーが幅、高さ、深さのすべての数値を検索するためのものですが、ユーザーがサイズを正確に指定した場合にのみ結果が返されます。ユーザーが入力した値と完全に一致するものが見つからない場合に、検索で最も近い値を返すことができるようにしたいと考えています。

そのような:

ユーザーが幅ボックスに「252」を入力すると、現在「検索が見つかりません」が返されますが、データベースには「251」があります。したがって、ユーザーが「252」と入力すると、SQL クエリは自動的に最も近いサイズを検索し、理論上は「251」と表示します。

HTMLとPHPは次のとおりです。

<body>

    <form action="form3.php" method="post"> 
      <label for ="description">Description:</label>
      <input type="text" name="descrip" /><br />

      <label for ="trayheight">Trayheight:</label>
      <input type="text" name="height" /> <br /> 

      <label for ="traywidth">Traywidth:</label>
      <input type="text" name="width" /> <br />

      <label for ="traydepth">Traydepth:</label>
      <input type="text" name="depth" /> <br />

      <label for="trayrange">Trayrange: </label>
                <select name="trayrange">
                    <option value=""></option>

                    <option value="BBQ">BBQ</option>

                    <option value="Dessert">Dessert</option>

                    <option value="Display">Display</option>

                    <option value="Meat">Meat</option>   

                    <option value="Microwave">Microwave</option>

                    <option value="Party">Party</option>

                    <option value="Salad/Wet Pasta">Salad/Wet Pasta</option>

                    <option value="Snacks">Snacks</option>

                    <option value="Standard">Standard</option>

                </select>

        <label for ="traytype">Traytype: </label> 
            <select name="traytype">
                    <option value=""></option>

                <option value="Open">Open</option>

            <option value="Cavitised">Cavitised</option>

                    <option value="Lid">Lid</option>

                    <option value="Tray">Tray</option>

                    <option value="Coallition">Coallition</option>

                    <option value="Bowl">Bowl</option>

                    <option value="Hinge pack">Open</option>

                    <option value="Pot">Pot</option>

                    <option value="Base & Lid">Base and Lid</option>

                    <option value="Rectangular">Rectangular</option>

                    <option value="Specalist">Specialist</option>
            </select><br />

        <label for="trayshape">Trayshape: </label>
            <select name="trayshape">
                    <option value=""></option>

            <option value="Rectangular">Rectangular</option>

                <option value="Oval">Oval</option>

                <option value="Square">Square</option>

                    <option value="Insert">Insert</option>

                    <option value="Round">Round</option>

                    <option value="Open">Open</option>
            </select><br />

        <input type="submit" value="Submit" /> 
    </form> 

    </body>

そしてPHP:

   <body>

 <?php
    $con = mysql_connect ("localhost", "root", "");
           mysql_select_db ("delyn_db", $con);

    if (!$con)
        { 
         die ("Could not connect: " . mysql_error());
        }

            $descrip = mysql_real_escape_string($_POST['descrip']); 
            $height  = mysql_real_escape_string($_POST['height']);
            $width   = mysql_real_escape_string($_POST['width']);
            $depth   = mysql_real_escape_string($_POST['depth']);

            $varRange = mysql_real_escape_string($_POST['trayrange']);
            $varType  = mysql_real_escape_string($_POST['traytype']);
            $varShape = mysql_real_escape_string($_POST['trayshape']);
            $varImage = mysql_real_escape_string($_POST['imagename']);

            $sql = "SELECT * FROM delyn WHERE 
                        description LIKE '%".$descrip."%' 
                    AND trayheight LIKE '%".$height."%' 
                    AND traywidth LIKE '%".$width."%' 
                    AND traydepth LIKE '%".$depth."%' 
                    AND trayrange LIKE '%".$varRange."%' 
                    AND traytype LIKE '%".$varType."%' 
                    AND trayshape LIKE '%".$varShape."%' ";


            $r_query = mysql_query($sql);

                    while ($row = mysql_fetch_array($r_query))
                { 
                echo '<br /> Tool Code:   '. $row['toolcode'];
                echo '<br /> Description: '. $row['description']; 
                echo '<br /> Tray range:  '. $row['trayrange']; 
                echo '<br /> Tray type:   '. $row['traytype'];
                echo '<br /> Tray size:   '. $row['traysize']; 
                echo '<br /> Tray shape:  '. $row['trayshape'];  
                    echo '<br /> <img src="   '. $row['imagename'] . '"
                                    width="200" length="100">' . '<br />' . '<br />';  
                    }

                if (mysql_num_rows($r_query) <= 0){
                    echo 'No results match your search, please try
                                                  again';
                                  }
        ?>
                </body>

誰かがそれを助けることができれば、前もって感謝します:)

編集:

   <body>
        $scope = 20;
                $width_min = $width - $scope;
                $width_max = $width + $scope;
                $depth_min = $depth - $scope;
                $depth_max = $depth + $scope;
                $height_min = $height - $scope;
                $height_max = $height + $scope;

            $sql = "SELECT * FROM delyn WHERE 
                        description LIKE '%".$descrip."%' 
                    AND traywidth LIKE '%".$width."%'   
                    AND traydepth LIKE '%".$depth."%' 
                    AND trayheight LIKE '%".$height."%'
                    AND trayrange LIKE '%".$varRange."%' 
                    AND traytype LIKE '%".$varType."%' 
                    AND trayshape LIKE '%".$varShape."%'";

                if ($row = 0) {
            $sql = "SELECT * FROM delyn WHERE 
                        description LIKE '%".$descrip."%' 
                    AND (traywidth BETWEEN ".$width_min." AND ".$width_max.")  
                    AND (traydepth BETWEEN ".$depth_min." AND ".$depth_max.")  
                    AND (trayheight BETWEEN ".$height_min." AND ".$height_max.")  
                    AND trayrange LIKE '%".$varRange."%' 
                    AND traytype LIKE '%".$varType."%' 
                    AND trayshape LIKE '%".$varShape."%'";
                }
    <body>
4

2 に答える 2

1

固定の「上」および「下」マージンを使用する代わりに、テーブルのトレイ幅とユーザーが入力した幅の間の絶対計算に基づいて、エントリのリストを並べ替えることができます。このようなもの:

select d.*, abs(d.traywidth - USER_SEARCH_INPUTTED_WIDTH) as WIDTH_ABS from delyn d order by WIDTH_ABS limit 20;

これにより、「USER_SEARCH_INPUTTED_WIDTH」に基づいて近くのトレイ幅のリストが表示されます。たとえば、ユーザーが何を求めているか、およびデータベースに実際にあるエントリからの相対的な「距離」として 252 です。

注:検索を許可しているすべての列は署名する必要があります。そうしないと、ファンキーな結果になります(absによる)。

于 2012-10-09T14:44:31.870 に答える
0

SQL BETWEEN 演算子を使用できます。

于 2012-10-09T14:24:37.513 に答える