phpstorm MySQL更名_phpstorm MySQL-Dialect字符串用php构建

在我的项目中,我使用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分析.

标签:php,mysql,phpstorm

来源: https://codeday.me/bug/20190702/1360691.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值