Doctrine orm 原则Querybuilder,绑定参数
我的QueryManager的我的选择功能:Doctrine orm 原则Querybuilder,绑定参数,doctrine-orm,Doctrine Orm,我的QueryManager的我的选择功能: /** * Führt eine SELECT - Query durch * * @param $select = array( array(column, [...]), table, shortcut ) * $orderby = array(column, sorting-type) * $where = array( array( column, value, type[or, and] )
/**
* Führt eine SELECT - Query durch
*
* @param $select = array( array(column, [...]), table, shortcut )
* $orderby = array(column, sorting-type)
* $where = array( array( column, value, type[or, and] ), [...] )
* $innerjoin = array( table, shortcut, condition )
* $pagination = array( page, limit )
*
* @return array $data
*/
public function select($select,$orderby, $where, $innerjoin, $pagination)
{
$qb = $this->conn->createQueryBuilder()
->select($select[0])
->from($select[1], $select[2])
;
if ($orderby) {
$qb->orderBy($orderby);
}
if ($where) {
foreach($where as $cond) {
$x = 0;
if ( key($cond) == 0 ) {
$qb
->where($cond[0] . ' = ?')
->setParameter($x,$cond[1]);
}
elseif ( $cond[2] == 'and' ) {
$qb
->andWhere($cond[0] . ' = ?')
->setParameter($x,$cond[1]);
}
elseif ( $cond[2] == 'and' ) {
$qb
->orWhere($cond[0] . ' = :' . $x)
->setParameter($x,$cond[1]);
}
$x++;
}
}
if ($innerjoin) {
$qb->join($select[2],$innerjoin);
}
$this->sql = $qb->getSQL();
$this->totalRowCount = count( $qb->execute() ) ;
if ($pagination) {
$max = $pagination[0] * $pagination[1];
$first = $max - $limit;
$qb
->setFirstResult($first)
->setMaxResults($max)
;
}
$stmt = $qb->execute();
return $stmt->fetchAll();
}
我不知道为什么,但在实际操作中,此函数生成一个select查询,而不插入参数值:
/**
* Lädt einen User nach dessen Username
*
* @param $username
* @return User $user | null
*/
public function getUser($username)
{
if($data = $this->select(array('*','users','u'), null, array( array('username',$username) ), null,null)) {
return $user = $this->hydrate($data);
}
return null;
}
我没有得到结果,并且查询设置不正确:
array(0) { }
SELECT * FROM users u WHERE username = ?
在我看来,生成器不会用提供的值替代我的参数
我得到了最新版本的DBAL(2.4),这个版本应该支持这个特性
谢谢你的帮助和建议:)我也遇到了这个问题。我在这里读到: 不能将参数绑定到QueryBuilder,只能绑定到查询 但是,我正在创建SQL条件,作为深嵌套对象中的收集和/或表达式,而最顶层的对象将创建查询对象。所以我以前不能创建查询对象,我总是返回表达式对象 所以我用直接将变量包含到准备好的变量的位置来解决这个问题
$qb->where($cond[0] . '=' . $cond[1]);
因为我需要字符串,所以我添加了硬编码引号。这不是理想的方法,但目前我不知道如何通过将参数绑定到QueryBuilder对象来解决这个问题
$expr = $d_qb->expr()->between($t_c, "'" . $date_from . "'", "'" . $date_from . "'");
其他建议
以下代码结果:
$expr = $d_qb->expr()->between($t_c, ':from', ':to');
$d_qb->setParameter('from', 1);
$d_qb->setParameter('to', 1);
或
结果:
e0_.created BETWEEN ? AND ?
e0_.created BETWEEN ? AND ?