我正在尝试将查询的ID从一个数据库表传递到另一个与之相关的表。
但是,由于它们是相关的,因此我必须将其作为与之相关的实体(类)的实例传递。
这是我得到的错误:
传递给App \ Entity \ KeywordRating :: setKeywordId()的参数1必须是App \ Entity \ Keywords的实例,给定整数,在以下位置的C:\ xampp \ htdocs \ ratingAPI \ src \ Service \ KeywordRatingService.php中调用第26行
这是我的代码:
public function insertRating($params, ObjectManager $manager, KeywordsRepository $keyRep, ProvidersRepository $provRep)
{
$keywordId = $keyRep->checkKeyword(strtolower($params['keyword']))->getId();
$providerId = $provRep->checkProvider($params['provider'])->getId();
$rating = new KeywordRating();
$rating->setKeywordId(<Keywords instance> $keywordId);
$rating->setProviderId(<Providers instance> $providerId);
if($params['attr'] === 'rocks')
{
$rating->setRocksRating($params['rating']);
$rating->setSucksRating(0);
} else
{
$rating->setRocksRating(0);
$rating->setSucksRating($params['rating']);
}
$rating->setRocksVotes(10);
$rating->setSucksVotes(8);
$rating->setSumVotes(18);
$rating->setScore(2.50);
$manager->persist($rating);
$manager->flush();
}
这是sql查询:
public function checkKeyword($keyword)
{
return $this->createQueryBuilder('k')
->where('k.keyword_name = :val')
->setParameter('val', $keyword)
->getQuery()
->getOneOrNullResult();
}
checkProvider()相同,只是参数不同。
我该怎么做?
答案 0 :(得分:1)
假设您拥有一个名为Entities的命名空间,并且拥有所有实体类,则可以尝试如下操作:
$entityManager = $this->getDoctrine()->getManager();
$queryBuilder = $entityManager->createQueryBuilder();
$queryBuilder->select('keyword')
->from('App\Entity\Keywords', 'keyword')
->where($queryBuilder->expr()->eq('keyword.keyword_name', $queryBuilder->expr()->literal($keyword)));
$result = $queryBuilder->getQuery()-> getOneOrNullResult();
return $result;