如何在没有本机查询的情况下使教义查找到JSON字段 [英] How make doctrine findby to json field without native query
本文介绍了如何在没有本机查询的情况下使教义查找到JSON字段的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我使用doctrine 2
中的json
列(在MySQL
数据库中).
实际上,我是使用
$rsm = new ResultSetMappingBuilder($entityManager);
$rsm->addRootEntityFromClassMetadata(\blabla\MyObject::class, 'o');
$query = $entityManager->createNativeQuery('select o.* from my_objects o where json_extract(jsonData, "$.test.key1")= "value1"', $rsm);
//jsonData column contains {"test": {"key1" : "value1"}}
$result = $query->getResult();
之类的本机查询在json
中进行搜索的
$rsm = new ResultSetMappingBuilder($entityManager);
$rsm->addRootEntityFromClassMetadata(\blabla\MyObject::class, 'o');
$query = $entityManager->createNativeQuery('select o.* from my_objects o where json_extract(jsonData, "$.test.key1")= "value1"', $rsm);
//jsonData column contains {"test": {"key1" : "value1"}}
$result = $query->getResult();
是否可以在没有本机查询机制的情况下进行类似的查询? (如findBy)
在此先感谢您的帮助;)
解决方案
我解决了我的问题. 我找到了DQL的扩展名.
$queryBuilder = $entityManager->createQueryBuilder();
$query = $queryBuilder
->select("o")
->from(\bla\bla\MyObject::class, "o")
->where("JSON_EXTRACT(o.jsonData, :jsonPath) = :value ")
->setParameter('jsonPath', '$.test.key1')
->setParameter('value', 'value1')
->getQuery();
$co = $query->getResult();
I use json
column in doctrine 2
(In MySQL
database).
Actually, I made my search in json
with native query like
$rsm = new ResultSetMappingBuilder($entityManager);
$rsm->addRootEntityFromClassMetadata(\blabla\MyObject::class, 'o');
$query = $entityManager->createNativeQuery('select o.* from my_objects o where json_extract(jsonData, "$.test.key1")= "value1"', $rsm);
//jsonData column contains {"test": {"key1" : "value1"}}
$result = $query->getResult();
Is it possible the made query like that without the native query mechanism ? (like a findBy)
Thanks in advance for your help ;)
解决方案
I solved my problem. I found this extension of DQL .
$queryBuilder = $entityManager->createQueryBuilder();
$query = $queryBuilder
->select("o")
->from(\bla\bla\MyObject::class, "o")
->where("JSON_EXTRACT(o.jsonData, :jsonPath) = :value ")
->setParameter('jsonPath', '$.test.key1')
->setParameter('value', 'value1')
->getQuery();
$co = $query->getResult();
这篇关于如何在没有本机查询的情况下使教义查找到JSON字段的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文