phpstorm MySQL-Dialect字符串用php构建

时间:2015-04-14 10:27:19

标签: php mysql phpstorm

在我的项目中,我使用MySQL,因此配置PhpStorm使用MySQL方言进行查询检查。 我有一个使用普通SQL和PHP变量构建的MySQL查询。

我们假设我有以下代码

$headline = 'Berlin';
$additional = (rand(1,5) > 2) ? ' AND t.public = 1' : '';
$query = "SELECT * FROM tours t WHERE t.headline = '". $headline . "'" . $additional .";";

如果我打印查询,它可能看起来像这样

SELECT * FROM tours t WHERE t.headline = 'Berlin' AND t.public = 1;

SELECT * FROM tours t WHERE t.headline = 'Berlin';

两个查询都是正确的。但是,PhpStorm在以下部分显示错误

>'"< . $additional .";";

带有消息

  

FOR,GROUP,HAVING,INTO,LIMIT,LOCK,ORDER,PROCEDURE或UNION预期,得到了&#39; $(&#39;

只有在phpvariable中有查询元素时才会出现问题。我该如何解决这个问题?

1 个答案:

答案 0 :(得分:2)

PHPStorm很可能会引发您的错误,因为SQL检查功能不足以执行可变扩展的分析。

它可能不是一个错误,只是检查员无法使用在查询上注入的PHP变量进行完整的SQL分析。