0

人々が私のウェブサイトに来て、次の情報を入力するための小さなフォームを作成しようとしています:

  • 名前
  • 電子メールアドレス

この情報をデータベースからテーブルに送り返す必要があります。

ここで、物事が「複雑」になります (...まあ、私にとってはそうですよね?)

メールアドレスがテーブルに存在する場合は、「メールアドレスが追加されました。ありがとうございます!」と表示される必要があります。存在しない場合は、「Email address already exists!」をエコーする必要があります。

何らかの理由でこれを行っていません。このエラーを吐き出しています:

Fatal error: Call to a member function fetch_assoc() on a non-object in C:\wamp\www\addemail.php on line 46

私のphpコードを添付しました(以下):

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">

<html lang="en">

<head>

<script LANGUAGE="JavaScript">
<!--
function redirect () { setTimeout("go_now()",3000); }
function go_now ()   { window.location.href = "newsletter_frame.html"; }
//-->
</script>

<!-- This is the link to the external CSS file-->
<link rel="stylesheet" type="text/css" href="css/mystyle.css">

<!-- This is the link to the external Javascript file-->
<script type="text/javascript" src="js/myjs.js"></script>

<title>Page</title>

<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<meta name="verify-v1" content="gDSxHR1Tk8vWtty9GoRHABGFEH+Bh2VHYCHv0Cx1/Ek=">
<meta name="copyright" content="Burger man">
<meta name="keywords" content="afro, afrodeep, soulful, funky, deep, vocal house, broken beats, disco">
<meta name="description" content="Burgers and chips">
<meta name="page-type" content="Information">

</head>
    <body  onLoad="redirect()" id="iframe_newsl_spec">

        <?php
            $dbc = mysqli_connect('localhost', 'root', '', 'si_store') or die('Error connecting to MySQL server.');

                if ( isset($_POST['email_address']) && isset($_POST['firstname']) && isset($_POST['surname']) )
                    {
                        $email_address = $_POST['email_address'];
                        $firstname = $_POST['firstname'];
                        $surname = $_POST['surname'];

                        $query = mysqli_query("SELECT * FROM email_list WHERE email_address = '$email_address'");

                        if ( mysql_num_rows($query) > 0)
                        {
                            echo 'Email address already exists!';
                        }
                        else
                        {
                            mysqli_query("INSERT INTO email_list(email_address, firstname, surname) VALUES ('$email_address','$firstname','$surname')");

                            echo 'Email Address Added. Thank you!';
                        }   
                    }

            //mysqli_query($dbc, $query) or die ('Error connecting to database.');

            mysqli_close($dbc);
        ?>



    </body>
</html>
4

1 に答える 1

0

mysql_*関数を修正してに変更しmysqli_*準備済みステートメントを使用するようにコードを変更たら、次のコードを追加する必要があります。

$stmt = mysqli_prepare('SELECT * FROM email_list WHERE email_address = ?');
//BTW, if all you want to check if a record exists, don't use SELECT *
//Just select one field, not the entire row
mysqli_stmt_bind_param($stmt,'s',$_POST['email_address']);
//bind param, to statement, as String, value ^^
mysqli_stmt_execute($stmt);
//execute the query
mysqli_stmt_bind_result($stmt,$col1,$col2,$col3);
//bind variables that will be assigned the value of the fields
while(mysqli_stmt_fetch($stmt))
{//get the values in question
    echo 'col1: '.$col1.'<br/>col2: '.$col2.'<br/>col3: '.$col3.'<br/>';
}

結果セットの連想配列を取得するには、使用したい関数がいくつかあるドキュメントを読む必要があります。

于 2012-10-05T12:46:42.243 に答える