对于我正在构建的网站,我需要检查一个位置是否有合同,这些位置可以有直接链接到它们的合同,或者当较大组织的一部分也有链接到该组织的合同时。
我正在尝试使用 DQL 查询首先检查是否有直接链接的合同,然后是否有任何通过组织与此查询链接的合同:
$q = self::createQuery("l")
->select('sl.sc_id, sl.type, so.sc_id, so.type, l.naam, l.loc_id, l.straat, l.telefoon, l.plaats, l.postcode, l.huisnummer, l.huisnummer_achtervoegsel, o.naam')
->from('Locatie l, l.Organisatie o, l.Sc sl, o.Sc so')
->orderBy('o.naam, l.naam')
->execute();
它做了我想要的,它返回一个包含我需要的所有数据的数组:
array(13) {
["loc_id"]=> string(2) "93" ["org_id"]=> string(1) "9" ["naam"]=> string(12) "test"
["Organisatie"]=> array(4) { ["org_id"]=> string(1) "9" ["naam"]=> string(3) "test"
["Sc"]=> array(1) { [0]=> array(6) { ["sc_id"]=> string(1) "1" ["sc_nummer"]=> NULL ["type"]=> string(6) "All-in" } } }
["Sc"]=> array(0) { }
}
问题是重复的 ["Sc"] 键,因为在 php 中,当数组有重复的键时,最后一个键会覆盖第一个键(无论如何我都读过),这使得无法进行如下检查:
if(!empty($SC) or !empty($SC2) {}
我似乎无法弄清楚如何使学说名称成为不同的键之一,甚至可能将两者合并。
我尝试使用INDEXBY
,但这改变了 ['SC'] 数组中的键,而不是 ['SC'] 本身。
有任何想法吗?