real_escape_string vs. prepared statements

2020-02-15 05:43发布

is there any reason to use one over the other in terms of speed and safety? Thanks!

标签: php mysqli
1条回答
叼着烟拽天下
2楼-- · 2020-02-15 06:24

Speed:

  • When you use bind parameters you can reuse the same query and query plan, just changing the parameters. When you build a query from strings the database has to reparse the statement.
  • With bind parameters the SQL parser also has less work to do. The parameters aren't escaped so the parsing is simpler.

Safety:

  • In my opinion, it is much easier to remember to use parameters than to remember to escape strings.
查看更多
登录 后发表回答