首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >PDOException SQLSTATE[HY093]:yii-2 where和between查询

PDOException SQLSTATE[HY093]:yii-2 where和between查询
EN

Stack Overflow用户
提问于 2014-11-20 18:20:09
回答 1查看 819关注 0票数 0

经过长时间的研究,我找不到PDOException SQLSTATEHY093的确切解决方案,我正在使用yii 2框架,并且在使用between条件时出现问题。

代码语言:javascript
复制
$query = SalesOrder::find()->where(['between','created_date', ':fromDate', ':toDate']); 
$query->addParams([':fromDate' => $salesReport->fromDate,':toDate' => $salesReport->toDate]);
$query->all();

已尝试不同的方法解决相同的问题。

代码语言:javascript
复制
$qString1=':fromDate';
$qString2=':toDate';

$query = SalesOrder::find()->where(['between','created_date',$qString1,$qString2]); 
$query->addParams([':fromDate' => $salesReport->fromDate],[':toDate' => $salesReport->toDate]);
        $query->all();

由: PDOException SQLSTATEHY093:无效参数数:绑定变量数与令牌数不匹配

EN

回答 1

Stack Overflow用户

发布于 2014-11-27 11:24:10

这种情况下不能传递参数名。尝试:

代码语言:javascript
复制
$query = SalesOrder::find()->where(['between','created_date', $salesReport->fromDate, $salesReport->toDate]);
$query->all();

或者,如果您想使用参数,请尝试:

代码语言:javascript
复制
$query = SalesOrder::find()->where('created_date BETWEEN :fromDate AND :toDate'); 
$query->addParams([':fromDate' => $salesReport->fromDate],[':toDate' => $salesReport->toDate]);
$query->all();
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/27037048

复制
相关文章

相似问题

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