为什么我的会话数据会发生变化?

时间:2016-12-22 12:30:34

标签: php symfony session doctrine-orm

在symfony和Doctrine中我正在使用会话来保存查询结果,然后我将使用一些参数过滤此结果。 问题是一旦参数改变,我就无法获得原始结果集。这是代码

获取结果并保存到会话

$query = $this->getDoctrine()->getManager()->createQueryBuilder();
$query->select("sp")
->from("CoreBundle:ServiceProvider","sp")
->innerJoin("sp.offers","offer")
->innerJoin("offer.service","service","with","offer.service = service")
->innerJoin("sp.firstImage","fi")
->andWhere("sp.city = :city_name")->setParameter("city_name",$cityName)
->orderBy("sp.points" ,"DESC")
->addOrderBy("sp.name" ,"ASC");
$queryAndFilters = $this->getFilters($query,$postData);
$query = $queryAndFilters['query'];
$filters=$queryAndFilters['filters'];
$paginator  = $this->get('knp_paginator');
$pagination = $paginator->paginate(
    $query, /* query NOT result */
    $pageNumber,
    20/*limit per page*/
);

$query = $query->getQuery();
$query->setHint(\Doctrine\ORM\Query::HINT_INCLUDE_META_COLUMNS, true);

$this->get('session')->set("results",$query->getResult());

然后在另一个函数中

过滤结果

$results = $this->get('session')->get("results");

$filteredResults = array();

// print_r(array_keys($results[0]));
foreach($results as $result){
    $sp = $result;
    foreach($sp->getOffers() as $offer){
        // echo "found offer ".$offer->getName()." with price ".$offer->getPrice()."<br />";
        $sp->removeOffer($offer);
        if($offer->getPrice() < $minPrice || $offer->getPrice() > $maxPrice){

        }else{
            $sp->addOffer($offer);
            // echo 'added $offer '.$offer->getName()." with price : ".$offer->getPrice()."<br />";
        }
        if(sizeof($sp->getOffers()) > 0 ){
            array_push($filteredResults,$sp);
        }
    }
}

我第一次更改$ minPrice和$ maxPrice变量时,结果被正确过滤,正是我需要的 但在再次提高$ maxPrice之后,高价格没有被添加到$ filteredResults

我还尝试将$ offer和$ result分配给新变量,但仍无效 任何想法如何解决这个问题?

PS。我无法更改查询或使用查询获取它们。

1 个答案:

答案 0 :(得分:1)

当您在会话中保存实体时,此实体为serialized,其值为序列化时刻的实际值。如果您不在会话中重写实体,则实体的下一次更改不会影响存储的值。

同样有权序列化private属性{/ 3}}。