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


PHP memBuff::getSql方法代碼示例

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


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

示例1: getListByUids

 /**
  * Выбрать ТУ для списка пользователей 
  * по указанному количеству на каждого
  * 
  * @param type $uids
  * @param type $limit
  * @param type $expire
  * @param type $group
  * @return type
  */
 public function getListByUids($uids, $limit = 3, $expire = 0, $group = false)
 {
     $sql = $this->db()->parse("\n            SELECT \n                DISTINCT ON (q.id) \n                q.*,\n                f.fname AS file\n            FROM (\n                SELECT \n                    s.id AS id, \n                    s.user_id,\n                    s.title AS title, \n                    s.price AS price,\n                    s.videos AS videos,\n                    s.total_feedbacks AS total_feedbacks,\n                    row_number() OVER(PARTITION BY s.user_id ORDER BY s.id DESC) AS rownum\n                FROM {$this->TABLE} AS s \n                LEFT JOIN {$this->TABLE_DEBT} AS od ON od.user_id = s.user_id \n                LEFT JOIN {$this->TABLE_BLOCKED} AS sb ON sb.src_id = s.id \n                WHERE \n                    s.user_id IN(?l) \n                    AND s.deleted = FALSE \n                    AND s.active = TRUE \n                    AND sb.src_id IS NULL\n                    AND (od.id IS NULL OR od.date >= NOW())\n            ) AS q\n            LEFT JOIN {$this->TABLE_FILES} AS f ON f.src_id = q.id AND f.small = 4\n            WHERE q.rownum <= ?i\n            ORDER BY q.id DESC, f.preview DESC, f.id \n        ", $uids, $limit);
     $memBuff = new memBuff();
     $result = $memBuff->getSql($error, $sql, $expire, true, $group);
     return $result;
 }
開發者ID:Nikitian,項目名稱:fl-ru-damp,代碼行數:17,代碼來源:TServiceModel.php

示例2: GetLastNews

 /**
  * Взять последнюю новость
  *
  * @return array Новость
  */
 function GetLastNews()
 {
     $sql = "SELECT post_date, header FROM news ORDER BY post_date DESC, id DESC LIMIT 1";
     $memBuff = new memBuff();
     $headers = $memBuff->getSql($error, $sql, 1800);
     if ($error) {
         $error = parse_db_error($error);
     } else {
         $ret = $headers[0];
     }
     return $ret;
 }
開發者ID:amage,項目名稱:fl-ru-damp,代碼行數:17,代碼來源:news.php

示例3: getProjectsCount

 /**
  * Подсчитывает и возвращает количество проектов по закладкам для постранички в ленте,
  * записыавет в memcache на 30 минут.
  * Если $uid != null также на последних страницах проверяется количество
  * забаненных проектов пользователя и суммируется с общим.
  *
  * @param integer $kind  Тип проектов (-1=5=Все проекты; 2=Конкурсы; 4=В офис; 6=Только для про)
  * @param integer $page  Номер текущей страницы
  * @param integer $uid   ИД работодателя, если есть.
  * @return integer
  */
 function getProjectsCount($kind = 0, $page = 1, $uid = null, $is_moder = null)
 {
     //$_uid = intval($uid);
     $_where = '';
     //$_where = !$is_moder?" AND (p.status = ".self::STATE_PUBLIC." OR e.uid = {$_uid})":'';
     //$_where = !$is_moder?"AND NOT(p.payed = 0 AND p.kind = ".self::KIND_VACANCY." AND p.state = ".self::STATE_MOVED_TO_VACANCY.")":'';
     $sql = "SELECT\n                    SUM(pro_only::int) as pro_only,\n                    SUM((kind = 1)::int) as prj_fl,\n                    SUM((kind IN (2,7))::int) as prj_kon,\n                    SUM((kind = 4)::int) as prj_off\n                FROM projects p\n                LEFT JOIN projects_blocked pb ON pb.project_id = p.id\n                INNER JOIN employer e ON e.uid = p.user_id AND e.is_banned = '0'\n                WHERE \n                    " . (get_uid(false) ? '' : 'COALESCE(p.hide, false) = false AND ') . "p.closed = false AND pb.project_id IS NULL AND p.kind <> 9 {$_where}";
     $memBuff = new memBuff();
     $a_num_prjs = $memBuff->getSql($error, $sql, 1800);
     if (!$a_num_prjs) {
         return 0;
     }
     $res = $a_num_prjs[0];
     $cnt = 0;
     switch ($kind) {
         case 6:
             //только про
             $cnt = $res['pro_only'];
             $where_kind = ' AND pro_only = true AND kind <> 9';
             break;
         case 1:
             //фриланс
             $cnt = $res['prj_fl'];
             $where_kind = ' AND kind = 1 ';
             break;
         case 2:
             //конкурсы
             $cnt = $res['prj_kon'];
             $where_kind = ' AND kind IN (2,7) ';
             break;
         case 4:
             //офис
             $cnt = $res['prj_off'];
             $where_kind = ' AND kind = 4 ';
             break;
         default:
             //все
             $cnt = $res['prj_fl'] + $res['prj_kon'] + $res['prj_off'];
             $where_kind = ' AND kind <> 9';
     }
     //нужно уточнить счетчик на последних страницах, и добавить
     //к общему кол-во забаненных проектов работодателя
     if ($uid && $page + 10 >= ceil($cnt / projects::PAGE_SIZE)) {
         $sql = "SELECT COUNT(*) as cnt FROM projects_blocked pb\n                    INNER JOIN projects p ON p.id = pb.project_id\n                    WHERE p.user_id = {$uid} {$where_kind}";
         $res_cnt = $memBuff->getSql($error, $sql, 300);
         if ($res_cnt) {
             $ban = $res_cnt[0];
             $cnt += (int) $ban['cnt'];
         }
     }
     return $cnt;
 }
