0

我需要找到一种方法来过滤来自 MongoDB 数据库的结果,基于在当前表中找到的字段,以及在链接到当前表的另一个表中找到的字段。表格格式:

{
   "_id": ObjectId("51af256a0da4dd7804000007"),
   "enddate": ISODate("2013-06-14T21:00:00.0Z"),
   "main": false,
   "name": "name 1",
   "photo": "image-1.jpg",
   "site": {
     "$ref": "Sites",
     "$id": ObjectId("51ac538c5f06751414bd9f98"),
     "$db": "local"
  },
   "startdate": ISODate("2013-04-30T21:00:00.0Z")
}   

{
   "_id": ObjectId("51d3d5b9caa8213b12e92c5e"),
   "sitefeatured": false,
   "sitename": "a",
   "sitephoto": "aa.jpg",
   "siteurl": "aaaa.com/"
}   

我在->where子句中尝试做的是在this.namethis.site.sitename形成的字符串中搜索:我的问题是我不知道/没有找到如何引用属性sitename网站对象的

$entries = $dm
                        ->getRepository($sTable)
                        ->createQueryBuilder('o')
                            ->where('function() { return ( (this.name + this.site.sitename).toLowerCase().indexOf("'.$_GET['sSearch'].'".toLowerCase()) !== -1 ) ? true : false }')
                            ->sort($aColumns[$_GET['iSortCol_0']], $_GET['sSortDir_0'])
                            ->limit($_GET['iDisplayLength'])
                            ->skip($_GET['iDisplayStart'])
                            ->getQuery()
                            ->execute();

有没有我没有遇到过的类似 SQL 连接的东西,或者解决方案是什么?

4

0 回答 0