-3

そこで、PHP / mySQL検索とjavascript「ページあたりの結果のこの数を表示する」HTML選択があり、ユーザーが希望するページあたりの数で送信され、検索ページが更新される検索サイトを構築しています。残念ながら、ページを読み込んだときに3つのエラーが発生しました。if (isset($_POST['select'])){ $total_pages == $_POST['select'];}設定しただけ$total_pages = 12でうまくいきますか?

  • 注意:SQL構文にエラーがあります。36行目の/Users/Me/Sites/mySite/search.phpの1行目の''の近くで使用する正しい構文については、MySQLサーバーのバージョンに対応するマニュアルを確認してください。
  • 警告:mysql_num_rows()は、パラメーター1がリソースであると想定しています。ブール値は/Users/Me/Sites/mySite/search.phpの37行目にあります。
  • 警告:104行目の/Users/Me/Sites/mySite/search.phpでゼロ除算

コードは次のとおりです。

<?php

    $q = mysql_real_escape_string(ucfirst(trim($_REQUEST['searchquery'])));

        if (isset($q)){
        if (isset($_GET['page'])) $page = $_GET['page']; else $page = 1;
        if (isset($_POST['select'])){ $total_pages == $_POST['select'];} //Here edit the amount per page 
        $record_start = ($page * $total_pages) - $total_pages;
            REQUIRE('config.php');

            $result = mysql_query("SELECT * FROM companies WHERE company_name LIKE '%$q%' OR company_description LIKE '%$q%' OR cat1 LIKE '%$q' OR cat2 LIKE '%$q' OR cat3 LIKE '%$q' OR company_phone LIKE '%$q' ORDER by company_name LIMIT $record_start,$total_pages") or trigger_error(mysql_error());
            $rows = mysql_num_rows($result);

            $total_results = mysql_result(mysql_query("SELECT COUNT(*) as Num FROM companies"),0); 
            echo "
            <h4>Search for &quot;$q&quot;</h4>
             <div class='right'>
                <div class='textad1'>
                    <center>

                        <form name='form1' method='post'>
                            Results per Page:
                            <select name='select' onChange='document.form1.submit()'>
                                <option value='10'";if($_REQUEST['select'] == 12) {echo "selected='selected'";} echo">12</option>
                                <option value='15'";if($_REQUEST['select'] == 18) {echo "selected='selected'";} echo">18</option>
                                <option value='25'";if($_REQUEST['select'] == 32) {echo "selected='selected'";} echo">32</option>
                            </select>
                        </form>

                   </center>
                </div>
                <div class='divider'></div>
            </div>
            <div class='left'>

            <ul>";
        while($row = mysql_fetch_array($result))

さらにコードが必要な場合は、すぐに入手します。どんな助けでも大歓迎です!

4

1 に答える 1

1

あなたのコードはこのようにすべきだと思います、

require('config.php');
$q = mysql_real_escape_string(ucfirst(trim($_REQUEST['searchquery'])));

    if (isset($q)){
    if (isset($_GET['page'])) $page = $_GET['page']; else $page = 1;
    if (isset($_POST['select'])){ $total_pages = $_POST['select'];} //Here edit the amount per page 
    $record_start = ($page * $total_pages) - $total_pages;

        $result = mysql_query("SELECT * FROM companies WHERE company_name LIKE '%$q%' OR company_description LIKE '%$q%' OR cat1 LIKE '%$q' OR cat2 LIKE '%$q' OR cat3 LIKE '%$q' OR company_phone LIKE '%$q' ORDER by company_name LIMIT $record_start,$total_pages") or trigger_error(mysql_error());
        $rows = mysql_num_rows($result);

        $total_results = mysql_result(mysql_query("SELECT COUNT(*) as Num FROM companies"),0); 

//code continuation
于 2012-06-05T05:38:51.953 に答える