開發者ID:amage,項目名稱:fl-ru-damp,代碼行數:63,代碼來源:projects.php

示例4: GetBannedStat

 /**
  * Статистика по забаненым пользователям.
  *
  * @return array статистика
  */
 public function GetBannedStat()
 {
     $sql = "SELECT COUNT(*) AS cnt FROM users WHERE is_banned = B'1' AND ban_where = 0";
     $memBuff = new memBuff();
     $row = $memBuff->getSql($error, $sql, 180);
     $site = $row[0]['cnt'];
     $sql = 'SELECT COUNT(*) AS cnt FROM users WHERE ban_where = 1';
     $memBuff = new memBuff();
     $row = $memBuff->getSql($error, $sql, 180);
     $blogs = $row[0]['cnt'];
     $sql = "SELECT COUNT(*) AS cnt FROM users WHERE warn > 0 AND is_banned = B'0' AND ban_where = 0";
     $memBuff = new memBuff();
     $row = $memBuff->getSql($error, $sql, 180);
     $warns = $row[0]['cnt'];
     return array('all' => $site + $blogs + $warns, 'site' => $site, 'blogs' => $blogs, 'warns' => $warns);
 }
開發者ID:kapai69,項目名稱:fl-ru-damp,代碼行數:21,代碼來源:users.php

示例5: GetAll

 /**
  * Получает обменные курсы
  *
  * @param  boolean $cache получить из базы или из кэша
  * @return array массив курсов валют
  */
 function GetAll($cache = true)
 {
     $sql = "SELECT * FROM project_exrates";
     if ($cache) {
         $memBuff = new memBuff();
         $ret = $memBuff->getSql($error, $sql, 600);
     } else {
         global $DB;
         $res = $DB->squery($sql);
         $ret = pg_fetch_all($res);
     }
     if ($ret) {
         foreach ($ret as $ikey => $val) {
             $out[$val['id']] = $val['val'];
         }
     }
     return $out;
 }
開發者ID:Nikitian,項目名稱:fl-ru-damp,代碼行數:24,代碼來源:project_exrates.php

示例6: setTypeByPage

 /**
  * Выборка записи из таблицы ban_promo_types по типу страницы
  * setTypeByPage.
  *
  * @param type $target
  */
 public function setTypeByPage($target = '0|0')
 {
     global $DB;
     $sql = "SELECT * FROM ban_promo_types\n            WHERE now()::date BETWEEN from_date AND to_date AND deleted = 'f'\n            AND (is_pro & B'{$this->is_pro}' = '{$this->is_pro}') AND (is_role & B'{$this->is_role}' = '{$this->is_role}')\n            ORDER BY (page_target = ?) DESC, is_activity DESC, advertising DESC, from_date ASC \n            LIMIT 1\n        ";
     $query = $DB->parse($sql, $target);
     $memBuff = new memBuff();
     $result = $memBuff->getSql($error, $query, 600, true, 'banner_promo');
     if ($result) {
         $this->info = $result[0];
         if (strpos($this->info['name_img'], '/users') === 0) {
             $this->info['name_img'] = WDCPREFIX . $this->info['name_img'];
         } else {
             $this->info['name_img'] = $this->info['name_img'];
         }
         $this->type_banner = $this->info['id'];
     }
     return $this->type_banner;
 }
