本文整理匯總了PHP中DatabaseFactory::open方法的典型用法代碼示例。如果您正苦於以下問題:PHP DatabaseFactory::open方法的具體用法?PHP DatabaseFactory::open怎麽用?PHP DatabaseFactory::open使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類DatabaseFactory
的用法示例。
在下文中一共展示了DatabaseFactory::open方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: getById
/**
* 獲取campaign
* @param int $campaignId
* @return array
*/
static function getById($campaignId)
{
$redis = RedisFactory::open()->connect($campaignId);
$key = sprintf(self::$REDIS_KEYS['getById'], $campaignId);
$result = $redis->get($key)->getResult();
if ($result === false) {
// 初始化
$db = DatabaseFactory::open();
$result = $db->createCommand("SELECT * FROM g_campaign WHERE id=:id")->findFirst(array(':id' => $campaignId));
if (empty($result)) {
$result = array();
}
$redis->set($key, $result);
}
return $result;
}
示例2: receivedTotal
/**
* 已領取總數(redis重啟後,通過command從DB導入到redis)
* @param int $campaignId
* @param int $userId
*/
static function receivedTotal($campaignId, $userId)
{
$redis = self::getRedis()->connect($userId);
$keyReceiveByUserId = sprintf(self::$REDIS_KEYS['receiveByUserId'], $campaignId, $userId);
$keyReceiveByUserIdIsInit = sprintf(self::$REDIS_KEYS['receiveByUserIdIsInit'], $campaignId, $userId);
$result = $redis->multi()->scard($keyReceiveByUserId)->get($keyReceiveByUserIdIsInit)->exec()->getResult();
list($total, $isInit) = $result;
if ($isInit == false) {
// 初始化該用戶的領取信息
$db = DatabaseFactory::open();
$rows = $db->createCommand('
SELECT giftbagCode FROM g_campaign_mapping_giftbag
WHERE campaignId=:campaignId AND userId=:userId
')->findAll(array(':campaignId' => $campaignId, ':userId' => $userId));
if ($rows) {
// 同步到領取列表
foreach ($rows as $row) {
$redis->multiChunk('sadd', $keyReceiveByUserId, $row['giftbagCode']);
}
$redis->multiChunkFlush();
}
// 獲取最新的總數
$result = $redis->multi()->scard($keyReceiveByUserId)->set($keyReceiveByUserIdIsInit, true)->exec()->getResult();
list($total, $isInit) = $result;
}
return $total;
}
示例3: add
/**
* 新增用戶
* @param array $userData
* @return int insertId
*/
static function add($userData)
{
$salt = StringUtil::random(10);
// 初始化
$db = DatabaseFactory::open();
$result = $db->createCommand("\n\t\t\tINSERT INTO `g_user` (username,mobile,password,salt)\n\t\t\t\tVALUES (:username,:mobile,:password,:salt)\n\t\t")->execute(array(':username' => $userData['username'], ':mobile' => $userData['mobile'], ':password' => self::encodePassword($userData['password'], $salt), ':salt' => $salt));
if ($result) {
$userId = $db->getInsertId();
$redis = self::getRedis();
$redis->connect($userId)->del(sprintf(self::$REDIS_KEYS['getById'], $userId));
$redis->connect($userData['username'])->del(sprintf(self::$REDIS_KEYS['getByUsername'], $userData['username']));
$redis->connect($userData['mobile'])->del(sprintf(self::$REDIS_KEYS['getByMobile'], $userData['mobile']));
return $userId;
} else {
return false;
}
}
示例4: insertMappingFlush
/**
* 批量插入 giftbag code - campaign - user的mapping的最終操作
*/
private function insertMappingFlush()
{
if (empty($this->mappingValues) == false) {
$db = DatabaseFactory::open();
$db->createCommand('
INSERT INTO g_campaign_mapping_giftbag (campaignId,userId, giftbagCode)
VALUES (' . implode('),(', $this->mappingValues) . ')
')->execute();
$this->mappingValues = array();
}
}