マジカルスリー・だいすけのなりゆき長者ブログ

沖縄/大阪WEB広告・ホームページ制作・印刷物制作 マジカルスリー 「福」代表のブログ

*

マルチサイトで複数のブログの新着情報を取得したい

      2016/09/09

WordPressでマルチサイトの新着情報を取りたいなーと思うことがあったのでメモメモ。

ちなみにマルチサイトではなく、フツーに新着情報を取りたい方は【こちら】

【元ネタ:マルチサイト化した複数のブログの新着記事を表示する-KOTORI様】

http://kotori-blog.com/wordpress/multisite_newpost/

 

元ネタのとおりだと記事へのリンクがないので付け足してみました(´∀`)

あと、元ネタは「記事タイトル-日付」の順ですが、下のコードでは「日付-記事タイトル」にしてます。細かいですが、この並びのほうが多いような気がしたので・・・。

<?php
$sql = '';
$blog_id_arr = array(1,2);//取得するブログIDの配列
$tmp = $blog_id_arr;
foreach($blog_id_arr as $b_id){
 next($tmp);
 switch_to_blog($b_id);
 $sql .= <<<HERE
(SELECT *, $b_id as blog_id
FROM $wpdb->posts
WHERE post_type = 'post'
AND post_status = 'publish')
HERE;
 
 if(current($tmp) !== false){
 $sql .= "UNION\n";
 }
 restore_current_blog();
}
$sql .= <<<HERE
ORDER BY post_date DESC
LIMIT 10
HERE;
$posts = $wpdb->get_results($sql);
?>
 
<?php
foreach ($posts as $post):
 switch_to_blog($post->blog_id);
 setup_postdata($post);
?>
<a href="<?php the_permalink(); ?>"><?php the_time('Y.m.d');?>-<?php the_title();?></a><br />
<?php endforeach;?>
<?php wp_reset_postdata();?>
<?php restore_current_blog();?>

ちなみにサイトIDの確認の仕方ですが・・・
管理画面→参加サイト→サイトネットワーク管理者→サイト を開いて、
それぞれマルチサイトのURLの部分にマウスカーソルをターゲットすると左下のリンク先表示にIDが出ます。

sitenetwork

 - WordPressの事

Comment

  1. 元ジェット より:

    だいすけさま
    こんにちは!

    どうしてもこの記事に書かれてられる機能がほしくて、
    日付の一番新しいサイトを探してここに来ました。

    WP素人でCSSにはじめて取り組む中
    何とかマルチサイトを作り上げたのですが
    この機能を最後につけたいと思っております、

    function.phpに記載するのでしょうか、
    ぶしつけですがどうぞよろしくお願いいたします。

    • だいすけ より:

      元ジェット様
      はじめまして、コメントありがとうございます。
      お返事が遅くなってスミマセン(T-T)
      このコードはfunction.phpに書くのではなく、テンプレートに書き込むタイプのものです。
      具体的にはトップページならindex.phpやhome.php(テーマの作りによって違います)です。
      home.phpってなんぞや?という場合は下記ページをご参照下さい。
      http://liginc.co.jp/programmer/archives/3805
      それでは上手く行くことを願っております(๑´ڡ`๑)

  2. 元ジェット より:

    こんにちは!お返事ありがとうございました。

    わたしはWordPress 4.4.1 でStinger520150505bを用いているのですが、
    いろいろやってみたのですが動きませんでした^^;
    FunctionやHomeやIndexなどいじってみたのですが、
    どうやらこぴぺだけでは限界のようですね・・・
    もう少し勉強して理解して記述できるようになるまで辛抱しようかと、思います。

    ご丁寧にありがとうございましたm(__)m

    • だいすけ より:

      元ジェット様
      わざわざご連絡ありがとうございました。
      あれ?と思ったので掲載しているソースを見なおしてみました。
      もしかすると

      nbsp;

      のところでエラーになってるかもしれません。
      ソースを書き換えてみたので、一度お試し頂ければ幸いです~。

  3. […] マルチサイトで複数のブログの新着情報を取得したい […]

Message

  関連記事

WEBサイトのスクリーンショットをサムネイル化する

弊社の制作実績を登録していこうと思ったのですが、直近のものだけでも軽く30を超え …

WordPressで勝手に画像リサイズされる

いつもの防備録です。   本当に間抜けな話なんですが、これってほぼ間違 …

海外テーマで文字化け回避したいの巻

テーマで文字化け! 海外製のWordpressテーマを使ったときに起こりやすいん …

プラグイン無しで外部サイトのRSSを表示するRSSリーダー的なもの

外部RSS(ブログの新着記事)を読み込む案件があったので「プラグインでええよなー …

ワードプレスのサイト引越し時に500エラー

毎度おなじみのワードプレス備忘録です。 表題の通り、よくある(よくあってほしくな …

PHPのバージョン変更したことでエラーが出る

PHPバージョン7系のサーバーからPHPバージョン8系サーバーにサイト移管した時 …

GravatarでWordPressのアバターを作ろう

最近物忘れがヒドイ、だいすけです。 テーレッテレー!! ついこの前、ワードプレス …

mb_substr()使ってもサムネイルの見出しがズレるじゃん!という話

またしても忘備録。 WordPressでよくある、こういう感じの記事表示方法。 …

子カテゴリに親カテゴリのテンプレートを引き継がせる

WordPressって基本的に親カテゴリを指定すると、それにぶら下がっている子カ …

各固定ページのページデザインをテンプレート選択で可能にする方法

よく使うのに忘れてしまうのでまた忘備録がわりに・・・。 【ネタ元:はじめてのWo …