開發者ID:kapai69,項目名稱:fl-ru-damp,代碼行數:24,代碼來源:banner_promo.php

示例7: NumsBlockedCommunes

 /**
  * Возвращает кол-во заблокированных проектов
  *
  * @return integer
  */
 function NumsBlockedCommunes()
 {
     $sql = "SELECT COUNT(*) AS cnt FROM commune_blocked JOIN commune ON commune.id = commune_blocked.commune_id";
     $memBuff = new memBuff();
     $row = $memBuff->getSql($error, $sql, 180);
     return (int) $row[0]['cnt'];
 }
開發者ID:Nikitian,項目名稱:fl-ru-damp,代碼行數:12,代碼來源:commune.php

示例8: getHHCurrency

 /**
  * Возвращает информацию по заданной HH-валюте
  *
  * @param string $code   код валюты (USD, UAH и т.д.).
  * @return array
  */
 function getHHCurrency($code)
 {
     global $DB;
     $sql = "SELECT * FROM hh_currency WHERE code ILIKE '{$code}'";
     $memBuff = new memBuff();
     if ($rows = $memBuff->getSql($error, $sql, self::MEM_LIFE)) {
         $ret = $rows[0];
     }
     return $ret;
 }
開發者ID:Nikitian,項目名稱:fl-ru-damp,代碼行數:16,代碼來源:hh.php

示例9: GetCatalogPositionsTable

 /**
  * Возвращает имя актуальной таблицы с позициями фрилансеров
  * в общем каталоге
  *
  * @param boolean $clear_cache Удалить или нет запись из кеша
  * @return string Имя актуальной таблицы
  */
 function GetCatalogPositionsTable($clear_cache = false)
 {
     $memBuff = new memBuff();
     $sql = "SELECT value FROM settings WHERE module = 'professions' AND variable = 'pos_table' LIMIT 1";
     if ($clear_cache) {
         $memBuff->delete(md5($sql));
     }
     if (!($pos_table = $memBuff->getSql($error, $sql, 3600))) {
         return NULL;
     }
     $pos_table = $pos_table[0]['value'];
     return $pos_table;
 }
開發者ID:Nikitian,項目名稱:fl-ru-damp,代碼行數:20,代碼來源:professions.php

