博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
黄聪:WordPress 多站点建站教程(三):主站如何调用子站的文章内容、SQL语句如何写?...
阅读量:6276 次
发布时间:2019-06-22

本文共 3759 字,大约阅读时间需要 12 分钟。

1、如果懂得编程的朋友可以SQL语句,然后加上PHP函数等操作就可以通过直接调用网站的数据库信息来实现想要达到的目的。

既然要用到SQL语句首先得对WordPress多站点数据库有一个了解,多站点激活后会多出这么几张表wp_site,wp_sitemeta,wp_blogs,wp_blog_versions其中最重要的是wp_blogs这张表,它将你创建的每一个子站点访问地址,以及创建和修改时间等等都存到了这张表里面。还有一点就是当你创建一个子站点后会多出一些中间带有数字的数据表,比如wp_2_posts,wp_2_options等等,中间的数字2其实就是你wp_blogs表里面的blog_id号。这就给我获取每个站点的数据提供了方便。

例如:

", $end_wrap=""){ global $wpdb; global $table_prefix; $counter = 0; //首先通过判断是否显示时间区间来分别使用不同的SQl语句 if ($how_long > 0) { $blogs = $wpdb->get_col("SELECT blog_id FROM $wpdb->blogs WHERE public = '1' AND archived = '0' AND mature = '0' AND spam = '0' AND deleted = '0' AND last_updated >= DATE_SUB(CURRENT_DATE(), INTERVAL $how_long DAY) ORDER BY last_updated DESC"); } else { $blogs = $wpdb->get_col("SELECT blog_id FROM $wpdb->blogs WHERE public = '1' AND archived = '0' AND mature = '0' AND spam = '0' AND deleted = '0' ORDER BY last_updated DESC"); } //如果存在多站点ID if ($blogs) { echo "
    "; foreach ($blogs as $blog) { // 下面是需要使用的数据表 $blogOptionsTable = $wpdb->base_prefix.$blog."_options"; $blogPostsTable = $wpdb->base_prefix.$blog."_posts"; $options = $wpdb->get_results("SELECT option_value FROM $blogOptionsTable WHERE option_name IN ('siteurl','blogname') ORDER BY option_name DESC"); // 为最新文章获取标题和ID号 if ($how_long > 0) $thispost = $wpdb->get_results("SELECT ID, post_title FROM $blogPostsTable WHERE post_status = 'publish' AND ID > 1 AND post_type = 'post' AND post_date >= DATE_SUB(CURRENT_DATE(), INTERVAL $how_long DAY) ORDER BY id DESC LIMIT 0,1"); } else { $thispost = $wpdb->get_results("SELECT ID, post_title FROM $blogPostsTable WHERE post_status = 'publish' AND ID > 1 AND post_type = 'post' ORDER BY id DESC LIMIT 0,1"); } // 如果存在将输入内容 if($thispost) { // 获取子站点文章链接 $thispermalink = get_blog_permalink($blog, $thispost[0]->ID); if ($titleOnly == false) { echo $begin_wrap.'
    '.$thispost[0]->post_title.'
    by
    ' .$options[1]->option_value.''.$end_wrap; $counter++; } else { echo $begin_wrap.'
    '.$thispost[0]->post_title.''.$end_wrap; $counter++; } } // 对文章数量进行判断。 if($counter >= $how_many) { break; } } echo "
"; } }?>

把上面的代码放到 functions.php 中,使用方法上面已有说明。如你有十个子站点。想显示这个十个子站点的最新文章,就可以使用上面的方法:

', ''); ?>

 

假如你有50个子站点,而你控制显示的最新文章数量只是10篇,很有可能十几个用户在同时使用子站点发布文章,那这样的话有些最新文章得不到显示,所以考虑到随机显示子站点的最新文章。且每刷新一次页面都会随机显示不同的子站点文章代码如下:

get_col("SELECT blog_id FROM $wpdb->blogs WHERE public = '1' AND archived = '0' AND mature = '0' AND spam = '0' AND deleted = '0' ORDER BY last_updated DESC"); foreach ($most_post as $key => $v) { if($v !=1 ) //除主站点ID { $b_id[$key] = $v; } } $newid = array_flip($b_id); //php数组函数对换键值 $new_post_id = array_rand($newid,2); //php数组函数随机显示2条,这里的数值不能大于你创建子站点的个数。 foreach ( $new_post_id as $k => $vol ) { $blogPostsTable = $wpdb->base_prefix.$vol."_posts"; $recent_post = $wpdb->get_results("SELECT * from $blogPostsTable where post_status = 'publish' and post_type = 'post' ORDER BY post_date desc LIMIT 0,$showpost"); foreach ($recent_post as $ks => $vs) { $thispermalink = get_blog_permalink($vol, $vs->ID); $count1 += 1; echo '
  • '.$vs->post_title.'
  • '; } }}?>

     

    将上面的方法同样放到你使用主题的functions.php文件里面,使用方法只要

     

    2、而不懂编程的朋友们会想到使用插件来完成,虽然有时候能满足我们的要求,但毕竟使用插件有局限性,并不是每一款插件都适合(插件里面的代码也都是用SQL语句来完成)。比如有这么几款插件:Multisite Latest Posts Widget(显示多站点最新文章) 和 Multisite Featured Blog (显示多站点特色博客)和 WPMU Recent Posts Widget(显示多站点最近文章) 

     

    转载于:https://www.cnblogs.com/huangcong/p/3718423.html

    你可能感兴趣的文章
    Android程序开发初级教程(一) 开始 Hello Android
    查看>>
    使用Gradle打RPM包
    查看>>
    “我意识到”的意义
    查看>>
    淘宝天猫上新辅助工具-新品填表
    查看>>
    再学 GDI+[43]: 文本输出 - 获取已安装的字体列表
    查看>>
    nginx反向代理
    查看>>
    操作系统真实的虚拟内存是什么样的(一)
    查看>>
    hadoop、hbase、zookeeper集群搭建
    查看>>
    python中一切皆对象------类的基础(五)
    查看>>
    modprobe
    查看>>
    android中用ExpandableListView实现三级扩展列表
    查看>>
    %Error opening tftp://255.255.255.255/cisconet.cfg
    查看>>
    java读取excel、txt 文件内容,传到、显示到另一个页面的文本框里面。
    查看>>
    《从零开始学Swift》学习笔记(Day 51)——扩展构造函数
    查看>>
    python多线程队列安全
    查看>>
    [汇编语言学习笔记][第四章第一个程序的编写]
    查看>>
    android 打开各种文件(setDataAndType)转:
    查看>>
    补交:最最原始的第一次作业(当时没有选上课,所以不知道)
    查看>>
    Vue实例初始化的选项配置对象详解
    查看>>
    PLM产品技术的发展趋势 来源:e-works 作者:清软英泰 党伟升 罗先海 耿坤瑛
    查看>>