本文整理匯總了PHP中PartnerPeer::getPartnerPriorityFactorByPartner方法的典型用法代碼示例。如果您正苦於以下問題:PHP PartnerPeer::getPartnerPriorityFactorByPartner方法的具體用法?PHP PartnerPeer::getPartnerPriorityFactorByPartner怎麽用?PHP PartnerPeer::getPartnerPriorityFactorByPartner使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類PartnerPeer
的用法示例。
在下文中一共展示了PartnerPeer::getPartnerPriorityFactorByPartner方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: updatePartnerLoad
public static function updatePartnerLoad($partnerId, $jobType, $jobSubType = null, PropelPDO $con = null)
{
$partner = PartnerPeer::retrieveByPK($partnerId);
$priorityFactor = PartnerPeer::getPartnerPriorityFactorByPartner($partner);
$maxQuota = $partner->getJobTypeQuota($jobType, $jobSubType);
if (!$maxQuota) {
$maxQuota = BatchJobLockPeer::getMaxJobsForPartner($jobType);
}
$dcId = kDataCenterMgr::getCurrentDcId();
// Hack to avoid the not-null constaint on job sub type
if (is_null($jobSubType)) {
$jobSubType = 0;
}
$c = new Criteria();
$c->add(self::PARTNER_ID, $partnerId);
$c->add(self::JOB_TYPE, $jobType);
$c->add(self::JOB_SUB_TYPE, $jobSubType);
$c->add(self::DC, $dcId);
$oldPartnerLoad = self::doSelectOne($c);
if ($oldPartnerLoad === null) {
try {
// Try to insert new entry
$partnerLoad = new PartnerLoad();
$partnerLoad->setPartnerId($partnerId);
$partnerLoad->setJobType($jobType);
$partnerLoad->setJobSubType($jobSubType);
$partnerLoad->setPartnerLoad(1);
$partnerLoad->setDc($dcId);
$partnerLoad->setWeightedPartnerLoad($priorityFactor);
$partnerLoad->setQuota($maxQuota - 1);
$res = $partnerLoad->save();
if ($res == 1) {
return;
// if we arrived here, it means the insert was successful
}
} catch (Exception $e) {
// probably a unique constraint - use the updae version below
}
}
$table = PartnerLoadPeer::TABLE_NAME;
$colPartnerLoad = PartnerLoadPeer::PARTNER_LOAD;
$colWeightedPartnerLoad = PartnerLoadPeer::WEIGHTED_PARTNER_LOAD;
$colJobType = PartnerLoadPeer::JOB_TYPE;
$colJobSubType = PartnerLoadPeer::JOB_SUB_TYPE;
$colPartnerId = PartnerLoadPeer::PARTNER_ID;
$colDC = PartnerLoadPeer::DC;
$colQuota = PartnerLoadPeer::QUOTA;
$sql = "UPDATE {$table} ";
$sql .= "SET {$colPartnerLoad} = ({$colPartnerLoad} + 1)";
$sql .= ", {$colWeightedPartnerLoad} = ({$colWeightedPartnerLoad} + {$priorityFactor})";
$sql .= ", {$colQuota} = ({$colQuota} - 1)";
$sql .= "WHERE {$colJobType} = {$jobType} ";
$sql .= "AND {$colJobSubType} = {$jobSubType} ";
$sql .= "AND {$colPartnerId} = {$partnerId} ";
$sql .= "AND {$colDC} = {$dcId} ";
try {
$affectedRows = $con->exec($sql);
} catch (Exception $e) {
KalturaLog::err("Failed to update partner load with error : " . $e->getMessage());
}
}