當前位置: 首頁>>代碼示例>>PHP>>正文


PHP ArrayUtils::joinArray方法代碼示例

本文整理匯總了PHP中ArrayUtils::joinArray方法的典型用法代碼示例。如果您正苦於以下問題:PHP ArrayUtils::joinArray方法的具體用法?PHP ArrayUtils::joinArray怎麽用?PHP ArrayUtils::joinArray使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在ArrayUtils的用法示例。


在下文中一共展示了ArrayUtils::joinArray方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: getTopBuilder

    public static function getTopBuilder($count, $location = null)
    {
        if ($location) {
            $city = GeoCityApi::getCityByName($location['city']);
            if ($count) {
                $sql = 'SELECT * from user_builder_profile JOIN
						(SELECT builder_id from user_builder_rating r 
							GROUP BY r.builder_id 
							order by AVG(r.rate) DESC LIMIT ' . "{$count}" . ')
	 					AS ratings ON (user_builder_profile.id=ratings.builder_id) where city_id=' . "{$city->id}" . ' ORDER BY rand()';
            }
            $sql = 'SELECT * from user_builder_profile JOIN
						(SELECT builder_id from user_builder_rating r 
							GROUP BY r.builder_id 
							order by AVG(r.rate) DESC)
	 					AS ratings ON (user_builder_profile.id=ratings.builder_id) where city_id=' . "{$city->id}" . ' ORDER BY rand()';
            $properties = Yii::app()->db->createCommand($sql)->queryAll();
            $countProperties = count($properties);
            if ($countProperties < $count) {
                $total = $count - $countProperties;
                $sql = 'SELECT * from user_builder_profile JOIN
						(SELECT builder_id from user_builder_rating r 
							GROUP BY r.builder_id 
							order by AVG(r.rate) DESC)
	 					AS ratings ON (user_builder_profile.id=ratings.builder_id) where city_id!=' . "{$city->id}" . ' AND state_id=' . "{$city->state_id}" . ' ORDER BY rand() limit ' . "{$total}" . '';
                $propertiesState = Yii::app()->db->createCommand($sql)->queryAll();
                $properties = ArrayUtils::joinArray($properties, $propertiesState);
                $countProperties = count($properties);
                if ($countProperties < $count) {
                    $total = $count - $countProperties;
                    $sql = 'SELECT * from user_builder_profile JOIN
								(SELECT builder_id from user_builder_rating r 
									GROUP BY r.builder_id 
									order by AVG(r.rate) DESC)
			 					AS ratings ON (user_builder_profile.id=ratings.builder_id) where city_id!=' . "{$city->id}" . ' AND state_id!=' . "{$city->state_id}" . ' ORDER BY rand() limit ' . "{$total}" . '';
                    $propertiesCountry = Yii::app()->db->createCommand($sql)->queryAll();
                    $properties = ArrayUtils::joinArray($properties, $propertiesCountry);
                }
            }
        } else {
            if ($count) {
                $sql = 'SELECT * from user_builder_profile JOIN
						(SELECT builder_id from user_builder_rating r 
							GROUP BY r.builder_id 
							order by AVG(r.rate) DESC LIMIT ' . "{$count}" . ')
	 					AS ratings ON (user_builder_profile.id=ratings.builder_id) ORDER BY rand()';
            }
            $sql = 'SELECT * from user_builder_profile JOIN
						(SELECT builder_id from user_builder_rating r 
							GROUP BY r.builder_id 
							order by AVG(r.rate) DESC)
	 					AS ratings ON (user_builder_profile.id=ratings.builder_id) ORDER BY rand()';
            $properties = Yii::app()->db->createCommand($sql)->queryAll();
        }
        if ($properties) {
            return $properties;
        } else {
            return false;
        }
        /*$criteria=new CDbCriteria;
        	 $criteria->limit=$count;
        	 $criteria->order='rand()';
        	 $criteria->with = 'propertyRatings r';
        	 $criteria->order='MAX(AVG(r.rate))';
        	 $properties=Property::model()->findAll($criteria);
        	 if($properties)
        	 return $properties;
        	 else
        	 return false;*/
    }
開發者ID:romeo14,項目名稱:wallfeet,代碼行數:70,代碼來源:BuilderProfileApi.php

示例2: getFeaturedProperties

 /**
  * This method gets the count and returns the featured properties
  * Returns the model if found.
  * Returns false if not found.
  *
  * @param string $count
  * @return model || boolean
  */
 public static function getFeaturedProperties($count, $location = null)
 {
     if ($location) {
         $city = GeoCityApi::getCityByName($location['city']);
         $criteria = new CDbCriteria();
         $criteria->condition = 'featured=:featured  AND city_id=:city';
         $criteria->params = array(':featured' => 1, ':city' => $city->id);
         if ($count) {
             $criteria->limit = $count;
         }
         $criteria->order = 'rand()';
         $properties = Property::model()->findAll($criteria);
         $countProperties = count($properties);
         if ($countProperties < $count) {
             $total = $count - $countProperties;
             $country = GeoCountryApi::getCountryByName($location['country']);
             $criteria = new CDbCriteria();
             $criteria->condition = 'featured=:featured  AND state_id=:state AND city_id!=:cityId';
             $criteria->params = array(':featured' => 1, ':state' => $city->state_id, ':cityId' => $city->id);
             $criteria->limit = $total;
             $criteria->order = 'rand()';
             $propertiesState = Property::model()->findAll($criteria);
             $properties = ArrayUtils::joinArray($properties, $propertiesState);
             $countProperties = count($properties);
             if ($countProperties < $count) {
                 $total = $count - $countProperties;
                 $criteria = new CDbCriteria();
                 $criteria->condition = 'featured=:featured  AND state_id!=:state AND city_id!=:cityId';
                 $criteria->params = array(':featured' => 1, ':state' => $city->state_id, ':cityId' => $city->id);
                 $criteria->limit = $total;
                 $criteria->order = 'rand()';
                 $propertiesState = Property::model()->findAll($criteria);
                 $properties = ArrayUtils::joinArray($properties, $propertiesState);
             }
         }
         if ($properties) {
             return $properties;
         } else {
             return false;
         }
     } else {
         $criteria = new CDbCriteria();
         $criteria->condition = 'featured=:featured';
         $criteria->params = array(':featured' => 1);
         if ($count) {
             $criteria->limit = $count;
         }
         $criteria->order = 'rand()';
         $properties = Property::model()->findAll($criteria);
         if ($properties) {
             return $properties;
         } else {
             return false;
         }
     }
 }
開發者ID:romeo14,項目名稱:wallfeet,代碼行數:64,代碼來源:PropertyApi.php


注:本文中的ArrayUtils::joinArray方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。