TL; DR - 如何将信息从不同的表中绑定在一起,为插件创建API。
要减少我正在做的事情。我们正在建立一个应用程序和一个网站,为客户健身房,该应用程序,现在,只有拉博客帖子,日历活动,允许他们将活动添加到他们的手机,以及设施的描述,而网站更多深入了解健身房,培训师以及任何正在进行的活动。我们决定将Wordpress用于网站和应用程序的管理面板,因此他们只需要在一个地方完成工作。
对于应用程序,我使用WP REST API v2来引入博客帖子,这是一个简单的部分。但日历变得非常困难。我们购买的主题是Symetrio Gym and Fitness,它带有我们可以使用的日历,它几乎与我们在应用程序中使用的相匹配。因此,我们需要做的是提取输入日历的数据,并在应用程序中使用API调用来显示数据。
因此,现在情况变得复杂,日历使用多个表来提取所有数据。对于Trainer,Classes和Room,它会创建一个自定义的帖子类型,其中只包含培训师,班级或房间的名称。但是对于日期,时间和它引用的数据,它使用两个单独的表,一个名为schedule_ap_multi,它具有日期,引用ID和类的id,在帖子中引用。
下一个表名为schedule_ap_multi_fields,它具有开始时间,结束时间,引用schedule_ap_multi中要使用的行的id,房间帖子的ID,培训师的ID以及活动的描述,但这些都在他们自己的行中,唯一真正将它们绑定在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,而且当我使用任何wpdb命令时,我收到任何其他post_type并不是一个挑战,当我使用任何wpdb命令时,我得到了查询,但是完全,只有当我将它用作JSON对象之一,当我把它放入
时它不会返回一个数组 $data[ here ]=array()
我要做的是总结一下,将所有这些对象组合在一起,希望进行一次api调用,并在应用程序端填写日历,以显示我在WordPress中创建的每个活动所需的数据。我现在完全失去了我需要做的事情,我的团队中没有其他人有任何wordpress插件或为wordpress创建自定义API的经验。
答案 0 :(得分:0)
因此,在与我合作的兼职高级开发者进行一对一的比赛后,我们终于明白了。这是我们的解决方案。
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和端点以与日历插件进行通信的参考点。我还有一些我需要打电话的项目,但除此之外它的效果非常好。在拨打电话时,这是一个很大的迟缓,所以我需要在某个时候回到它,看看我是否可以清理它,所以我没有拨打这么多电话,但这对我来说似乎是不可避免的。但我可能错了。