在我的项目中,我使用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 or UNION expected, got ‘$(‘
只有在PHPvariable中有一个查询元素时才会出现此问题.我该如何解决这个问题?
解决方法:
PHPStorm很可能会引发您的错误,因为sql检查功能不足以执行可变扩展的分析.
它可能不是一个错误,只是检查员无法使用在查询上注入的PHP变量进行完整的sql分析.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。