The design of the mysql_query
function is such that you've got to be careful to escape each and every bit of data you're injecting into it, and if you miss even one your entire application can be destroyed by an automatic SQL vulnerability exploit tool.
Both mysqli
and PDO support placeholders which are required to ensure that your queries are safe from SQL injection bugs. Calling mysql_real_escape_string
on everything is not only tedious, but error-prone, and that's where the problems arise.
The mysql
functions are a product of the very early days of PHP and are significantly more limited than the new object-oriented features offered by both mysqli
as an option, or PDO by design.
There's a number of very good reasons to use one of these two new interfaces, but the most important is that the mysql_query
function is simply too hazardous to use in production code. With it you will always be one mistake away from some very serious problems.
There's a reason rips of databases full of passwords and credit card numbers keep showing up. Having an obvious SQL injection point makes it almost too easy to completely take over a site.