gpt4 book ai didi

mysql - Doctrine2和where sql语句

转载 作者:行者123 更新时间:2023-11-28 23:25:30 24 4
gpt4 key购买 nike

我有一个这样写的学说查询:

    $qb = $this->createQueryBuilder('u');

$qb
->leftJoin('u.relatedEventTypes', 'relatedEventTypes')
->leftJoin('u.relatedGenres', 'relatedGenres')
->where(
$qb->expr()->eq('u.type', ':userType')
)
->setParameter('userType', 'dj')
;

我想再添加一个 where 语句,用于查找两个坐标之间的距离并处理该数据。查询看起来像这样:

    $qb
->andWhere(
'( 6371 * acos( cos( radians(lat_placeholder) ) * cos( radians(lat_placeholder) ) * cos( radians(lng_placeholder) - radians(lng_placeholder) ) +
sin( radians(lat_placeholder) ) * sin( radians(la t_placeholder) ) ) ) AS distance
HAVING distance < distanceToTravel_placeholder)'
;

我找不到一种方法来完成这项工作,这意味着我不知道如何用占位符编写它,所以我可以从一开始就使用查询中的变量(例如 u.locLat、u.distanceToTravel 等) .可能吗?

最佳答案

我认为 doctrine 无法处理所有函数,如 acos、cos 和弧度。你应该看看 Doctrine DBAL或学说 native queries其中 DBAL 看起来像 PDO, native 查询为您提供了使用普通 mysql 查询填充实体的可能性。

关于mysql - Doctrine2和where sql语句,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39561459/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com