编写 PHP SQL 更新语句的最佳方法

Best way to write PHP SQL Update Statement(编写 PHP SQL 更新语句的最佳方法)
本文介绍了编写 PHP SQL 更新语句的最佳方法的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有这个 PHP SQL 语句:

I have this PHP SQL statement:

$updateCategory = "UPDATE category 
                   SET name=".$name.", description=".$description.",
                       parent=".$parent.", active=".$active." 
                   WHERE id=".$catID."";

最好的写法是什么?

谢谢,

克里斯.

推荐答案

我建议你使用prepared statements而不是将查询字符串连接在一起:

I suggest you use prepared statements instead of concatenating the query string together:

$sql = 'UPDATE 
           category
        SET
           name=:name,
           description=:description,
           parent=:parent, 
           active=:active
        WHERE
           id=:catID';

如果您使用的是 PDO,我强烈建议您这样做:p>

if you are using PDO, which I strongly suggest, you would then call it like this:

$params = array(
    ':name'        => $name,
    ':description' => $description,
    ':parent'      => $parent,
    ':active'      => $active,
    ':catID'       => $catID
);

$stmt = $pdo->prepare($sql);
$stmt->execute($params);

您可能会问,为什么要这么麻烦?"这种方法的优势非常明显:

You might ask, "why all this hassle?" The advantages of this approach are quite overwhelming:

  • 您不必关心 SQL 注入,因为数据库驱动程序现在可以处理输入参数的正确转换
  • 您不必关心转义特殊字符,但您可以专注于您想要实现的目标,而不是如何实现它:-)

这篇关于编写 PHP SQL 更新语句的最佳方法的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Convert JSON integers and floats to strings(将JSON整数和浮点数转换为字符串)
in php how do I use preg replace to turn a url into a tinyurl(在php中,如何使用preg替换将URL转换为TinyURL)
all day appointment for ics calendar file wont work(ICS日历文件的全天约会不起作用)
trim function is giving unexpected values php(Trim函数提供了意外的值php)
Basic PDO connection to MySQL(到MySQL的基本PDO连接)
PHP number_format returns 1.00(Php number_Format返回1.00)