現在、次のように、非推奨のコードを使用してユーザーからデータを取得しています。
/* retrieve */
$lastName = $_POST['lastName'];
$firstName = $_POST['firstName'];
$examLevel=$_POST['level'];
/* connect */
$dbc=mysql_connect("localhost", "user", "passw") or die('Error connecting to MySQL server');
mysql_select_db("db") or die('Error selecting database.');
/* sanitize */
$lastName=mysql_real_escape_string($lastName);
$firstName=mysql_real_escape_string($firstName);
$examLevel=mysql_real_escape_string($examLevel);
/* insert */
$query_personal = "INSERT INTO personal (LastName, FirstName) VALUES ('$lastName', '$firstName')";
$query_exam = "INSERT INTO exam (Level, Centre, BackupCentre, etc.) VALUES ('$examLevel', '$centre', '$backup', 'etc')";
これは機能していますが、セキュリティとサポートの欠如に関する警告に出くわします。mysql の代わりに mysqli に接続するように少し書き直しましたが、 mysqli_real_escape_stringはどうですか? 例で使用されているのを見たことがありますが、代わりに mysqli_real_escape_string を使用しないプリペアド ステートメントを使用するというアドバイスも見ました。
また、準備済みステートメントを使用してデータを挿入するにはどうすればよいでしょうか? これまでのところ、私はこのビットで少し海にいます。たとえば、パラメーター バインディングは INSERT のみ、結果バインディングは SELECT のみですか?