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


PHP WP_Date_Query類代碼示例

本文整理匯總了PHP中WP_Date_Query的典型用法代碼示例。如果您正苦於以下問題:PHP WP_Date_Query類的具體用法?PHP WP_Date_Query怎麽用?PHP WP_Date_Query使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


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

示例1: __construct

 /**
  * Constructor.
  *
  * @param array  $date_query
  * @param string $column
  *
  * @see WP_Date_Query::__construct()
  */
 public function __construct($date_query, $column = '')
 {
     if (!empty($column)) {
         $this->column = $column;
         add_filter('date_query_valid_columns', array($this, 'register_date_column'));
     }
     parent::__construct($date_query, $column);
 }
開發者ID:mawilliamson,項目名稱:wordpress,代碼行數:16,代碼來源:class-bp-date-query.php

示例2: get

 public static function get($args = array(), $output = OBJECT)
 {
     global $wpdb;
     $query = wp_parse_args($args);
     $query_length = count($query);
     $i = 1;
     $table = XBooking_BOOKING_TABLE;
     $where = $query_length > 0 ? 'WHERE ' : '';
     foreach ($query as $column => $value) {
         if ($column == 'date_query') {
             $query_args = array(array('column' => 'date', 'before' => $value['before'], 'inclusive' => true), array('column' => 'date', 'after' => $value['after'], 'inclusive' => true));
             $date_query = new WP_Date_Query($query_args, 'date');
             $where .= $date_query->get_sql();
             // Reduce counter as get_sql produces 'AND' for us
             $i--;
         } else {
             $where .= "{$column} = '{$value}' ";
         }
         $i++;
     }
     $select = "SELECT * FROM {$table} {$where} ORDER BY date DESC";
     // If unique value queried only get single row
     if (isset($query['id'])) {
         $results = $wpdb->get_row($select, $output);
     } else {
         $results = $wpdb->get_results($select, $output);
     }
     return !empty($results) ? $results : false;
 }
開發者ID:sebgrey,項目名稱:xbookings,代碼行數:29,代碼來源:Booking.php

示例3: prepare_query


//.........這裏部分代碼省略.........
         } else {
             // Non-integer key means this the key is the field and the value is ASC/DESC.
             $_orderby = $_key;
             $_order = $_value;
         }
         $parsed = $this->parse_orderby($_orderby);
         if (!$parsed) {
             continue;
         }
         $orderby_array[] = $parsed . ' ' . $this->parse_order($_order);
     }
     // If no valid clauses were found, order by user_login.
     if (empty($orderby_array)) {
         $orderby_array[] = "user_login {$order}";
     }
     $this->query_orderby = 'ORDER BY ' . implode(', ', $orderby_array);
     // limit
     if ($qv['number']) {
         if ($qv['offset']) {
             $this->query_limit = $wpdb->prepare("OFFSET %d ROWS FETCH NEXT %d ROWS ONLY", $qv['offset'], $qv['number']);
         } else {
             $this->query_limit = $wpdb->prepare("OFFSET 0 ROWS FETCH NEXT %d ROWS ONLY", $qv['number']);
         }
     }
     $search = '';
     if (isset($qv['search'])) {
         $search = trim($qv['search']);
     }
     if ($search) {
         $leading_wild = ltrim($search, '*') != $search;
         $trailing_wild = rtrim($search, '*') != $search;
         if ($leading_wild && $trailing_wild) {
             $wild = 'both';
         } elseif ($leading_wild) {
             $wild = 'leading';
         } elseif ($trailing_wild) {
             $wild = 'trailing';
         } else {
             $wild = false;
         }
         if ($wild) {
             $search = trim($search, '*');
         }
         $search_columns = array();
         if ($qv['search_columns']) {
             $search_columns = array_intersect($qv['search_columns'], array('ID', 'user_login', 'user_email', 'user_url', 'user_nicename'));
         }
         if (!$search_columns) {
             if (false !== strpos($search, '@')) {
                 $search_columns = array('user_email');
             } elseif (is_numeric($search)) {
                 $search_columns = array('user_login', 'ID');
             } elseif (preg_match('|^https?://|', $search) && !(is_multisite() && wp_is_large_network('users'))) {
                 $search_columns = array('user_url');
             } else {
                 $search_columns = array('user_login', 'user_nicename');
             }
         }
         /**
          * Filter the columns to search in a WP_User_Query search.
          *
          * The default columns depend on the search term, and include 'user_email',
          * 'user_login', 'ID', 'user_url', and 'user_nicename'.
          *
          * @since 3.6.0
          *
          * @param array         $search_columns Array of column names to be searched.
          * @param string        $search         Text being searched.
          * @param WP_User_Query $this           The current WP_User_Query instance.
          */
         $search_columns = apply_filters('user_search_columns', $search_columns, $search, $this);
         $this->query_where .= $this->get_search_sql($search, $search_columns, $wild);
     }
     if (!empty($include)) {
         // Sanitized earlier.
         $ids = implode(',', $include);
         $this->query_where .= " AND {$wpdb->users}.ID IN ({$ids})";
     } elseif (!empty($qv['exclude'])) {
         $ids = implode(',', wp_parse_id_list($qv['exclude']));
         $this->query_where .= " AND {$wpdb->users}.ID NOT IN ({$ids})";
     }
     // Date queries are allowed for the user_registered field.
     if (!empty($qv['date_query']) && is_array($qv['date_query'])) {
         $date_query = new WP_Date_Query($qv['date_query'], 'user_registered');
         $this->query_where .= $date_query->get_sql();
     }
     /**
      * Fires after the WP_User_Query has been parsed, and before
      * the query is executed.
      *
      * The passed WP_User_Query object contains SQL parts formed
      * from parsing the given query.
      *
      * @since 3.1.0
      *
      * @param WP_User_Query $this The current WP_User_Query instance,
      *                            passed by reference.
      */
     do_action_ref_array('pre_user_query', array(&$this));
 }
開發者ID:remonlam,項目名稱:projectnami,代碼行數:101,代碼來源:user.php

