gpt4 book ai didi

php - 带有参数数组的 SQL 请求

转载 作者:行者123 更新时间:2023-11-29 18:45:49 24 4
gpt4 key购买 nike

我的 SQL(dql) 请求有问题,我有一个包含书籍(媒体)的表,一个包含类别的表,以及一个将两者关联的表:CategoryAffiliation(一本书可以有多个类别)

在客户端,我可以选择通过检查多个类别来搜索书籍。然后客户端向服务器发送一系列类别,并且他必须返回至少具有其中一个类别的书籍。

$books = [];
if (isset($data['categories'])) {
foreach ($data['categories'] as $key => $value){
$query = $em->createQuery("SELECT m
FROM AppBundle:Media m, AppBundle:Category c, AppBundle:CategoryAffiliation mc
WHERE m.idMedia = mc.idMedia
AND mc.idCategory = :key
GROUP by m.idMedia"
)->setParameter('key',$key);
$result = $query->getResult();
foreach ($result as $book) {
array_push($books, $book);
}
}
}

这是我现在的解决方案,但这不太好,我无法按结果排序..我收到一组重复的书籍,然后在客户端合并它们以删除重复的书籍。

我正在寻找一种方法,可以通过一个请求一次性获取所有数据

谢谢

最佳答案

我无法访问我的东西来测试它,但这可以做到。我只是不确定 setParameter 将如何处理我将 ' 放入字符串中的事实。我认为您需要获取原始信息。我不记得 symfony 和原则是如何做到这一点的,太久了;)

如果你找不到其他方法,你可以直接在字符串中构建它......我真的不推荐。

$query = $em->createQuery("SELECT m
FROM AppBundle:Media m, AppBundle:Category c, AppBundle:CategoryAffiliation mc
WHERE m.idMedia = mc.idMedia
AND mc.idCategory IN (:key)
GROUP by m.idMedia"
)->setParameter('key',implode("','",array_keys($data['categories'])));

关于php - 带有参数数组的 SQL 请求,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44659441/

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