MySQL UPDATE クエリでの値のインクリメント
MySQL UPDATE クエリでは、インクリメント値を手動で連結するよりも、直接インクリメントする方が効率的です。データベース内の既存の値。これにより、適切なポイント増分が確保されます。
間違った例:
以下のコードは、ユーザーのポイントを増分しようとしましたが、既存のポイントを増分値と連結するため失敗し、その結果、元の値の置き換え:
mysql_query(" UPDATE member_profile SET points= ' ".$points." ' + 1 WHERE user_id = '".$userid."' ");
修正メソッド:
値を適切にインクリメントするには、次のコードを使用します。
$sql = "UPDATE member_profile SET points = points + 1 WHERE user_id = ? ;"; $db->prepare($sql)->execute([$userid]);
このコードは、準備されたステートメントとプレースホルダーを使用して、インクリメント操作を安全に処理します。最新の PHP バージョンでは PDO と mysqli の両方で動作します。この方法を使用すると、データベースが既存のポイント値を自動的に増分し、正確なポイント更新を保証します。
以上がMySQL UPDATE クエリで値を効率的にインクリメントするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。