- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
TL;DR - 如何将不同表中的信息联系在一起,为插件创建 API。
总结一下我在做什么。我们正在为客户的健身房构建一个应用程序和一个网站,该应用程序目前仅提取博客文章、日历事件,允许他们将事件添加到他们的手机中,以及对设施的描述,而网站则更多深入了解健身房、教练和任何正在进行的事件。决定我们应该使用 Wordpress 作为网站和应用程序的管理面板,这样他们只需要在一个地方完成工作。
对于应用程序,我使用 WP REST API v2 来提取博客文章,这是比较容易的部分。但是日历变得异常困难。我们购买的主题是 Symetrio Gym and Fitness,它带有我们可以使用的日历,它几乎与我们在应用程序中使用的相匹配。因此,我们需要做的是提取输入到日历中的数据,并在应用程序中使用 API 调用来显示数据。
事情变得复杂了,日历使用多个表来提取所有数据。对于培训师、类(class)和房间,它创建了一个自定义帖子类型,其中仅包含培训师、类(class)或房间的名称。但是对于日期、时间和它引用的数据,它使用两个单独的表,一个名为 schedule_ap_multi 的表具有日期、引用 ID 和在帖子中引用的类的 ID。
下一个表称为 schedule_ap_multi_fields,它有开始时间、结束时间、引用 schedule_ap_multi 中使用哪一行的 id、房间帖子的 id、培训师的 id 和事件的描述,但这些都在他们自己的行中,唯一真正将它们绑定(bind)在 schedule_ap_multi 的 ID 中的东西。
这里有一些关于如何设置这两个表的图片。
我开始为日历构建一个API,但是我无法从表格中获取任何数据,似乎我只能从帖子中获取数据,并且由于日期和开始和结束时间不是帖子,所以很难得到他们。对于 JSON 对象,我正在创建其结构如下:
protected function make_data( $post, $data ) {
global $wpdb;
$classesID = $wpdb->get_results('SELECT ID FROM wp_wtr_schedule_ap_multi',ARRAY_A);
$classes = $wpdb->get_results('SELECT * FROM wp_posts WHERE post_type = "classes"',OBJECT);
$date = $wpdb->get_results('SELECT * FROM wp_wtr_schedule_ap_multi');
$data[ $post->ID ] = array(
'title' => 'the title',
'type' => $post->post_type,
'room' => 'the room',
'instructor' => 'the instructor',
'description' => 'the description',
'start_date' => 'start date',
'end_date' => 'end date',
'image' => 'image',
'style' => 'style',
};
return $date;
当我执行 $post-> 时,它只获取帖子的 post_type,获取任何其他不是帖子的 post_type 是一个挑战,当我使用任何 wpdb 命令时,我得到查询,但是在完整,并且只有当我将它用作 JSON 对象之一时,当我将它放入
时它才不会返回数组$data[ 这里 ]=array()
总而言之,我想做的是将所有这些对象联系在一起,希望进行一次 api 调用,并在应用程序端填写日历,以显示我在 WordPress 中创建的每个事件所需的数据.我现在完全不知道我需要做什么,而且我团队中没有其他人有任何使用 wordpress 插件或为 wordpress 创建自定义 API 的经验。
最佳答案
因此,在与我工作的兼职高级开发人员进行一对一交流后,我们终于弄明白了。这是我们的解决方案。
protected function make_data() {
global $wpdb;
$date = date("Y-m-d");//returns current date in Year-Month-Day format
$queryResult = $wpdb->get_results("SELECT wp_wtr_schedule_ap_multi.id ,wp_posts.post_title, wp_wtr_schedule_ap_multi.date FROM wp_wtr_schedule_ap_multi INNER JOIN wp_posts ON wp_wtr_schedule_ap_multi.id_classes=wp_posts.ID WHERE wp_wtr_schedule_ap_multi.date >= '$date'");//Only pulls date on or after current date, so we don't pull everything back at once.
$data = array();
foreach ( $queryResult as $post ) {
$fields = $wpdb->get_results("SELECT * FROM wp_wtr_schedule_ap_multi_fields WHERE id_ap_multi ='$post->id' ");// gets all th essential data from multi_fields that is associated with ID
$trainNum = $fields[5]->value; //recieves Trainer ID for regex
$trainerNum = preg_replace('/[^0-9]/s', '', $trainNum);//pulls out the random ";" and returns just the trainer number
$trainer = $wpdb->get_row("SELECT * FROM wp_posts WHERE ID = '$trainerNum'");//gets all the data from the trainer row number
$roomNum = $fields[4]->value;//gets the room number, for query function. did not like $fields[4]->value for some reason
$room = $wpdb->get_row("SELECT * FROM wp_posts WHERE ID = '$roomNum' ");//returns the row info for the room id
$class_data = array( );
$class_data['_id'] = $post->id;
$class_data['title'] = $post->post_title;
$class_data['room'] = $room->post_title;
$class_data['instructor'] = $trainer->post_title;
$class_data['start'] = date("{$post->date} {$fields[0]->value}:{$fields[1]->value}:00.000Z");
$class_data['end'] = date("{$post->date} {$fields[2]->value}:{$fields[3]->value}:00.000Z");
//$class_data['ref'] = $fields;//used to reference items returned
$data[] = $class_data;
};
return $data;
}
解决方案有效,This是我们如何创建 API 和端点以与日历插件通信的引用点。我还有一些需要调用的项目,但除此之外效果很好。打电话时速度很慢,所以我需要在某个时候回来查看是否可以清理它,这样我就不会打那么多电话,但这对我来说似乎是不可避免的。但我可能错了。
关于php - 构建一个调用多个表的wordpress api,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36183167/
我正在尝试将我所有的东西从 videomarathon.com/dk 导入到 videomarathon.com/se(帖子等) 我正在使用 wordpress 导入器。 上传导出的文件时,它向我显示
Azure WordPress 和 Azure 可扩展 WordPress 之间有什么区别?除了可扩展的 WordPress 允许您选择 azure 存储之外,我看不出有什么区别 最佳答案 基本区别:
我目前正在一个与体育相关的 wordpress 网站上工作。我所有的帖子都在同一个地方,分为足球、网球等。我想改变我博客的结构,比如足球,应该是domain.com/football对于网球,应该是
Wordpress 3 有一个漂亮的 TinyMCE 实现,我相信它比它所基于的原始 TinyMCE 运行得流畅得多。 很棒的事情:- HTML/源代码 View 作为选项卡而不是弹出窗口- 有吸引力
我在 codex.wordpress.org 和developer.wordpress.org 上看到了 WordPress 开发人员文档。他们都有关于插件和主题的文档。由于我不了解 wordpres
我有自定义帖子循环,我想在底部添加“查看全部”链接,该链接应指向包含该类型所有帖子的页面。 我能想到的唯一解决方案是为帖子类型创建一个模板页面并硬编码指向它的链接,但我希望有一个更优雅和动态的解决方案
我正在尝试使用类在 WordPress 中创建自定义 REST API 端点。我也用传统方法做了同样的事情——效果很好。但是,使用类时出现错误 The handler for the route is
我是 WordPress 的新手,正在尝试在主页的一部分中使用一些自定义代码,该部分旨在显示三个类别(白皮书、文章和帖子)中每个类别的 #1 趋势帖子.代码只是显示(据我所知)最近的 3 个帖子,无论
我正在尝试在 wordpress 中设置搜索页面的样式。在 search.php 中,我可以设置大部分页面的样式,但随后的以下语句(我从未经编辑的原始页面中获得)生成了内容。
我希望得到一些帮助来解决一些让我发疯的编码问题。我更喜欢在我的 wordpress 帖子标题中写“&”而不是“and”。但是写出&符号会破坏我们的 twitter、facebook 和 google-
是否可以只重写一个类别? 我有一个类别“ 照片”,并且只针对这个类别。 我只想从/category/photos重写它至 /photos 最佳答案 您可以使用 WP Rewrite API 来实现。
我有一个托管在 www.example.com 上的网站,它是一个 Bitnami 应用程序。 我想在 www.example.com/blog 上可以访问的同一台服务器上安装另一个 bitnami
我一直在做一些测试。注意:这仅在Safari浏览器中发生。 我关闭了所有插件并激活了主题二十(而不是我的Catch Box子主题)。在此配置下,除了顶部菜单中的“主页”选项卡(在Safari中显示如下
我是一名 php 开发人员,目前正在开发一个 CMS/博客系统。我想添加一个永久链接系统,比如 WordPress。我很好奇 WordPress 如何解析永久链接。例如,如何获取 id 这样的数据和
有谁知道Wordpress有多安全? 我不知道如何定义“有多安全”。但与其他CMS系统相比,它的安全性如何? 更新: 详细说明我的项目。 我会有很多用户注册。登录后,他们将可以访问我正在开发的插件。大
是否可以授予编辑者管理主题小部件的功能?默认情况下,只有管理员可以这样做。 谢谢, 乔恩 最佳答案 恐怕您将需要使用插件来实现此目的,因为更改窗口小部件是switch_themes capabilit
我有一个在服务器上运行的多站点 wordpress,我想将我的站点转移到另一台服务器上。我通过 filezilla ftp 下载了完整的文件备份还导出了完整的数据库。 现在我将此备份导入到新服务器 (
我使用通用 HTML 标签在 WordPress 插件中创建了一个表单。我刚刚用 echo 测试了文本框提交的值,它工作正常。提交表单后,我需要在同一页面中重定向或显示成功/失败消息。表单提交后如何显
我想启用 wordpress 站点的调试日志,在 wp-config.php 中添加以下设置 /* WordPress debug mode for developers. */ define('WP
是否可以仅在前端(无需编辑 .mo/.po 文件)更改我的 wordpress 安装(WP 3.0 Multisite)的语言? 在此处更改此选项: 也会在后端更改我的语言。 有任何想法吗? 感谢您的
我是一名优秀的程序员,十分优秀!