当前位置: 首页>>代码示例>>PHP>>正文


PHP ProductQuery::where方法代码示例

本文整理汇总了PHP中Thelia\Model\ProductQuery::where方法的典型用法代码示例。如果您正苦于以下问题:PHP ProductQuery::where方法的具体用法?PHP ProductQuery::where怎么用?PHP ProductQuery::where使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Thelia\Model\ProductQuery的用法示例。


在下文中一共展示了ProductQuery::where方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。

示例1: doSearch

 /**
  * @param ProductQuery $search
  * @param $searchTerm
  * @param $searchIn
  * @param $searchCriteria
  */
 public function doSearch(&$search, $searchTerm, $searchIn, $searchCriteria)
 {
     $search->_and();
     foreach ($searchIn as $index => $searchInElement) {
         if ($index > 0) {
             $search->_or();
         }
         switch ($searchInElement) {
             case "ref":
                 $search->filterByRef($searchTerm, $searchCriteria);
                 break;
             case "title":
                 $search->where("CASE WHEN NOT ISNULL(`requested_locale_i18n`.ID) THEN `requested_locale_i18n`.`TITLE` ELSE `default_locale_i18n`.`TITLE` END " . $searchCriteria . " ?", $searchTerm, \PDO::PARAM_STR);
                 break;
         }
     }
 }
开发者ID:jeremyFreeAgent,项目名称:thelia,代码行数:23,代码来源:Product.php

示例2: manageFeatureValue

 /**
  * @param ProductQuery $search
  * @param string[] $feature_values
  */
 protected function manageFeatureValue(&$search, $feature_values)
 {
     if (null !== $feature_values) {
         foreach ($feature_values as $feature => $feature_choice) {
             foreach ($feature_choice['values'] as $feature_value) {
                 $featureAlias = 'fv_' . $feature;
                 if ($feature_value != '*') {
                     $featureAlias .= '_' . $feature_value;
                 }
                 $search->joinFeatureProduct($featureAlias, Criteria::LEFT_JOIN)->addJoinCondition($featureAlias, "`{$featureAlias}`.FEATURE_ID = ?", $feature, null, \PDO::PARAM_INT);
                 if ($feature_value != '*') {
                     $search->addJoinCondition($featureAlias, "`{$featureAlias}`.FREE_TEXT_VALUE = ?", $feature_value, null, \PDO::PARAM_STR);
                 }
             }
             /* format for mysql */
             $sqlWhereString = $feature_choice['expression'];
             if ($sqlWhereString == '*') {
                 $sqlWhereString = 'NOT ISNULL(`fv_' . $feature . '`.ID)';
             } else {
                 $sqlWhereString = preg_replace('#([a-zA-Z0-9_\\-]+)#', 'NOT ISNULL(`fv_' . $feature . '_' . '\\1`.ID)', $sqlWhereString);
                 $sqlWhereString = str_replace('&', ' AND ', $sqlWhereString);
                 $sqlWhereString = str_replace('|', ' OR ', $sqlWhereString);
             }
             $search->where("(" . $sqlWhereString . ")");
         }
     }
 }
开发者ID:vigourouxjulien,项目名称:thelia,代码行数:31,代码来源:Product.php


注:本文中的Thelia\Model\ProductQuery::where方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。