Php 构建调用多个表的wordpress api

Php 构建调用多个表的wordpress api,php,mysql,sql,wordpress,Php,Mysql,Sql,Wordpress,TL;DR-如何将不同表中的信息联系在一起,为插件创建API 来概括我正在做的事情。我们正在为客户的健身房建立一个应用程序和一个网站,目前该应用程序只提供博客帖子、日历活动,允许他们将活动添加到手机中,并提供设施说明,而网站则更深入地介绍健身房、培训师和正在进行的任何活动。我们决定使用Wordpress作为网站和应用程序的管理面板,所以他们只需要在一个地方完成工作 对于应用程序,我使用WP-restapiv2来获取博客文章,这是最简单的部分。但日历已经变得极其困难。我们购买的主题是Symetri

TL;DR-如何将不同表中的信息联系在一起,为插件创建API

来概括我正在做的事情。我们正在为客户的健身房建立一个应用程序和一个网站,目前该应用程序只提供博客帖子、日历活动,允许他们将活动添加到手机中,并提供设施说明,而网站则更深入地介绍健身房、培训师和正在进行的任何活动。我们决定使用Wordpress作为网站和应用程序的管理面板,所以他们只需要在一个地方完成工作

对于应用程序,我使用WP-restapiv2来获取博客文章,这是最简单的部分。但日历已经变得极其困难。我们购买的主题是Symetrio Gym and Fitness,它附带了一个日历,我们可以使用,它几乎与我们在应用程序中使用的内容相匹配。因此,我们需要做的是将输入日历的数据拉入,并在应用程序中使用API调用来显示数据

所以这里是事情变得复杂的地方,日历使用多个表来提取所有的数据。对于培训师、班级和房间,它会创建一个自定义的帖子类型,其中只包含培训师、班级或房间的名称。但是对于日期、时间和它引用的数据,它使用两个单独的表,一个称为schedule_ap_multi的表,其中包含日期、引用id和类的id,该类在POST中引用

下一个表称为schedule_ap_multi_fields,其中包含开始时间、结束时间、引用schedule_ap_multi中要使用的行的id、房间张贴的id、培训师的id以及活动的描述,但这些都在各自的行中,在schedule\u ap\u 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_类型的post,而获取任何其他非post的post_类型都是一个挑战,当我使用任何wpdb命令时,我都会返回查询,但查询是完整的,并且只有当我将其作为JSON对象之一使用时,当我将其放入时,它不会返回数组

$data[here]=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;
    }
这个解决方案是有效的,它是我们如何创建API和端点以与日历插件通信的参考点。我仍然有一些东西需要打电话,但除此之外效果很好。打电话的时候很慢,所以我需要在某个时候回来看看我是否能把它清理干净,这样我就不会打那么多电话了,但对我来说这似乎是不可避免的。但我可能错了