首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何避免Heredoc SQL语句

如何避免Heredoc SQL语句
EN

Stack Overflow用户
提问于 2014-02-21 02:28:02
回答 1查看 612关注 0票数 2

如何避免在SQL语句中使用Heredoc字符串分隔符?或者更好的问题是,在PHP中创建和调用SQL语句的现代方法是什么?

我对php比较陌生。我经常在我正在做的项目中看到这样的事情:

代码语言:javascript
复制
        $sql = <<<SQL
SELECT
    `data`.`key`,
FROM `tableName`
ORDER BY `data`.`key`
SQL;

在研究更多关于Heredoc的信息时(我不得不使用SQL来找到它的名字),我感觉还有更好的方法来编写SO symbol reference语句。用户会说他们使用了Heredoc For SQL "back in the day“。

使用Heredoc似乎不是最好的解决方案,因为很小的格式更改就可以mess it up。不能缩进结束标记会使代码更难阅读和格式化。看起来仅仅使用Heredoc就会鼓励使用SQL语句和逻辑来乱丢代码。

这只是“完成它的方式”,还是有更好的方法?

This question about managing your SQL queries来自6年前。5年前的PDO or an ORM are mentioned in this answer。这些仍然是最好的方式吗?

EN

回答 1

Stack Overflow用户

发布于 2014-02-21 02:30:57

您的HEREDOC语句没有任何错误,但是这里有另一种通过引用字符串来创建$sql变量的方法。

代码语言:javascript
复制
$sql = "SELECT `data`.`key`, FROM `tableName` ORDER BY `data`.`key`";

在需要额外可读性的较长语句的情况下,您可以利用空白被忽略的事实:

代码语言:javascript
复制
$sql = "SELECT `data`.`key`, 
    FROM `tableName`
    ORDER BY `data`.`key`";

还可以考虑以面向对象的方式使用PDO进行数据库交互:http://www.php.net/PDO

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/21916457

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档