public function saveProductHasSaleList($con = null) { if (!$this->isValid()) { throw $this->getErrorSchema(); } if (!isset($this->widgetSchema['product_has_sale_list'])) { // somebody has unset this widget return; } if (null === $con) { $con = $this->getConnection(); } $c = new Criteria(); $c->add(ProductHasSalePeer::SALE_ID, $this->object->getPrimaryKey()); ProductHasSalePeer::doDelete($c, $con); $values = $this->getValue('product_has_sale_list'); if (is_array($values)) { foreach ($values as $value) { $obj = new ProductHasSale(); $obj->setSaleId($this->object->getPrimaryKey()); $obj->setProductId($value); $obj->save(); } } }
/** * Adds an object to the instance pool. * * Propel keeps cached copies of objects in an instance pool when they are retrieved * from the database. In some cases -- especially when you override doSelect*() * methods in your stub classes -- you may need to explicitly add objects * to the cache in order to ensure that the same objects are always returned by doSelect*() * and retrieveByPK*() calls. * * @param ProductHasSale $value A ProductHasSale object. * @param string $key (optional) key to use for instance map (for performance boost if key was already calculated externally). */ public static function addInstanceToPool(ProductHasSale $obj, $key = null) { if (Propel::isInstancePoolingEnabled()) { if ($key === null) { $key = serialize(array((string) $obj->getProductId(), (string) $obj->getSaleId())); } // if key === null self::$instances[$key] = $obj; } }