Вход Регистрация
Файл: base-sys/base/bol/search_result_dao.php
Строк: 90
<?php

class BOL_SearchResultDao extends PEEP_BaseDao
{

    
/**
     * Constructor.
     *
     */
    
protected function __construct()
    {
        
parent::__construct();
    }
    
/**
     * Singleton instance.
     *
     * @var BOL_SearchDao
     */
    
private static $classInstance;

    
/**
     * Returns an instance of class (singleton pattern implementation).
     *
     * @return BOL_Search
     */
    
public static function getInstance()
    {
        if ( 
self::$classInstance === null )
        {
            
self::$classInstance = new self();
        }

        return 
self::$classInstance;
    }

    
/**
     * @see PEEP_BaseDao::getDtoClassName()
     *
     */
    
public function getDtoClassName()
    {
        return 
'BOL_SearchResult';
    }

    
/**
     * @see PEEP_BaseDao::getTableName()
     *
     */
    
public function getTableName()
    {
        return 
PEEP_DB_PREFIX 'base_search_result';
    }

    
/**
     * @see PEEP_BaseDao::getTableName()
     *
     */
    
public function saveSearchResult$searchId, array $idList )
    {
        
$query " INSERT INTO " $this->getTableName() . " ( searchId, userId, sortOrder ) VALUES ";
        
$count 0;
        
$values '';

        
$valuesList = array();

        foreach ( 
$idList as $order => $userId )
        {
            if ( 
$count )
            {
                
$values .= ",";
            }

            
$values .= " ( ?, ?, ? )";

            
$valuesList[] = $searchId;
            
$valuesList[] = $userId;
            
$valuesList[] = $order;

            
$count++;

            if ( 
$count >= 100 )
            {
                
$this->dbo->query($query $values$valuesList);
                
$count 0;
                
$values '';
                
$valuesList = array();
            }
        }

        if ( 
$count )
        {
            
$this->dbo->query($query $values$valuesList);
        }
    }

    
/**
     * Return search result item count
     *
     * @param int $listId
     * @param int $first
     * @param int $count
     * return array
     */
    
public function getUserIdList$listId$first$count$excludeList = array() )
    {
        
$example = new PEEP_Example();
        
$example->andFieldEqual('searchId', (int) $listId);
        
$example->setOrder(' sortOrder ');
        
$example->setLimitClause($first$count);
        
        if ( !empty(
$excludeList) )
        {
            
$example->andFieldNotInArray('userId'$excludeList);
        }

        
$results $this->findListByExample($example);

        
$userIdList = array();

        foreach ( 
$results as $result )
        {
            
$userIdList[] = $result->userId;
        }

        return 
$userIdList;
    }


    
/**
     * Return search result item count
     *
     * @param int $listId
     * return int
     */
    
public function countSearchResultItem$listId )
    {
        
$example = new PEEP_Example();
        
$example->andFieldEqual('searchId', (int) $listId);

        return 
$this->countByExample($example);
    }

    
/**
     * Return search result item count
     *
     * @param array $listId
     */
    
public function deleteSearchResultItems( array $listId )
    {
        if ( empty(
$listId) )
        {
            return;
        }

        
$example = new PEEP_Example();
        
$example->andFieldInArray('searchId'$listId);

        
$this->deleteByExample($example);
    }
}
Онлайн: 1
Реклама