MySQL では、アポストロフィ (一重引用符) を含む挿入クエリで構文エラーが発生する可能性があります。 「SQL 構文にエラーがあります...」というエラー、特にアポストロフィが発生した場合、データの挿入を確実に成功させるための解決策があります。
重要な解決策は、バックスラッシュ (\) を使用してアポストロフィをエスケープすることです。 ) キャラクター。たとえば、文字列「Kellog's」は「Kellogg\'s」と記述する必要があります。アポストロフィをバックスラッシュでエスケープすると、MySQL は次の文字を構文インジケーターではなくリテラルとして解釈します。
さらに、挿入用のデータを準備するときに MySQL の mysql_real_escape_string() 関数を利用することをお勧めします。この関数は、アポストロフィを含む特殊文字を自動的にエスケープし、潜在的な SQL インジェクションに対する包括的な保護策となります。次の例を考えてみましょう。
function insert($database, $table, $data_array) {
$mysql_connect = connect_to_database();
mysql_select_db($database, $mysql_connect);
foreach ($data_array as $key => $value) {
$tmp_col[] = $key;
$tmp_dat[] = "'" . mysql_real_escape_string($value) . "'"; // Escaping
}
$columns = join(',', $tmp_col);
$data = join(',', $tmp_dat);
$sql = 'INSERT INTO ' . $table . '(' . $columns . ')VALUES(' . $data . ')';
$result = mysql_query($sql, $mysql_connect);
if (!$result) {
echo 'MySQL Update Error: ' . mysql_error($mysql_connect);
$result = '';
} else {
return $result;
}
}
このメソッドを使用すると、構文エラーやセキュリティ脆弱性を発生させることなく、アポストロフィを含むデータを MySQL テーブルに挿入できます。
免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。
Copyright© 2022 湘ICP备2022001581号-3