示例10: getAllOpCodes

 /**
  * Загрузить весь список опкодов.
  * 
  * @return bool
  */
 public static function getAllOpCodes($refresh = false)
 {
     if (!empty(self::$_cache_data) && !$refresh) {
         return self::$_cache_data;
     }
     $error = null;
     $memBuff = new memBuff();
     $data = $memBuff->getSql($error, ' 
             SELECT * FROM ' . get_class($this) . '
         ', self::OP_CODES_MEMCACHE_LIFE, true, self::OP_CODES_MEMCACHE_TAG);
     if ($data && !$error) {
         foreach ($data as $el) {
             self::$_cache_data[$el['id']] = $el;
         }
         return self::$_cache_data;
     }
     return false;
 }
開發者ID:kapai69,項目名稱:fl-ru-damp,代碼行數:23,代碼來源:op_codes.php

示例11: getReqvFields

 /**
  * Возвращает реквизиты физ. и юр. лица
  * 
  * @return array
  */
 function getReqvFields()
 {
     if (!sbr_meta::$reqv_fields) {
         $memBuff = new memBuff();
         $mlife = 1800;
         $rows = $memBuff->getSql($err, 'SELECT * FROM sbr_reqv_fields  ORDER BY pos, name  ', $mlife);
         $ro = $memBuff->getSql($err, 'SELECT * FROM reqv_ordered   LIMIT 1', $mlife);
         $bp = $memBuff->getSql($err, 'SELECT * FROM bank_payments  LIMIT 1', $mlife);
         $fre = '/^_(\\d)_(.*)$/';
         // $1:тип лица (физ. или юр.), $2:имя поля
         if ($rows) {
             foreach ($rows as $row) {
                 if (!preg_match($fre, $row['idname'], $m)) {
                     continue;
                 }
                 $ft = $m[1];
                 $nm = $m[2];
                 $row['bill_bound'] = $ft == sbr::FT_JURI && @array_key_exists($nm, $ro[0]) || $ft == sbr::FT_PHYS && @array_key_exists($nm, $bp[0]);
                 //Переводим битарный тип в массив форм резиденства
                 //которые поддреживает данное поле
                 $rez_type_new = $row['rez_type_new'];
                 $row['rez_type_new'] = array();
                 if (bindec($rez_type_new) > 0) {
                     for ($idx = 0; $idx < strlen($rez_type_new); $idx++) {
                         if (substr($rez_type_new, $idx, 1) == 1) {
                             $row['rez_type_new'][] = $idx + 1;
                             //сопостовление sbr::RT_ ...
                         }
                     }
                 }
                 sbr_meta::$reqv_fields[$ft][$nm] = $row;
             }
         }
     }
     return sbr_meta::$reqv_fields;
 }
開發者ID:Nikitian,項目名稱:fl-ru-damp,代碼行數:41,代碼來源:sbr_meta.php

示例12: Calculate


//.........這裏部分代碼省略.........
                         $profs[] = $v[1];
                     }
                 }
             }
         }
         // если указаны только группы разделов
         if ($op) {
             $res = $DB->query('SELECT prof_group, id, main_prof FROM professions LEFT JOIN mirrored_professions ON mirror_prof = id WHERE prof_group IN (?l)', $op);
             $tmp = array();
             while ($row = pg_fetch_assoc($res)) {
                 $profsgr[] = $row['id'];
                 $tmp[$row['prof_group']] = 1;
                 if ($row['main_prof']) {
                     $profsgr[] = $row['main_prof'];
                 }
             }
             $op = array_keys($tmp);
         }
         $in_ids = implode(array_unique(array_merge($profs, $profsgr)), ',');
         //@todo: здесь лучше бы избавится от подзапроса, но походу никак
         //JOIN не быстрее да и другие результаты выдает
         $whc = " AND (u.spec_orig IN ({$in_ids})\n            OR (u.is_pro = TRUE AND EXISTS(\n                SELECT 1 FROM\n                    spec_add_choise\n                WHERE user_id = u.uid AND prof_id IN ({$in_ids})\n\t\t\t)))";
     } else {
         $whc = " AND u.spec_orig IS NOT NULL AND u.spec_orig > 0";
     }
     //----------------------------------------------------------------------
     // если указано меторасположение, то оно обробатывается своими запросами
     if (($cw || $ow) && !$commit && $this->isCalcMethond('locations')) {
         $locations = array();
         $haveTheir = array();
         // страны без городов
         if ($ow) {
             $sql = "SELECT country, is_pro, COUNT(*) AS cnt FROM freelancer u {$jn} WHERE is_banned = '0' {$whc}{$wh} AND (" . substr($ow, 4) . ") GROUP BY country, is_pro";
             if (!($rows = $memBuff->getSql($error, $sql, 600, false, $memBuffGroup))) {
                 $rows = array();
             }
             foreach ($rows as $row) {
                 $c = "{$row['country']}:0";
                 if (empty($locations[$c])) {
                     $locations[$c] = array('country' => $row['country'], 'city' => 0, 'cost' => 0, 'cost' => 0, 'pro' => array('cost' => 0, 'count' => 0));
                 }
                 $locations[$c]['count'] += $row['cnt'];
                 if ($row['is_pro'] == 't') {
                     $locations[$c]['cost'] += $row['cnt'] * $cost['pro'];
                     $locations[$c]['pro']['count'] += $row['cnt'];
                     $locations[$c]['pro']['cost'] += $row['cnt'] * $cost['pro'];
                 } else {
                     $locations[$c]['cost'] += $row['cnt'] * $cost['no_pro'];
                 }
                 $haveTheir[$row['country']] = TRUE;
             }
         }
         // страны с городами
         if ($cw) {
             $sql = "SELECT country, city, is_pro, COUNT(*) AS cnt FROM freelancer u {$jn} WHERE is_banned = '0' {$whc}{$wh} AND (" . substr($cw, 4) . ") GROUP BY country, city, is_pro";
             if (!($rows = $memBuff->getSql($error, $sql, 600, false, $memBuffGroup))) {
                 $rows = array();
             }
             foreach ($rows as $row) {
                 $c = "{$row['country']}:{$row['city']}";
                 if (empty($locations[$c])) {
                     $locations[$c] = array('country' => $row['country'], 'city' => $row['city'], 'cost' => 0, 'cost' => 0, 'pro' => array('cost' => 0, 'count' => 0));
                 }
                 if (!empty($haveTheir[$row['country']])) {
                     $locations[$c]['no'] = 1;
                 }
開發者ID:Nikitian,項目名稱:fl-ru-damp,代碼行數:67,代碼來源:masssending.php

示例13: getRankCount

 /**
  * Считаем количество фрилансеров различных разрядов СБР
  *
  * @return array Данные подсчета
  */
 function getRankCount($prof_id = 0)
 {
     $memBuff = new memBuff();
     if ($prof_id) {
         $or_prof = professions::GetProfessionOrigin($prof_id);
         $tbl_s = "\n                ( SELECT * FROM fu WHERE spec_orig = '{$or_prof}' UNION ALL\n                  SELECT fu.* FROM fu INNER JOIN spec_add_choise sp ON sp.user_id = fu.uid AND sp.prof_id = '{$or_prof}' WHERE fu.is_pro = true\n                  UNION ALL\n                  SELECT fu.* FROM fu INNER JOIN spec_paid_choise spc ON spc.user_id = fu.uid AND spc.prof_id = '{$or_prof}' AND spc.paid_to > now()\n                ) as s\n            ";
     } else {
         $tbl_s = "fu s";
         $join_pc = "\n              INNER JOIN\n                portf_choise pc\n                  ON pc.prof_id = s.spec_orig\n                 AND pc.user_id = s.uid\n            ";
     }
     $sql = "\n          SELECT SUM((r.rank=3)::int) as rank3, SUM((r.rank=2)::int) as rank2, SUM((r.rank=1)::int) as rank1\n            FROM rating r\n          INNER JOIN\n            {$tbl_s}\n              ON s.uid = r.user_id\n             AND s.is_banned = '0'\n          {$join_pc}\n           WHERE r.rank > 0\n        ";
     $rank = $memBuff->getSql($error, $sql, 3600);
     if ($error || !$rank) {
         return NULL;
     }
     return $rank[0];
 }
開發者ID:amage,項目名稱:fl-ru-damp,代碼行數:22,代碼來源:freelancers_filter.php

示例14: getDocsFlow


//.........這裏部分代碼省略.........
     // документы, после загрузки которых выводим работодателя в док-те.
     $frl_upload_docs_cond = sbr::DOCS_TYPE_ACT;
     if ($scheme) {
         if ($scheme != -1) {
             $where[] = "ss.arch_closed_time > NOW()::date - interval '6 months'";
             $scheme_cond = "AND s.scheme_type = {$scheme}";
             if ($scheme == sbr::SCHEME_PDRD || $scheme == sbr::SCHEME_PDRD2) {
                 $scheme_cond = "AND ( s.scheme_type = {$scheme} OR s.scheme_type = " . sbr::SCHEME_PDRD2 . ')';
             }
         }
         $docs_cond = 'AND su.docs_received = false AND su.is_removed = false';
     } else {
         if ($filter['archive'] == 't') {
             $where[] = "ss.arch_closed_time < NOW()::date - interval '6 months'";
         }
         if ($filter['archive'] == 'f') {
             $where[] = "ss.arch_closed_time >= NOW()::date - interval '6 months'";
         }
     }
     if ($fv = pg_escape_string(trim($filter['contract_num']))) {
         $where[] = "'СБР-'||ss.sbr_id||'-'||ss.num ILIKE '%{$fv}%'";
     }
     if ($fv = pg_escape_string(trim($filter['user']))) {
         $where[] = "(u.login ILIKE '%{$fv}%' OR u.uname ILIKE '%{$fv}%' OR u.usurname ILIKE '%{$fv}%')";
     }
     if ($fv = pg_escape_string(trim($filter['name']))) {
         $where[] = "ss.name ILIKE '%{$fv}%'";
     }
     if ($fv = round((double) str_replace(array(' ', ','), array('', '.'), $filter['act_sum']), 2)) {
         $where[] = "round(su.act_lcomm+su.act_lintr, 2) = {$fv}";
     }
     if ($fv = (int) $filter['act_sys']) {
         $where[] = "ss.act_sys = {$fv}";
     }
     if ($fv = $filter['has_docs']) {
         $where[] = "su.docs_received = '{$fv}'";
     }
     if ($fv = $filter['has_act']) {
         $where[] = '((su.uploaded_docs & ' . sbr::DOCS_TYPE_COPY_ACT . ") <> 0) = '{$fv}'";
     }
     if ($fv = $filter['has_fct']) {
         $where[] = '((su.uploaded_docs & ' . sbr::DOCS_TYPE_COPY_FACTURA . ") <> 0) = '{$fv}'";
     }
     if ($fv = $filter['has_reqv']) {
         $where[] = "COALESCE(sr.is_filled[sr.form_type], false) = '{$fv}'";
     }
     if ($fv = $filter['is_removed']) {
         $where[] = "su.is_removed = '{$fv}'";
     }
     if ($scheme == 0) {
         $where[] = ' ( ss.scheme_type <> ' . sbr::SCHEME_LC . ' ) ';
         // исключаем Аккредитив
     }
     if ($where) {
         $where = 'WHERE ' . implode(' AND ', $where);
     }
     $leftPdrd = 'WHERE sp.completed IS NOT NULL OR su.user_id IS NOT NULL';
     if ($scheme == SBR::SCHEME_PDRD || $scheme == sbr::SCHEME_PDRD2) {
         $leftPdrd = "LEFT JOIN \n                 sbr_stages_users su1 \n                   ON su1.stage_id = wss.id \n                  AND su1.user_id = wss.frl_id \n                  AND (su1.uploaded_docs & {$frl_upload_docs_cond}) <> 0 \n                  WHERE su1.user_id IS NOT NULL OR su.user_id IS NOT NULL\n                  ";
     }
     $from = "\n            FROM (\n              WITH w_sbr_stages AS (\n                SELECT ss.*, s.emp_id, s.frl_id, s.scheme_id, s.scheme_type, s.cost_sys, \n                        arb.resolved, arb.frl_percent\n                  FROM sbr s\n                INNER JOIN\n                  sbr_stages ss\n                    ON ss.sbr_id = s.id\n                LEFT JOIN sbr_stages_arbitrage arb\n                    ON arb.stage_id = ss.id\n                 WHERE s.reserved_id IS NOT NULL\n                   AND s.norisk_id IS NULL\n                       {$scheme_cond}\n              )\n              SELECT wss.*, wss.emp_id as user_id, wss.cost_sys as act_sys,\n                    wss.closed_time as arch_closed_time\n                FROM w_sbr_stages wss \n              LEFT JOIN\n                sbr_stages_payouts sp\n                  ON sp.stage_id = wss.id\n                 AND sp.user_id = wss.frl_id\n              LEFT JOIN\n                sbr_stages_users su\n                  ON su.stage_id = wss.id\n                 AND su.user_id = wss.emp_id\n                 AND (su.uploaded_docs & {$emp_upload_docs_cond}) <> 0\n              {$leftPdrd}  \n              UNION ALL\n              SELECT wss.*, wss.frl_id, sp.credit_sys,\n                    sp.requested as arch_closed_time\n                FROM w_sbr_stages wss\n              INNER JOIN\n                sbr_stages_payouts sp\n                  ON sp.stage_id = wss.id\n                 AND sp.user_id = wss.frl_id\n            ) as ss\n          INNER JOIN\n            sbr_stages_users su\n              ON su.stage_id = ss.id\n             AND su.user_id = ss.user_id\n             {$docs_cond}\n          INNER JOIN\n            users u\n              ON u.uid = ss.user_id\n          LEFT JOIN\n            sbr_reqv sr\n              ON sr.user_id = ss.user_id\n        ";
     $sql = "\n          SELECT ss.*, sr.*, ss.id as stage_id,\n                 su.uploaded_docs, su.docs_received, su.act_lcomm, su.act_lintr, su.act_lndfl, su.act_lnp, su.act_lcomm + su.act_lintr as act_sum, su.act_notnp, su.is_removed,\n                 sp.credit_sys, sp.credit_sum,\n                 u.login, u.uname, u.usurname, u.role,\n                 COALESCE(docs.publ_time, ss.arch_closed_time) as act_upload_time\n          {$from}\n          LEFT JOIN\n            sbr_stages_payouts sp\n\n              ON sp.stage_id = ss.id\n             AND sp.user_id = ss.user_id\n             \n          --LEFT JOIN sbr_docs docs ON docs.stage_id = ss.id AND docs.access_role IN (1,2) AND docs.type IN (1,8) AND docs.is_deleted = false AND docs.owner_role = 0\n          LEFT JOIN (\n                SELECT DISTINCT ON (stage_id, access_role) stage_id, d.publ_time, f.modified, d.access_role FROM sbr_docs d\n                INNER JOIN file_sbr f ON f.id = d.file_id\n                WHERE \n                is_deleted = false AND access_role IN (1,2)\n                AND owner_role = 0\n                ORDER BY stage_id, access_role, publ_time DESC\n          ) docs ON docs.stage_id = ss.id AND (docs.access_role = substring(u.role, 1, 1)::integer + 1)\n          \n          {$where}\n           ORDER BY {$this->form_cols['docsflow'][$dir_col][1][$dir]}\n           LIMIT {$limit} OFFSET {$offset}\n        ";
     /*
               LEFT JOIN (
         SELECT DISTINCT ON (stage_id) stage_id, d.publ_time, f.modified FROM sbr_docs d
         INNER JOIN sbr s ON s.id = d.sbr_id
         INNER JOIN file_sbr f ON f.id = d.file_id
         WHERE type IN (1,8) 
         --AND status = 4 
         AND is_deleted = false AND access_role IN (1,2)
         AND owner_role = 0
         ORDER BY stage_id, publ_time DESC
               ) docs ON docs.stage_id = ss.id
     */
     if ($res = pg_query(self::connect(), $sql)) {
         if ($ret = pg_fetch_all($res)) {
             $account = new account();
             foreach ($ret as &$row) {
                 if ($row['uploaded_docs']) {
                     $access_role = is_emp($row['role']) ? self::DOCS_ACCESS_EMP : self::DOCS_ACCESS_FRL;
                     if ($docs = sbr_meta::getDocs("WHERE sd.stage_id = '{$row['id']}' AND (sd.access_role & {$access_role}) = {$access_role} AND sd.is_deleted = false", null, true)) {
                         $row['uploaded_docs_a'] = array();
                         foreach ($docs as $doc) {
                             $row['uploaded_docs_a'][$doc['type']] = $doc;
                         }
                     }
                 }
                 // это потом переделать
                 $account->GetInfo($row['user_id']);
                 $row['attaches'] = $account->getAllAttach();
             }
             $sql = "SELECT COUNT(1) as cnt {$from} {$where}";
             $mem = new memBuff();
             if ($rows = $mem->getSql($err, $sql, 60)) {
                 $page_count = $rows[0]['cnt'];
             }
         }
     }
     return $ret;
 }
開發者ID:kapai69,項目名稱:fl-ru-damp,代碼行數:101,代碼來源:sbr_adm.php

示例15: getProfiLanding

 /**
  * Список PROFI пользлвателей для лендинга
  * 
  * @param type $limit
  * @return null
  */
 function getProfiLanding($limit = 39)
 {
     $fu_table = self::$fu_table;
     $error = null;
     $sql = "\n            SELECT \n                p.name as profname,\n                s.*\n            FROM {$fu_table} AS s \n            INNER JOIN orders AS o ON o.from_id = s.uid AND o.from_date < NOW() AND (o.from_date + o.to_date) > NOW()\n            LEFT JOIN professions AS p ON p.id = s.spec\n            WHERE \n                s.is_profi = 't' AND s.is_banned = '0'\n            ORDER BY o.from_date DESC\n            LIMIT {$limit}\n        ";
     $memBuff = new memBuff();
     $frls = $memBuff->getSql($error, $sql, self::CATALOG_PROFI_MEM_LIFE, true, self::CATALOG_PROFI_MEM_TAG);
     if ($error || !$frls) {
         return null;
     }
     return $frls;
 }
開發者ID:amage,項目名稱:fl-ru-damp,代碼行數:18,代碼來源:freelancer.php


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