ユーザーがデータを入力するために選択したフォーム フィールドに基づいて、mysql クエリを動的に生成する方法を学習しようとしています。学習プロセスをできるだけ簡単にするために、ユーザーの姓と名のフィールドを持つ単純なフォームを使用しています。コードの基本的な (非動的) バージョンは次のとおりです。
<html>
<head>
<title>Untitled</title>
</head>
<body>
<form method="post" name="test" action="dynamic_search.php">
<input type="text" name="first_name">
<input type="text" name="last_name">
<input type="submit" value="Submit">
</form>
<?php
$first_name = $_POST['first_name'];
$last_name = $_POST['last_name'];
include "link.php";
$query = "SELECT * FROM members " .
"WHERE first_name = '$first_name' " .
"AND last_name = '$last_name' ";
$result = mysql_query($query)
or die(mysql_error());
$row = mysql_fetch_array($result);
$member_id = $row['member_id'];
$member_first_name = $row['first_name'];
$member_last_name = $row['last_name'];
echo $member_id;
echo $member_first_name;
echo $member_last_name;
?>
</body>
</html>
私ができる必要があるのは、送信されたデータに基づいてクエリを生成することです。したがって、ユーザーが名前のみを入力すると、クエリは次のようになります。
$query = "SELECT * FROM members " .
"WHERE first_name = '$first_name' ";
ただし、ユーザーが姓と名の両方を入力すると、クエリは次のようになります。
$query = "SELECT * FROM members " .
"WHERE first_name = '$first_name' " .
"AND last_name = '$last_name' ";
どんな助けでも(または誰かが私に良いチュートリアルを教えてくれれば)大歓迎です!
ありがとう!