Home >Backend Development >PHP Tutorial >How Can I Safely Use LIKE '%{Var}%' with Prepared Statements in SQL?
Utilizing Prepared Statements with LIKE '%{Var}%' Effectively
When working with sanitized user input in SQL queries, it is recommended to employ prepared statements to mitigate the risk of SQL injection attacks. However, using the LIKE '%{Var}%' pattern with prepared statements can present challenges.
Incorrect Approach:
The following syntax will generate errors:
$sql = 'SELECT * FROM `users` WHERE username LIKE \'%{?}%\' ';
$sql = 'SELECT * FROM `users` WHERE username LIKE %{?}% ';
Correct Approach:
To use LIKE '%{Var}%' with prepared statements correctly, follow these steps:
$likeVar = "%" . $ yourParam . "%";
$ stmt = $ mysqli -> prepare('SELECT * FROM REGISTRY WHERE name LIKE ?');
$stmt -> bind_param('s', $likeVar);
$stmt -> execute();
Explanation:
By following these steps, you can safely use LIKE '%{Var}%' in your SQL queries while upholding security best practices.
The above is the detailed content of How Can I Safely Use LIKE '%{Var}%' with Prepared Statements in SQL?. For more information, please follow other related articles on the PHP Chinese website!