質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

2回答

3403閲覧

WordPressのWP_Queryを使って最新3件・昇順の指定をしたい

cnc

総合スコア12

WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

1クリップ

投稿2016/02/04 02:35

WordPressのWP_Queryを使って、ID順の昇順で並べ、最新3件の表示にしたいです。
以下のコードだとID順(1,2,3,4,5)と並びますが、表示が(1,2,3)となってしまいます。
ID順(1,2,3,4,5)で、表示は(3,4,5)になるようにしたいのですが、
どう変更すれば良いか教えていただけますでしょうか。
(WP_Queryにこだわりがあるわけではありません。)
よろしくお願いいたします。

###ソースコード

php

1<?php $loop = new WP_Query( array( 2 'post_type' => 'page', 3 'posts_per_page' => 3, 4 'orderby' => 'ID', 5 'order' => 'ASC' 6 )); ?> 7<?php while ( $loop->have_posts() ) : $loop->the_post(); ?>

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

最初の ID 二つを飛ばして「3, 4, 5 」を表示したい理由は何でしょうか。
単に二つ飛ばしたいだけなら WP_Query のコンストラクタに渡すパラメータに 'offset' => 2 をつけるとよいのではないでしょうか (当方、検証できていませんが)。
あと、post_limits フィルタを使うことで二つ飛ばすというのはできると思います。

もし、もっと複雑な条件で飛ばしたい ID がある場合も、うまくフィルタを使えば実現できるかもしれませんし、もっともっと複雑な条件で投稿を絞りたい場合は、 Wordpressで投稿記事をサムネイル付きでカテゴリごとに1件ずつ表示したい - teratail の回答に私が書いたように、$wpdb->get_results() を使ってやれば、mysql の SQL で表現できる問い合わせなら、お好みの結果が得られると思います。

投稿2016/02/04 08:45

unau

総合スコア2468

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

cnc

2016/02/04 09:17

すみません!'orderby'はデフォルト値’date’でも大丈夫でした。 IDを二つ飛ばすというよりは、最新3件の表示をさせたいです。 (1,2,3,4,5,6)とあったら、(4,5,6)の表示にしたいのです。 ありがとうございます、 最新3件に絞った後、昇順に表示する方法を調べてみようと思います。
unau

2016/02/04 14:45

一応、次のような問い合わせを mysql に直接投げればよいようです。 select ID, post_title from wp_posts where post_type = 'page' and ID > (select ID from wp_posts where post_type = 'page' order by ID desc limit 3,1) order by ID; まあ、リソースを食いますが、SQL にはこだわらず、PHP 側で逆順にソートするのが妥当なんでしょう。 データ数が多い、データ量が多い方はまた話が別になりますけれども。
guest

0

ベストアンサー

IDの昇順でなければいけないのでしょうか?
分かりやすく投稿日時の昇順3件を表示すればいいと思うのですが。

投稿2016/02/04 03:18

y-neon

総合スコア106

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

cnc

2016/02/04 04:20

'orderby' => 'date' 'orderby' => 'modified' にしても、表示が(1,2,3)となってしまいます。。。
y-neon

2016/02/04 05:29 編集

すみません、昇順だと永遠に1,2,3の記事しか出ません。 基本的に一番上からか一番したからの順番しかありません。 途中の番号から昇順、降順はできません。 面倒ですが降順でループさせてタグの出力はせず、変数に格納するようにしてください。 ループの外で昇順で変数を出力すれば可能です。
cnc

2016/02/04 06:22

そうなんですね、ありがとうございます!アドバイスいただいた方法で試してみます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問