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


PHP freelancer::createCatalogFilterSql方法代碼示例

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


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

示例1: setResults

 function setResults()
 {
     global $DB;
     require_once $_SERVER['DOCUMENT_ROOT'] . "/classes/freelancer.php";
     if ($filter = $this->isAdvanced()) {
         foreach ($this->matches as $val) {
             $frl_ids[] = $val;
         }
         $page = $this->_advanced_page;
         $limit = $this->_advanced_limit;
         $offset = 0;
         if ($page > 0) {
             $offset = ($page - 1) * $limit;
         }
         $this->_offset = $offset;
         //if(isset($filter['nt_negative'])) $filter['not_negative'] = $filter['nt_negative'];
         $prof_id = is_array($filter['prof'][1]) ? array_keys($filter['prof'][1]) : array();
         $order_by_spec_orign = "";
         if (count($prof_id)) {
             $order_by_spec_orign = "s.spec IN (" . join(", ", $prof_id) . ") DESC,";
         }
         $prof = $filter['prof'];
         unset($filter['prof']);
         $fprms = freelancer::createCatalogFilterSql($filter, 0);
         $filter_sql = $inner_sql = '';
         if ($fprms !== -1) {
             list($filter_sql, $inner_sql) = $fprms;
             if ($filter_sql) {
                 $filter_sql = ' AND ' . $filter_sql;
             }
         }
         $sql = "SELECT \n                      COUNT(u.uid) as cnt \n                    FROM users u\n                    LEFT JOIN \n                      freelancer s ON s.uid = u.uid\n                    LEFT JOIN\n                      portf_choise pc ON ( pc.prof_id = s.spec_orig AND pc.user_id = s.uid )\n                    LEFT JOIN\n                      users_counters uc ON ( uc.user_id = u.uid )\n                    {$inner_sql} \n                    WHERE \n                      u.uid IN (" . implode(", ", $frl_ids) . ") \n                        AND \n                      u.is_banned = '0'\n                      {$filter_sql} \n                    LIMIT 1;";
         $this->total = $DB->val($sql);
         $sql = "SELECT \n                      u.uid as uid, \n                      u.photo, \n                      u.role, \n                      u.is_pro, \n                      u.is_profi,\n                      u.is_team, \n                      u.is_pro_test, \n                      u.info_for_reg, \n                      p.name as name_prof, \n                      u.login, \n                      u.uname, \n                      u.usurname,\n                      u.email, \n                      u.skype, \n                      s.site, \n                      ctr.country_name, \n                      ct.city_name, \n                      s.spec_text, \n                      s.resume, \n                      s.konk, \n                      s.blocks, \n                      s.status_type,  \n                      s.cost_month, \n                      s.cost_hour AS frl_cost_hour, \n                      s.cost_type_hour as frl_cost_type_hour,\n                      s.in_office, \n                      s.exp, \n                      s.tabs,\n                      \n                      uc.sbr_opi_plus, \n                      uc.sbr_opi_minus, \n                      uc.sbr_opi_null,\n                      \n                      pc.cost_from, \n                      pc.cost_to, \n                      pc.cost_1000, \n                      pc.cost_type, \n                      uc.ops_emp_null + uc.ops_frl_null AS se, \n                      uc.ops_emp_plus + uc.ops_frl_plus AS sg, \n                      uc.ops_emp_minus + uc.ops_frl_minus AS sl, \n                      s.cost_type_hour, \n                      s.cost_type_month, \n                      rating_get(s.rating, s.is_pro, s.is_verify, s.is_profi) as t_rating,\n                      (add_spec.additional_specs || ', ' || COALESCE(p_spec.paid_specs, '')) AS additional_specs,\n                      -- get_additional_specs_as_string(u.uid) AS additional_spec,\n                      \n                      (uc.paid_advices_cnt + uc.sbr_opi_plus + uc.tu_orders_plus + uc.projects_fb_plus) AS total_opi_plus,\n                      (uc.sbr_opi_null) AS total_opi_null,\n                      (uc.sbr_opi_minus + uc.tu_orders_minus + uc.projects_fb_minus) AS total_opi_minus,\n                      \n                      COALESCE(smeta.completed_cnt, 0) + COALESCE(uc.reserves_completed_cnt, 0) AS completed_cnt -- старые БС + новые БС\n                      \n                    FROM users u\n                    LEFT JOIN freelancer s ON s.uid = u.uid\n                    LEFT JOIN portf_choise pc ON ( pc.prof_id = s.spec_orig AND pc.user_id = s.uid )\n                    LEFT JOIN professions p ON p.id = s.spec AND p.id > 0\n                    LEFT JOIN users_counters uc ON uc.user_id = u.uid\n                    LEFT JOIN country ctr ON ctr.id = s.country AND ctr.id > 0\n                    LEFT JOIN city ct ON ct.id = s.city AND ct.id > 0\n                    LEFT JOIN sbr_meta AS smeta ON smeta.user_id = u.uid -- старые БС\n                    LEFT JOIN \n                    ( \n                        SELECT \n                            array_to_string(array_agg(p.name), ', '::text) AS additional_specs, \n                            sa.user_id AS uid\n                        FROM spec_add_choise AS sa\n                        LEFT JOIN professions AS p ON p.id = prof_id\n\t                GROUP BY sa.user_id\n                    ) AS add_spec ON add_spec.uid = u.uid\n                    LEFT JOIN \n                    ( \n                        SELECT \n                            array_to_string(array_agg(p.name), ', '::text) AS paid_specs, \n                            sp.user_id AS uid\n                        FROM spec_paid_choise AS sp\n                        LEFT JOIN professions AS p ON p.id = prof_id\n\t                GROUP BY sp.user_id\n                    ) AS p_spec ON p_spec.uid = u.uid  \n                    \n                    {$inner_sql}\n                    WHERE\n                      u.uid IN (" . implode(", ", $frl_ids) . ") AND \n                      u.is_banned = '0' \n                      {$filter_sql}\n                    ORDER BY u.is_pro DESC, {$order_by_spec_orign} s.rating DESC, u.uid  \n                    LIMIT {$limit} OFFSET {$offset}";
         //echo "<pre>".$sql;
         $this->results = $DB->rows($sql);
     } else {
         $this->results = $this->getRecords('is_pro DESC, rating DESC, id');
     }
     if ($this->results) {
         $frl_ids_map = array();
         $tu_frl_ids = array();
         foreach ($this->results as $key => $row) {
             $frl_ids[] = $row['uid'];
             $frl_ids_map[$row['uid']] = $key;
             //Если вкладка ТУ выключена то сразу исключаем такие UID
             if (substr($row['tabs'], 7, 1) == 1) {
                 $tu_frl_ids[$key] = $row['uid'];
             }
         }
         $uid = isset($_SESSION["uid"]) ? $_SESSION["uid"] : 0;
         $is_spec = isset($prof[0]);
         $categoty_id = $is_spec ? key($prof[0]) : 0;
         $prof_id = !$is_spec && isset($prof[1]) ? key($prof[1]) : 0;
         //print_r($current_categoty_id);
         //exit;
         //Получение пользовательский превью работ/услуг
         require_once ABS_PATH . '/freelancers/widgets/FreelancersPreviewWidget.php';
         require_once ABS_PATH . '/freelancers/models/FreelancersPreviewModel.php';
         $freelancersPreviewModel = new FreelancersPreviewModel();
         $list = $freelancersPreviewModel->getListByUids($frl_ids, $categoty_id, $prof_id);
         $tmp_tu_uids = $tu_frl_ids;
         foreach ($list as $item) {
             //Если отключена вкладка ТУ то их исключаем
             if (!$item || $item->type == FreelancersPreviewModel::TYPE_TU && !in_array($item->user_id, $tmp_tu_uids)) {
                 continue;
             }
             //Инициализируем данные юзера в работе/услуге пока только логин нужен
             $key = $frl_ids_map[$item->user_id];
             $item->setUser(array('login' => $this->results[$key]['login']));
             //Инитим виджет если его нет
             if (!isset($this->results[$key]['preview'])) {
                 $this->results[$key]['preview'] = new FreelancersPreviewWidget();
             }
             //Добавляем работу в виджет
             $this->results[$key]['preview']->addItem($item);
             //Исключаем из дальнейшей обработки
             unset($frl_ids[$key], $tu_frl_ids[$key]);
         }
         //------------------------------------------------------------------
         $this->works = null;
         if ($frl_ids) {
             $this->works = $this->getUsersWorks($frl_ids, $uid);
         }
         //------------------------------------------------------------------
         //Если у пользователя не отображатся портфолио
         //то можно показать 3 последнии ТУ
         $exist_uids = $this->works ? array_keys($this->works) : array();
         $tu_uids = array_diff($frl_ids, $exist_uids);
         if ($tu_uids) {
             require_once ABS_PATH . '/tu/models/TServiceModel.php';
             $tserviceModel = new TServiceModel();
             if ($list = $tserviceModel->getListByUids($tu_uids, 3, freelancer::CATALOG_PORTFOLIO_MEM_LIFE)) {
                 $current_user_tu_ids = array();
                 foreach ($list as $item) {
                     $key = $frl_ids_map[$item['user_id']];
                     $item['login'] = $this->results[$key]['login'];
                     $this->results[$key]['tservices'][] = $item;
                     if ($item['user_id'] == $uid) {
                         $current_user_tu_ids[] = $item['id'];
//.........這裏部分代碼省略.........
開發者ID:Nikitian,項目名稱:fl-ru-damp,代碼行數:101,代碼來源:search_element_users_ext.php

示例2: setResults

 function setResults()
 {
     global $session, $DB;
     if ($filter = $this->isAdvanced()) {
         require_once $_SERVER['DOCUMENT_ROOT'] . "/classes/projects.php";
         require_once $_SERVER['DOCUMENT_ROOT'] . "/classes/freelancer.php";
         foreach ($this->matches as $val) {
             $frl_ids[] = $val;
         }
         $page = $this->_advanced_page;
         $limit = $this->_advanced_limit;
         $offset = 0;
         if ($page > 0) {
             $offset = ($page - 1) * $limit;
         }
         $this->_offset = $offset;
         //if(isset($filter['nt_negative'])) $filter['not_negative'] = $filter['nt_negative'];
         $prof_id = is_array($filter['prof'][1]) ? array_keys($filter['prof'][1]) : array();
         $order_by_spec_orign = "";
         if (count($prof_id)) {
             $order_by_spec_orign = "s.spec IN (" . join(", ", $prof_id) . ") DESC,";
         }
         //@todo: спорная операция так как в запрос не пойдут категории
         //и вся надежда только на поиск по тексту от Сфинкса
         //
         //пока убираю
         //
         //unset($filter['prof']);
         $fprms = freelancer::createCatalogFilterSql($filter, 0);
         $filter_sql = $inner_sql = '';
         if ($fprms !== -1) {
             list($filter_sql, $inner_sql) = $fprms;
             if ($filter_sql) {
                 $filter_sql = ' AND ' . $filter_sql;
             }
         }
         $sql = "SELECT \n                      COUNT(u.uid) as cnt \n                    FROM users u\n                    LEFT JOIN \n                      freelancer s ON s.uid = u.uid\n                    LEFT JOIN\n                      portf_choise pc ON ( pc.prof_id = s.spec_orig AND pc.user_id = s.uid )\n                    LEFT JOIN\n                      users_counters uc ON ( uc.user_id = u.uid )\n                    {$inner_sql} \n                    WHERE \n                      u.uid IN (" . implode(", ", $frl_ids) . ") \n                        AND \n                      u.is_banned = '0'\n                      {$filter_sql} \n                    LIMIT 1;";
         $this->total = $DB->val($sql);
         $sql = "SELECT \n                      u.uid as id, \n                      u.photo, \n                      u.role, \n                      u.is_pro, \n                      u.is_profi, \n                      u.is_team, \n                      u.is_pro_test, \n                      u.info_for_reg, \n                      p.name as name_prof, \n                      u.login, \n                      u.uname, \n                      u.usurname, \n                      u.email, \n                      u.skype, \n                      s.site, \n                      ctr.country_name, \n                      ct.city_name, \n                      s.spec_text, \n                      s.resume, \n                      s.konk, \n                      s.blocks, \n                      s.status_type,  \n                      s.cost_month, \n                      s.cost_hour, \n                      s.in_office, \n                      s.exp,\n                      pc.cost_from, \n                      pc.cost_to, \n                      pc.cost_1000, \n                      pc.cost_type, \n\n                      (uc.paid_advices_cnt + uc.ops_emp_plus + uc.ops_frl_plus + uc.sbr_opi_plus + uc.tu_orders_plus + uc.projects_fb_plus) AS all_opi_plus,\n                      (uc.ops_emp_null + uc.ops_frl_null + uc.sbr_opi_null) AS all_opi_null,\n                      (uc.ops_emp_minus + uc.ops_frl_minus + uc.sbr_opi_minus + uc.tu_orders_minus + uc.projects_fb_minus) AS all_opi_minus,\n\n                      s.cost_type_hour, \n                      s.cost_type_month, \n                      rating_get(s.rating, s.is_pro, s.is_verify, s.is_profi) as rating,\n                      (add_spec.additional_specs || ', ' || COALESCE(p_spec.paid_specs, '')) AS additional_specs\n                      -- get_additional_specs_as_string(u.uid) AS additional_spec\n\n                    FROM users u\n                    LEFT JOIN \n                      freelancer s ON s.uid = u.uid\n                    LEFT JOIN\n                      portf_choise pc ON ( pc.prof_id = s.spec_orig AND pc.user_id = s.uid )\n                    LEFT JOIN\n                      professions p ON p.id = s.spec AND p.id > 0\n                    LEFT JOIN\n                      users_counters uc ON uc.user_id = u.uid\n                    LEFT JOIN \n                      country ctr ON ctr.id = s.country AND ctr.id > 0\n                    LEFT JOIN \n                      city ct ON ct.id = s.city AND ct.id > 0\n\n                    LEFT JOIN ( SELECT array_to_string(array_agg(p.name), ', '::text)  AS additional_specs, sa.user_id AS uid\n                        FROM spec_add_choise AS sa\n                    LEFT JOIN professions AS p ON p.id = prof_id\n\t                   GROUP BY sa.user_id) AS add_spec ON add_spec.uid = u.uid\n\n                    LEFT JOIN ( SELECT array_to_string(array_agg(p.name), ', '::text)  AS paid_specs, sp.user_id AS uid\n                        FROM spec_paid_choise AS sp\n                    LEFT JOIN professions AS p ON p.id = prof_id\n\t                    GROUP BY sp.user_id) AS p_spec ON p_spec.uid = u.uid  \n                    \n                    {$inner_sql}\n                    WHERE\n                      u.uid IN (" . implode(", ", $frl_ids) . ") \n                        AND \n                      u.is_banned = '0' \n                      {$filter_sql}\n                    ORDER BY u.is_pro DESC, {$order_by_spec_orign} s.rating DESC, u.uid  \n                    LIMIT {$limit} OFFSET {$offset}";
         //echo "<pre>".$sql;
         $this->results = $DB->rows($sql);
         if ($this->results) {
             foreach ($this->results as $row) {
                 $filter_frl_ids[] = $row['id'];
             }
             if (count($filter_frl_ids) > 0) {
                 $this->works = $this->getUsersWorks($filter_frl_ids);
             }
         }
     } else {
         $this->results = $this->getRecords('is_pro DESC, rating DESC, id');
         if ($this->results) {
             foreach ($this->results as $row) {
                 $frl_ids[] = $row['id'];
             }
             if (count($frl_ids) > 0) {
                 $this->works = $this->getUsersWorks($frl_ids);
             }
         }
     }
 }
開發者ID:Nikitian,項目名稱:fl-ru-damp,代碼行數:61,代碼來源:search_element_users.php


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