示例4: test_build_time_query_minute_second

 public function test_build_time_query_minute_second()
 {
     $q = new WP_Date_Query(array());
     $found = $q->build_time_query('post_date', '=', null, 15, 35);
     // $compare value is floating point - use regex to account for
     // varying precision on different PHP installations
     $this->assertRegExp("/DATE_FORMAT\\( post_date, '0\\.%i%s' \\) = 0\\.15350*/", $found);
 }
開發者ID:Benrajalu,項目名稱:philRaj,代碼行數:8,代碼來源:query.php

示例5: query


//.........這裏部分代碼省略.........
         $where[] = $wpdb->prepare('user_id = %d', $this->query_vars['user_id']);
     }
     if ('' !== $this->query_vars['search']) {
         $search_sql = $this->get_search_sql($this->query_vars['search'], array('comment_author', 'comment_author_email', 'comment_author_url', 'comment_author_IP', 'comment_content'));
         // Strip leading 'AND'.
         $where[] = preg_replace('/^\\s*AND\\s*/', '', $search_sql);
     }
     // If any post-related query vars are passed, join the posts table.
     $join_posts_table = false;
     $plucked = wp_array_slice_assoc($this->query_vars, array('post_author', 'post_name', 'post_parent', 'post_status', 'post_type'));
     $post_fields = array_filter($plucked);
     if (!empty($post_fields)) {
         $join_posts_table = true;
         foreach ($post_fields as $field_name => $field_value) {
             $where[] = $wpdb->prepare(" {$wpdb->posts}.{$field_name} = %s", $field_value);
         }
     }
     // Comment author IDs for an IN clause.
     if (!empty($this->query_vars['author__in'])) {
         $where[] = 'user_id IN ( ' . implode(',', wp_parse_id_list($this->query_vars['author__in'])) . ' )';
     }
     // Comment author IDs for a NOT IN clause.
     if (!empty($this->query_vars['author__not_in'])) {
         $where[] = 'user_id NOT IN ( ' . implode(',', wp_parse_id_list($this->query_vars['author__not_in'])) . ' )';
     }
     // Post author IDs for an IN clause.
     if (!empty($this->query_vars['post_author__in'])) {
         $join_posts_table = true;
         $where[] = 'post_author IN ( ' . implode(',', wp_parse_id_list($this->query_vars['post_author__in'])) . ' )';
     }
     // Post author IDs for a NOT IN clause.
     if (!empty($this->query_vars['post_author__not_in'])) {
         $join_posts_table = true;
         $where[] = 'post_author NOT IN ( ' . implode(',', wp_parse_id_list($this->query_vars['post_author__not_in'])) . ' )';
     }
     if ($join_posts_table) {
         $join = "JOIN {$wpdb->posts} ON {$wpdb->posts}.ID = {$wpdb->comments}.comment_post_ID";
     }
     if (!empty($this->meta_query->queries)) {
         $clauses = $this->meta_query->get_sql('comment', $wpdb->comments, 'comment_ID', $this);
         $join .= $clauses['join'];
         // Strip leading 'AND'.
         $where[] = preg_replace('/^\\s*AND\\s*/', '', $clauses['where']);
         if (!$this->query_vars['count']) {
             $groupby = "{$wpdb->comments}.comment_ID";
         }
     }
     $date_query = $this->query_vars['date_query'];
     if (!empty($date_query) && is_array($date_query)) {
         $date_query_object = new WP_Date_Query($date_query, 'comment_date');
         $where[] = preg_replace('/^\\s*AND\\s*/', '', $date_query_object->get_sql());
     }
     $where = implode(' AND ', $where);
     $pieces = array('fields', 'join', 'where', 'orderby', 'order', 'limits', 'groupby');
     /**
      * Filter the comment query clauses.
      *
      * @since 3.1.0
      *
      * @param array            $pieces A compacted array of comment query clauses.
      * @param WP_Comment_Query &$this  Current instance of WP_Comment_Query, passed by reference.
      */
     $clauses = apply_filters_ref_array('comments_clauses', array(compact($pieces), &$this));
     $fields = isset($clauses['fields']) ? $clauses['fields'] : '';
     $join = isset($clauses['join']) ? $clauses['join'] : '';
     $where = isset($clauses['where']) ? $clauses['where'] : '';
     $orderby = isset($clauses['orderby']) ? $clauses['orderby'] : '';
     $order = isset($clauses['order']) ? $clauses['order'] : '';
     $limits = isset($clauses['limits']) ? $clauses['limits'] : '';
     $groupby = isset($clauses['groupby']) ? $clauses['groupby'] : '';
     if ($where) {
         $where = 'WHERE ' . $where;
     }
     if ($groupby) {
         $groupby = 'GROUP BY ' . $groupby;
     }
     if ($orderby) {
         $orderby = "ORDER BY {$orderby} {$order}";
     }
     $this->request = "SELECT {$fields} FROM {$wpdb->comments} {$join} {$where} {$groupby} {$orderby} {$limits}";
     if ($this->query_vars['count']) {
         return $wpdb->get_var($this->request);
     }
     if ('ids' == $this->query_vars['fields']) {
         $this->comments = $wpdb->get_col($this->request);
         return array_map('intval', $this->comments);
     }
     $results = $wpdb->get_results($this->request);
     /**
      * Filter the comment query results.
      *
      * @since 3.1.0
      *
      * @param array            $results  An array of comments.
      * @param WP_Comment_Query &$this    Current instance of WP_Comment_Query, passed by reference.
      */
     $comments = apply_filters_ref_array('the_comments', array($results, &$this));
     wp_cache_add($cache_key, $comments, 'comment');
     return $comments;
 }
開發者ID:sunyang3721,項目名稱:wp-for-sae,代碼行數:101,代碼來源:comment.php

示例6: get_commissions

 /**
  * Get Commissions
  *
  * @param array $q
  *
  * @return array
  * @author Andrea Grillo <andrea.grillo@yithemes.com>
  * @since  1.0
  */
 public function get_commissions($q = array())
 {
     global $wpdb;
     $default_args = array('line_item_id' => 0, 'product_id' => 0, 'order_id' => 0, 'user_id' => 0, 'vendor_id' => 0, 'status' => 'unpaid', 'm' => false, 'date_query' => false, 's' => '', 'number' => '', 'offset' => '', 'paged' => '', 'orderby' => 'ID', 'order' => 'ASC', 'fields' => 'ids');
     foreach (array('order_id', 'vendor_id', 'status', 'paged', 'm', 's', 'orderby', 'order', 'product_id') as $key) {
         if (isset($_REQUEST[$key])) {
             $default_args[$key] = $_REQUEST[$key];
         }
     }
     $q = wp_parse_args($q, $default_args);
     // Fairly insane upper bound for search string lengths.
     if (!is_scalar($q['s']) || !empty($q['s']) && strlen($q['s']) > 1600) {
         $q['s'] = '';
     }
     // First let's clear some variables
     $where = '';
     $limits = '';
     $join = '';
     $groupby = '';
     $orderby = '';
     // query parts initializating
     $pieces = array('where', 'groupby', 'join', 'orderby', 'limits');
     // filter
     if (!empty($q['line_item_id'])) {
         $where .= $wpdb->prepare(" AND c.line_item_id = %d", $q['line_item_id']);
     }
     if (!empty($q['product_id'])) {
         $join .= " JOIN {$wpdb->prefix}woocommerce_order_items oi ON ( oi.order_item_id = c.line_item_id AND oi.order_id = c.order_id )";
         $join .= " JOIN {$wpdb->prefix}woocommerce_order_itemmeta oim ON ( oim.order_item_id = oi.order_item_id )";
         $where .= $wpdb->prepare(" AND oim.meta_key = %s AND oim.meta_value = %s", '_product_id', $q['product_id']);
     }
     if (!empty($q['order_id'])) {
         $where .= $wpdb->prepare(" AND c.order_id = %d", $q['order_id']);
     }
     if (!empty($q['user_id'])) {
         $where .= $wpdb->prepare(" AND c.user_id = %d", $q['user_id']);
     }
     if (!empty($q['vendor_id'])) {
         $where .= $wpdb->prepare(" AND c.vendor_id = %d", $q['vendor_id']);
     }
     if (!empty($q['status']) && 'all' != $q['status']) {
         if (is_array($q['status'])) {
             $q['status'] = implode("', '", $q['status']);
         }
         $where .= sprintf(" AND c.status IN ( '%s' )", $q['status']);
     }
     // The "m" parameter is meant for months but accepts datetimes of varying specificity
     if ($q['m']) {
         $q['m'] = absint(preg_replace('|[^0-9]|', '', $q['m']));
         $join .= strpos($join, "{$wpdb->posts} o") === false ? " JOIN {$wpdb->posts} o ON o.ID = c.order_id" : '';
         $where .= " AND o.post_type = 'shop_order'";
         $where .= " AND YEAR(o.post_date)=" . substr($q['m'], 0, 4);
         if (strlen($q['m']) > 5) {
             $where .= " AND MONTH(o.post_date)=" . substr($q['m'], 4, 2);
         }
         if (strlen($q['m']) > 7) {
             $where .= " AND DAYOFMONTH(o.post_date)=" . substr($q['m'], 6, 2);
         }
         if (strlen($q['m']) > 9) {
             $where .= " AND HOUR(o.post_date)=" . substr($q['m'], 8, 2);
         }
         if (strlen($q['m']) > 11) {
             $where .= " AND MINUTE(o.post_date)=" . substr($q['m'], 10, 2);
         }
         if (strlen($q['m']) > 13) {
             $where .= " AND SECOND(o.post_date)=" . substr($q['m'], 12, 2);
         }
     }
     // Handle complex date queries
     if (!empty($q['date_query'])) {
         $join .= strpos($join, "{$wpdb->posts} o") === false ? " JOIN {$wpdb->posts} o ON o.ID = c.order_id" : '';
         $where .= " AND o.post_type = 'shop_order'";
         $date_query = new WP_Date_Query($q['date_query'], 'o.post_date');
         $where .= $date_query->get_sql();
     }
     // Search
     if ($q['s']) {
         // added slashes screw with quote grouping when done early, so done later
         $q['s'] = stripslashes($q['s']);
         // there are no line breaks in <input /> fields
         $q['s'] = str_replace(array("\r", "\n"), '', $q['s']);
         // order
         $join .= strpos($join, "{$wpdb->posts} o") === false ? " JOIN {$wpdb->posts} o ON o.ID = c.order_id" : '';
         // product
         $join .= strpos($join, 'woocommerce_order_items') === false ? " JOIN {$wpdb->prefix}woocommerce_order_items oi ON ( oi.order_item_id = c.line_item_id AND oi.order_id = c.order_id )" : '';
         $where .= " AND oi.order_item_type = 'line_item'";
         // user
         $join .= " JOIN {$wpdb->users} u ON u.ID = c.user_id";
         $join .= " JOIN {$wpdb->usermeta} um ON um.user_id = c.user_id";
         $join .= " JOIN {$wpdb->usermeta} um2 ON um2.user_id = c.user_id";
         $where .= " AND um.meta_key = 'first_name'";
//.........這裏部分代碼省略.........
開發者ID:kanhaiyasharma,項目名稱:Bestswiss,代碼行數:101,代碼來源:class.yith-commissions.php

示例7: wp_get_archives

 public static function wp_get_archives($args = array())
 {
     global $wpdb, $wp_rewrite;
     $r = wp_parse_args($args, array('type' => 'monthly', 'post_type' => 'post', 'order' => 'DESC', 'date_query' => null));
     $r['post_type'] = sanitize_key($r['post_type']);
     if (!post_type_exists($r['post_type'])) {
         return array();
     }
     if ('' == $r['type']) {
         $r['type'] = 'monthly';
     }
     $order = strtoupper($r['order']);
     if ($order !== 'ASC') {
         $order = 'DESC';
     }
     $where = " WHERE {$wpdb->posts}.post_type = '" . $r['post_type'] . "' AND {$wpdb->posts}.post_status = 'publish'";
     if (!empty($r['date_query'])) {
         $date_query = new WP_Date_Query($r['date_query']);
         $where .= $date_query->get_sql();
     }
     $where = apply_filters('getarchives_where', $where, $args);
     $where = apply_filters('ry_getarchives_where', $where, $args);
     $join = '';
     $join = apply_filters('getarchives_join', $join, $args);
     $join = apply_filters('ry_getarchives_join', $join, $args);
     $last_changed = wp_cache_get('last_changed', 'posts');
     if (!$last_changed) {
         $last_changed = microtime();
         wp_cache_set('last_changed', $last_changed, 'posts');
     }
     $list = array();
     if ('monthly' == $r['type']) {
         $query = "SELECT YEAR({$wpdb->posts}.post_date) AS `year`, MONTH({$wpdb->posts}.post_date) AS `month` FROM {$wpdb->posts} {$join} {$where} GROUP BY YEAR({$wpdb->posts}.post_date), MONTH({$wpdb->posts}.post_date) ORDER BY {$wpdb->posts}.post_date {$order} {$limit}";
         $key = md5($query);
         $key = "RY_CP_wp_get_archives:{$key}:{$last_changed}";
         if (!($results = wp_cache_get($key, 'posts'))) {
             $results = $wpdb->get_results($query);
             wp_cache_set($key, $results, 'posts');
         }
         if ($results) {
             $permalink_type = $wp_rewrite->get_month_permastruct();
             $permalink_type = empty($permalink_type);
             foreach ((array) $results as $result) {
                 $url = get_month_link($result->year, $result->month);
                 if ($r['post_type'] != 'post') {
                     if ($permalink_type) {
                         $url .= '&post_type=' . $r['post_type'];
                     } else {
                         $url = str_replace('/date/', '/date/' . $r['post_type'] . '/', $url);
                     }
                 }
                 $list[] = array('year' => $result->year, 'month' => $result->month, 'day' => 0, 'url' => $url);
             }
         }
     } elseif ('yearly' == $r['type']) {
         $query = "SELECT YEAR({$wpdb->posts}.post_date) AS `year` FROM {$wpdb->posts} {$join} {$where} GROUP BY YEAR({$wpdb->posts}.post_date) ORDER BY {$wpdb->posts}.post_date {$order} {$limit}";
         $key = md5($query);
         $key = "RY_CP_wp_get_archives:{$key}:{$last_changed}";
         if (!($results = wp_cache_get($key, 'posts'))) {
             $results = $wpdb->get_results($query);
             wp_cache_set($key, $results, 'posts');
         }
         if ($results) {
             $permalink_type = $wp_rewrite->get_year_permastruct();
             $permalink_type = empty($permalink_type);
             foreach ((array) $results as $result) {
                 $url = get_year_link($result->year);
                 if ($r['post_type'] != 'post') {
                     if ($permalink_type) {
                         $url .= '&post_type=' . $r['post_type'];
                     } else {
                         $url = str_replace('/date/', '/date/' . $r['post_type'] . '/', $url);
                     }
                 }
                 $list[] = array('year' => $result->year, 'month' => 0, 'day' => 0, 'url' => $url);
             }
         }
     } elseif ('daily' == $r['type']) {
         $query = "SELECT YEAR({$wpdb->posts}.post_date) AS `year`, MONTH({$wpdb->posts}.post_date) AS `month`, DAYOFMONTH({$wpdb->posts}.post_date) AS `day` FROM {$wpdb->posts} {$join} {$where} GROUP BY YEAR({$wpdb->posts}.post_date), MONTH({$wpdb->posts}.post_date), DAYOFMONTH({$wpdb->posts}.post_date) ORDER BY {$wpdb->posts}.post_date {$order} {$limit}";
         $key = md5($query);
         $key = "RY_CP_wp_get_archives:{$key}:{$last_changed}";
         if (!($results = wp_cache_get($key, 'posts'))) {
             $results = $wpdb->get_results($query);
             wp_cache_set($key, $results, 'posts');
         }
         if ($results) {
             $archive_day_date_format = 'Y/m/d';
             if (!(bool) $r['over_date']) {
                 $archive_day_date_format = get_option('date_format');
             }
             $permalink_type = $wp_rewrite->get_day_permastruct();
             $permalink_type = empty($permalink_type);
             foreach ((array) $results as $result) {
                 $url = get_day_link($result->year, $result->month, $result->day);
                 if ($r['post_type'] != 'post') {
                     if ($permalink_type) {
                         $url .= '&post_type=' . $r['post_type'];
                     } else {
                         $url = str_replace('/date/', '/date/' . $r['post_type'] . '/', $url);
                     }
//.........這裏部分代碼省略.........
開發者ID:RicherYang,項目名稱:ry-custom-pagination,代碼行數:101,代碼來源:class.ry-cp.php

示例8: get_posts


//.........這裏部分代碼省略.........
             $where .= " AND HOUR({$this->db->posts}.post_date)=" . substr($q['m'], 8, 2);
         }
         if (strlen($q['m']) > 11) {
             $where .= " AND MINUTE({$this->db->posts}.post_date)=" . substr($q['m'], 10, 2);
         }
         if (strlen($q['m']) > 13) {
             $where .= " AND SECOND({$this->db->posts}.post_date)=" . substr($q['m'], 12, 2);
         }
     }
     // Handle the other individual date parameters
     $date_parameters = array();
     if ('' !== $q['hour']) {
         $date_parameters['hour'] = $q['hour'];
     }
     if ('' !== $q['minute']) {
         $date_parameters['minute'] = $q['minute'];
     }
     if ('' !== $q['second']) {
         $date_parameters['second'] = $q['second'];
     }
     if ($q['year']) {
         $date_parameters['year'] = $q['year'];
     }
     if ($q['monthnum']) {
         $date_parameters['monthnum'] = $q['monthnum'];
     }
     if ($q['w']) {
         $date_parameters['week'] = $q['w'];
     }
     if ($q['day']) {
         $date_parameters['day'] = $q['day'];
     }
     if ($date_parameters) {
         $date_query = new WP_Date_Query(array($date_parameters));
         $where .= $date_query->get_sql();
     }
     unset($date_parameters, $date_query);
     // Handle complex date queries
     if (!empty($q['date_query'])) {
         $this->date_query = new WP_Date_Query($q['date_query']);
         $where .= $this->date_query->get_sql();
     }
     // If we've got a post_type AND it's not "any" post_type.
     if (!empty($q['post_type']) && 'any' != $q['post_type']) {
         foreach ((array) $q['post_type'] as $_post_type) {
             $ptype_obj = get_post_type_object($_post_type);
             if (!$ptype_obj || !$ptype_obj->query_var || empty($q[$ptype_obj->query_var])) {
                 continue;
             }
             if (!$ptype_obj->hierarchical) {
                 // Non-hierarchical post types can directly use 'name'.
                 $q['name'] = $q[$ptype_obj->query_var];
             } else {
                 // Hierarchical post types will operate through 'pagename'.
                 $q['pagename'] = $q[$ptype_obj->query_var];
                 $q['name'] = '';
             }
             // Only one request for a slug is possible, this is why name & pagename are overwritten above.
             break;
         }
         //end foreach
         unset($ptype_obj);
     }
     if ('' !== $q['title']) {
         $where .= $this->db->prepare(" AND {$this->db->posts}.post_title = %s", stripslashes($q['title']));
     }
開發者ID:inpsyde,項目名稱:wordpress-dev,代碼行數:67,代碼來源:class-wp-query.php

示例9: get_posts


//.........這裏部分代碼省略.........
             $where .= " AND HOUR({$wpdb->posts}.post_date)=" . substr($q['m'], 8, 2);
         }
         if (strlen($q['m']) > 11) {
             $where .= " AND MINUTE({$wpdb->posts}.post_date)=" . substr($q['m'], 10, 2);
         }
         if (strlen($q['m']) > 13) {
             $where .= " AND SECOND({$wpdb->posts}.post_date)=" . substr($q['m'], 12, 2);
         }
     }
     // Handle the other individual date parameters
     $date_parameters = array();
     if ('' !== $q['hour']) {
         $date_parameters['hour'] = $q['hour'];
     }
     if ('' !== $q['minute']) {
         $date_parameters['minute'] = $q['minute'];
     }
     if ('' !== $q['second']) {
         $date_parameters['second'] = $q['second'];
     }
     if ($q['year']) {
         $date_parameters['year'] = $q['year'];
     }
     if ($q['monthnum']) {
         $date_parameters['monthnum'] = $q['monthnum'];
     }
     if ($q['w']) {
         $date_parameters['week'] = $q['w'];
     }
     if ($q['day']) {
         $date_parameters['day'] = $q['day'];
     }
     if ($date_parameters) {
         $date_query = new WP_Date_Query(array($date_parameters));
         $where .= $date_query->get_sql();
     }
     unset($date_parameters, $date_query);
     // Handle complex date queries
     if (!empty($q['date_query'])) {
         $this->date_query = new WP_Date_Query($q['date_query']);
         $where .= $this->date_query->get_sql();
     }
     // If we've got a post_type AND it's not "any" post_type.
     if (!empty($q['post_type']) && 'any' != $q['post_type']) {
         foreach ((array) $q['post_type'] as $_post_type) {
             $ptype_obj = get_post_type_object($_post_type);
             if (!$ptype_obj || !$ptype_obj->query_var || empty($q[$ptype_obj->query_var])) {
                 continue;
             }
             if (!$ptype_obj->hierarchical || strpos($q[$ptype_obj->query_var], '/') === false) {
                 // Non-hierarchical post_types & parent-level-hierarchical post_types can directly use 'name'
                 $q['name'] = $q[$ptype_obj->query_var];
             } else {
                 // Hierarchical post_types will operate through the
                 $q['pagename'] = $q[$ptype_obj->query_var];
                 $q['name'] = '';
             }
             // Only one request for a slug is possible, this is why name & pagename are overwritten above.
             break;
         }
         //end foreach
         unset($ptype_obj);
     }
     if ('' != $q['name']) {
         $q['name'] = sanitize_title_for_query($q['name']);
         $where .= " AND {$wpdb->posts}.post_name = '" . $q['name'] . "'";
開發者ID:Nancers,項目名稱:Snancy-Website-Files,代碼行數:67,代碼來源:query.php

示例10: date_where

 /**
  * Inject the date_query SQL in SearchWP's WHERE
  *
  * @since 2.6
  *
  * @param $sql
  * @param $engine
  *
  * @return string
  */
 function date_where($sql, $engine)
 {
     if ($engine != $this->engine || empty($this->date_query) || !is_array($this->date_query)) {
         return $sql;
     }
     $date_query = new WP_Date_Query((array) $this->date_query);
     $dq_sql = $date_query->get_sql();
     return $sql . $dq_sql;
 }
開發者ID:acutedeveloper,項目名稱:havering-intranet-development,代碼行數:19,代碼來源:class.swp-query.php

示例11: get_following

 /**
  * Get the IDs that a user is following.
  *
  * @since 1.0.0
  *
  * @param int $user_id The user ID.
  * @param string $follow_type The follow type.  Leave blank to query users.
  * @param array $query_args {
  *     Various query arguments
  *     @type array $date_query See {@link WP_Date_Query}.
  *     @type string $orderby The DB column to order results by. Default: 'id'.
  *     @type string $order The order. Either 'ASC' or 'DESC'. Default: 'DESC'.
  * }
  * @return array
  */
 public static function get_following($user_id = 0, $follow_type = '', $query_args = array())
 {
     global $wpdb;
     // SQL statement
     $sql = self::get_select_sql('leader_id');
     $sql .= self::get_where_sql(array('follower_id' => $user_id, 'follow_type' => $follow_type));
     // Setup date query
     if (!empty($query_args['date_query']) && class_exists('WP_Date_Query')) {
         add_filter('date_query_valid_columns', array(__CLASS__, 'register_date_column'));
         $date_query = new WP_Date_Query($query_args['date_query'], 'date_recorded');
         $sql .= $date_query->get_sql();
         remove_filter('date_query_valid_columns', array(__CLASS__, 'register_date_column'));
     }
     // Setup orderby query
     $orderby = array();
     if (!empty($query_args['orderby'])) {
         $orderby = $query_args['orderby'];
     }
     if (!empty($query_args['order'])) {
         $orderby = $query_args['order'];
     }
     $sql .= self::get_orderby_sql($orderby);
     // do the query
     return $wpdb->get_col($sql);
 }
開發者ID:socialray,項目名稱:surfied-2-0,代碼行數:40,代碼來源:bp-follow-classes.php

示例12: prepare_query


//.........這裏部分代碼省略.........
         if ($wild) {
             $search = trim($search, '*');
         }
         $search_columns = array();
         if ($qv['search_columns']) {
             $search_columns = array_intersect($qv['search_columns'], array('ID', 'user_login', 'user_email', 'user_url', 'user_nicename'));
         }
         if (!$search_columns) {
             if (false !== strpos($search, '@')) {
                 $search_columns = array('user_email');
             } elseif (is_numeric($search)) {
                 $search_columns = array('user_login', 'ID');
             } elseif (preg_match('|^https?://|', $search) && !(is_multisite() && wp_is_large_network('users'))) {
                 $search_columns = array('user_url');
             } else {
                 $search_columns = array('user_login', 'user_nicename');
             }
         }
         /**
          * Filter the columns to search in a WP_User_Query search.
          *
          * The default columns depend on the search term, and include 'user_email',
          * 'user_login', 'ID', 'user_url', and 'user_nicename'.
          *
          * @since 3.6.0
          *
          * @param array         $search_columns Array of column names to be searched.
          * @param string        $search         Text being searched.
          * @param WP_User_Query $this           The current WP_User_Query instance.
          */
         $search_columns = apply_filters('user_search_columns', $search_columns, $search, $this);
         $this->query_where .= $this->get_search_sql($search, $search_columns, $wild);
     }
     $blog_id = 0;
     if (isset($qv['blog_id'])) {
         $blog_id = absint($qv['blog_id']);
     }
     if (isset($qv['who']) && 'authors' == $qv['who'] && $blog_id) {
         $qv['meta_key'] = $wpdb->get_blog_prefix($blog_id) . 'user_level';
         $qv['meta_value'] = 0;
         $qv['meta_compare'] = '!=';
         $qv['blog_id'] = $blog_id = 0;
         // Prevent extra meta query
     }
     $meta_query = new WP_Meta_Query();
     $meta_query->parse_query_vars($qv);
     $role = '';
     if (isset($qv['role'])) {
         $role = trim($qv['role']);
     }
     if ($blog_id && ($role || is_multisite())) {
         $cap_meta_query = array();
         $cap_meta_query['key'] = $wpdb->get_blog_prefix($blog_id) . 'capabilities';
         if ($role) {
             $cap_meta_query['value'] = '"' . $role . '"';
             $cap_meta_query['compare'] = 'like';
         }
         if (empty($meta_query->queries)) {
             $meta_query->queries = array($cap_meta_query);
         } elseif (!in_array($cap_meta_query, $meta_query->queries, true)) {
             // Append the cap query to the original queries and reparse the query.
             $meta_query->queries = array('relation' => 'AND', array($meta_query->queries, $cap_meta_query));
         }
         $meta_query->parse_query_vars($meta_query->queries);
     }
     if (!empty($meta_query->queries)) {
         $clauses = $meta_query->get_sql('user', $wpdb->users, 'ID', $this);
         $this->query_from .= $clauses['join'];
         $this->query_where .= $clauses['where'];
         if ('OR' == $meta_query->relation) {
             $this->query_fields = 'DISTINCT ' . $this->query_fields;
         }
     }
     if (!empty($include)) {
         // Sanitized earlier.
         $ids = implode(',', $include);
         $this->query_where .= " AND {$wpdb->users}.ID IN ({$ids})";
     } elseif (!empty($qv['exclude'])) {
         $ids = implode(',', wp_parse_id_list($qv['exclude']));
         $this->query_where .= " AND {$wpdb->users}.ID NOT IN ({$ids})";
     }
     // Date queries are allowed for the user_registered field.
     if (!empty($qv['date_query']) && is_array($qv['date_query'])) {
         $date_query = new WP_Date_Query($qv['date_query'], 'user_registered');
         $this->query_where .= $date_query->get_sql();
     }
     /**
      * Fires after the WP_User_Query has been parsed, and before
      * the query is executed.
      *
      * The passed WP_User_Query object contains SQL parts formed
      * from parsing the given query.
      *
      * @since 3.1.0
      *
      * @param WP_User_Query $this The current WP_User_Query instance,
      *                            passed by reference.
      */
     do_action_ref_array('pre_user_query', array(&$this));
 }
開發者ID:trinoamez,項目名稱:WordpressPlatzi,代碼行數:101,代碼來源:user.php

示例13: query


//.........這裏部分代碼省略.........
     // Parse comment IDs for an IN clause.
     if (!empty($this->query_vars['comment__in'])) {
         $where .= ' AND comment_ID IN ( ' . implode(',', wp_parse_id_list($this->query_vars['comment__in'])) . ' )';
     }
     // Parse comment IDs for a NOT IN clause.
     if (!empty($this->query_vars['comment__not_in'])) {
         $where .= ' AND comment_ID NOT IN ( ' . implode(',', wp_parse_id_list($this->query_vars['comment__not_in'])) . ' )';
     }
     // Parse comment post IDs for an IN clause.
     if (!empty($this->query_vars['post__in'])) {
         $where .= ' AND comment_post_ID IN ( ' . implode(',', wp_parse_id_list($this->query_vars['post__in'])) . ' )';
     }
     // Parse comment post IDs for a NOT IN clause.
     if (!empty($this->query_vars['post__not_in'])) {
         $where .= ' AND comment_post_ID NOT IN ( ' . implode(',', wp_parse_id_list($this->query_vars['post__not_in'])) . ' )';
     }
     if ('' !== $this->query_vars['author_email']) {
         $where .= $wpdb->prepare(' AND comment_author_email = %s', $this->query_vars['author_email']);
     }
     if ('' !== $this->query_vars['karma']) {
         $where .= $wpdb->prepare(' AND comment_karma = %d', $this->query_vars['karma']);
     }
     if ('comment' == $this->query_vars['type']) {
         $where .= " AND comment_type = ''";
     } elseif ('pings' == $this->query_vars['type']) {
         $where .= ' AND comment_type IN ("pingback", "trackback")';
     } elseif (!empty($this->query_vars['type'])) {
         $where .= $wpdb->prepare(' AND comment_type = %s', $this->query_vars['type']);
     }
     if ('' !== $this->query_vars['parent']) {
         $where .= $wpdb->prepare(' AND comment_parent = %d', $this->query_vars['parent']);
     }
     if (is_array($this->query_vars['user_id'])) {
         $where .= ' AND user_id IN (' . implode(',', array_map('absint', $this->query_vars['user_id'])) . ')';
     } elseif ('' !== $this->query_vars['user_id']) {
         $where .= $wpdb->prepare(' AND user_id = %d', $this->query_vars['user_id']);
     }
     if ('' !== $this->query_vars['search']) {
         $where .= $this->get_search_sql($this->query_vars['search'], array('comment_author', 'comment_author_email', 'comment_author_url', 'comment_author_IP', 'comment_content'));
     }
     $plucked = wp_array_slice_assoc($this->query_vars, array('post_author', 'post_name', 'post_parent', 'post_status', 'post_type'));
     $post_fields = array_filter($plucked);
     if (!empty($post_fields)) {
         $join = "JOIN {$wpdb->posts} ON {$wpdb->posts}.ID = {$wpdb->comments}.comment_post_ID";
         foreach ($post_fields as $field_name => $field_value) {
             $where .= $wpdb->prepare(" AND {$wpdb->posts}.{$field_name} = %s", $field_value);
         }
     }
     if (!empty($this->meta_query->queries)) {
         $clauses = $this->meta_query->get_sql('comment', $wpdb->comments, 'comment_ID', $this);
         $join .= $clauses['join'];
         $where .= $clauses['where'];
         $groupby = "{$wpdb->comments}.comment_ID";
     }
     $date_query = $this->query_vars['date_query'];
     if (!empty($date_query) && is_array($date_query)) {
         $date_query_object = new WP_Date_Query($date_query, 'comment_date');
         $where .= $date_query_object->get_sql();
     }
     $pieces = array('fields', 'join', 'where', 'orderby', 'order', 'limits', 'groupby');
     /**
      * Filter the comment query clauses.
      *
      * @since 3.1.0
      *
      * @param array            $pieces A compacted array of comment query clauses.
      * @param WP_Comment_Query &$this  Current instance of WP_Comment_Query, passed by reference.
      */
     $clauses = apply_filters_ref_array('comments_clauses', array(compact($pieces), &$this));
     $fields = isset($clauses['fields']) ? $clauses['fields'] : '';
     $join = isset($clauses['join']) ? $clauses['join'] : '';
     $where = isset($clauses['where']) ? $clauses['where'] : '';
     $orderby = isset($clauses['orderby']) ? $clauses['orderby'] : '';
     $order = isset($clauses['order']) ? $clauses['order'] : '';
     $limits = isset($clauses['limits']) ? $clauses['limits'] : '';
     $groupby = isset($clauses['groupby']) ? $clauses['groupby'] : '';
     if ($groupby) {
         $groupby = 'GROUP BY ' . $groupby;
     }
     $query = "SELECT {$fields} FROM {$wpdb->comments} {$join} WHERE {$where} {$groupby} ORDER BY {$orderby} {$order} {$limits}";
     if ($this->query_vars['count']) {
         return $wpdb->get_var($query);
     }
     if ('ids' == $this->query_vars['fields']) {
         $this->comments = $wpdb->get_col($query);
         return array_map('intval', $this->comments);
     }
     $results = $wpdb->get_results($query);
     /**
      * Filter the comment query results.
      *
      * @since 3.1.0
      *
      * @param array            $results  An array of comments.
      * @param WP_Comment_Query &$this    Current instance of WP_Comment_Query, passed by reference.
      */
     $comments = apply_filters_ref_array('the_comments', array($results, &$this));
     wp_cache_add($cache_key, $comments, 'comment');
     return $comments;
 }
開發者ID:justatechnology,項目名稱:Security,代碼行數:101,代碼來源:comment.php

示例14: do_action_ref_array


//.........這裏部分代碼省略.........
         }
         if (strlen($q['m']) > 7) {
             $where .= " AND DAYOFMONTH({$this->network_posts}.post_date)=" . substr($q['m'], 6, 2);
         }
         if (strlen($q['m']) > 9) {
             $where .= " AND HOUR({$this->network_posts}.post_date)=" . substr($q['m'], 8, 2);
         }
         if (strlen($q['m']) > 11) {
             $where .= " AND MINUTE({$this->network_posts}.post_date)=" . substr($q['m'], 10, 2);
         }
         if (strlen($q['m']) > 13) {
             $where .= " AND SECOND({$this->network_posts}.post_date)=" . substr($q['m'], 12, 2);
         }
     }
     if ('' !== $q['hour']) {
         $where .= " AND HOUR({$this->network_posts}.post_date)='" . $q['hour'] . "'";
     }
     if ('' !== $q['minute']) {
         $where .= " AND MINUTE({$this->network_posts}.post_date)='" . $q['minute'] . "'";
     }
     if ('' !== $q['second']) {
         $where .= " AND SECOND({$this->network_posts}.post_date)='" . $q['second'] . "'";
     }
     if ($q['year']) {
         $where .= " AND YEAR({$this->network_posts}.post_date)='" . $q['year'] . "'";
     }
     if ($q['monthnum']) {
         $where .= " AND MONTH({$this->network_posts}.post_date)='" . $q['monthnum'] . "'";
     }
     if ($q['day']) {
         $where .= " AND DAYOFMONTH({$this->network_posts}.post_date)='" . $q['day'] . "'";
     }
     if (isset($q['date_query'])) {
         $date_query = new WP_Date_Query($q['date_query'], 'wp_network_posts.post_date');
         $where .= $date_query->get_sql();
     }
     // If we've got a post_type AND its not "any" post_type.
     if (!empty($q['post_type']) && 'any' != $q['post_type']) {
         foreach ((array) $q['post_type'] as $_post_type) {
             $ptype_obj = get_post_type_object($_post_type);
             if (!$ptype_obj || !$ptype_obj->query_var || empty($q[$ptype_obj->query_var])) {
                 continue;
             }
             if (!$ptype_obj->hierarchical || strpos($q[$ptype_obj->query_var], '/') === false) {
                 // Non-hierarchical post_types & parent-level-hierarchical post_types can directly use 'name'
                 $q['name'] = $q[$ptype_obj->query_var];
             } else {
                 // Hierarchical post_types will operate through the
                 $q['pagename'] = $q[$ptype_obj->query_var];
                 $q['name'] = '';
             }
             // Only one request for a slug is possible, this is why name & pagename are overwritten above.
             break;
         }
         //end foreach
         unset($ptype_obj);
     }
     if ('' != $q['name']) {
         $q['name'] = sanitize_title_for_query($q['name']);
         $where .= " AND {$this->network_posts}.post_name = '" . $q['name'] . "'";
     } elseif ('' != $q['pagename']) {
         if (isset($this->queried_object_id)) {
             $reqpage = $this->queried_object_id;
         } else {
             if ('page' != $q['post_type']) {
                 foreach ((array) $q['post_type'] as $_post_type) {
開發者ID:ryan2407,項目名稱:Vision,代碼行數:67,代碼來源:networkquery.php

示例15: query


//.........這裏部分代碼省略.........
         $approved = "( comment_approved = '0' OR comment_approved = '1' )";
     }
     $order = 'ASC' == strtoupper($order) ? 'ASC' : 'DESC';
     if (!empty($orderby)) {
         $ordersby = is_array($orderby) ? $orderby : preg_split('/[,\\s]/', $orderby);
         $allowed_keys = array('comment_agent', 'comment_approved', 'comment_author', 'comment_author_email', 'comment_author_IP', 'comment_author_url', 'comment_content', 'comment_date', 'comment_date_gmt', 'comment_ID', 'comment_karma', 'comment_parent', 'comment_post_ID', 'comment_type', 'user_id');
         if (!empty($this->query_vars['meta_key'])) {
             $allowed_keys[] = $this->query_vars['meta_key'];
             $allowed_keys[] = 'meta_value';
             $allowed_keys[] = 'meta_value_num';
         }
         $ordersby = array_intersect($ordersby, $allowed_keys);
         foreach ($ordersby as $key => $value) {
             if ($value == $this->query_vars['meta_key'] || $value == 'meta_value') {
                 $ordersby[$key] = "{$wpdb->commentmeta}.meta_value";
             } elseif ($value == 'meta_value_num') {
                 $ordersby[$key] = "{$wpdb->commentmeta}.meta_value+0";
             }
         }
         $orderby = empty($ordersby) ? 'comment_date_gmt' : implode(', ', $ordersby);
     } else {
         $orderby = 'comment_date_gmt';
     }
     $number = absint($number);
     $offset = absint($offset);
     if (!empty($number)) {
         if ($offset) {
             $limits = 'LIMIT ' . $offset . ',' . $number;
         } else {
             $limits = 'LIMIT ' . $number;
         }
     } else {
         $limits = '';
     }
     if ($count) {
         $fields = 'COUNT(*)';
     } else {
         $fields = '*';
     }
     $join = '';
     $where = $approved;
     if (!empty($post_id)) {
         $where .= $wpdb->prepare(' AND comment_post_ID = %d', $post_id);
     }
     if ('' !== $author_email) {
         $where .= $wpdb->prepare(' AND comment_author_email = %s', $author_email);
     }
     if ('' !== $karma) {
         $where .= $wpdb->prepare(' AND comment_karma = %d', $karma);
     }
     if ('comment' == $type) {
         $where .= " AND comment_type = ''";
     } elseif ('pings' == $type) {
         $where .= ' AND comment_type IN ("pingback", "trackback")';
     } elseif (!empty($type)) {
         $where .= $wpdb->prepare(' AND comment_type = %s', $type);
     }
     if ('' !== $parent) {
         $where .= $wpdb->prepare(' AND comment_parent = %d', $parent);
     }
     if ('' !== $user_id) {
         $where .= $wpdb->prepare(' AND user_id = %d', $user_id);
     }
     if ('' !== $search) {
         $where .= $this->get_search_sql($search, array('comment_author', 'comment_author_email', 'comment_author_url', 'comment_author_IP', 'comment_content'));
     }
     $post_fields = array_filter(compact(array('post_author', 'post_name', 'post_parent', 'post_status', 'post_type')));
     if (!empty($post_fields)) {
         $join = "JOIN {$wpdb->posts} ON {$wpdb->posts}.ID = {$wpdb->comments}.comment_post_ID";
         foreach ($post_fields as $field_name => $field_value) {
             $where .= $wpdb->prepare(" AND {$wpdb->posts}.{$field_name} = %s", $field_value);
         }
     }
     if (!empty($this->meta_query->queries)) {
         $clauses = $this->meta_query->get_sql('comment', $wpdb->comments, 'comment_ID', $this);
         $join .= $clauses['join'];
         $where .= $clauses['where'];
         $groupby = "{$wpdb->comments}.comment_ID";
     }
     if (!empty($date_query) && is_array($date_query)) {
         $date_query_object = new WP_Date_Query($date_query, 'comment_date');
         $where .= $date_query_object->get_sql();
     }
     $pieces = array('fields', 'join', 'where', 'orderby', 'order', 'limits', 'groupby');
     $clauses = apply_filters_ref_array('comments_clauses', array(compact($pieces), &$this));
     foreach ($pieces as $piece) {
         ${$piece} = isset($clauses[$piece]) ? $clauses[$piece] : '';
     }
     if ($groupby) {
         $groupby = 'GROUP BY ' . $groupby;
     }
     $query = "SELECT {$fields} FROM {$wpdb->comments} {$join} WHERE {$where} {$groupby} ORDER BY {$orderby} {$order} {$limits}";
     if ($count) {
         return $wpdb->get_var($query);
     }
     $comments = $wpdb->get_results($query);
     $comments = apply_filters_ref_array('the_comments', array($comments, &$this));
     wp_cache_add($cache_key, $comments, 'comment');
     return $comments;
 }
開發者ID:palimadra,項目名稱:bubblegraphics-wpsite,代碼行數:101,代碼來源:comment.php


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