Чего я пытаюсь достичь
Итак, чего я пытался добиться, так это вставить пару ключ/значение массива в объект JSON, который сам по себе является массивом, так что есть один объект, а одна из пар ключ-значение содержит массив.
ЭТО ТО, ЧЕГО Я ПЫТАЮСЬ ДОСТИГНУТЬ в виде вывода JSON, другого массива данных2 внутри другого массива данных.
[
{
"data": {
"temp_service_id": "3",
"name": "health checkup",
"price": "10000",
"service_id": "41",
"data2": [
{
"fees": "2000",
"service_name": "Anaesthesiologist"
},
{
"fees": "300",
"service_name": "Andrologist"
},
]
},
}
]
Что я пробовал
ЭТО МОЙ КОНТРОЛЛЕР:
$where['subtype_id'] = $this->post('org_id');
$where['is_active'] = 'Y';
$table_package_master = 'package_master';
$fetch_package_name = $this->$model_name->fetch($table_package_master,$where);
$array = [];
$array1 = [];
$array2 = [];
if($fetch_package_name){
foreach($fetch_package_name as $row){
$where_r['t1.package_num'] = $row->package_num;
$where_r['t1.is_active'] = 'Y';
$where_r['services.is_active'] = 'Y';
$where_r['t4.is_active'] = 'Y';
$fetch_packages1 = $this->$model_name->fetch_packages1($where_r);
$array['data'] = $fetch_packages1;
$fetch_packages = $this->$model_name->fetch_packages($where_r);
foreach($fetch_packages as $row1){
$where_re['services.service_id'] = $row1->service_id;
$where_re['services.is_active'] = 'Y';
$where_re['template_services.is_active'] = 'Y';
$fetch_package_ser = $this->$model_name->fetch_service_details($where_re);
array_push($array1,$fetch_package_ser);
}
}
$array['data2'] = $array1;
$array3 = [$array];
$this->response($array3);
}
ЭТО МОЯ МОДЕЛЬ:
function fetch($table,$where_con){
$this->db->select('*')->from($table)->where($where_con);
return $this->db->get()->result();
}
function fetch_packages1($where){
$this->db->select('t3.temp_service_id,t4.name,t4.price,services.service_id');
$this->db->from('package_services as t1');
$this->db->join('services','services.service_id = t1.service_id', 'LEFT');
$this->db->join('template_services as t3','t3.temp_service_id = services.temp_service_id' , 'LEFT');
$this->db->join('package_master as t4', 't4.package_num = t1.package_num','LEFT');
$this->db->where($where);
$this->db->group_by('t1.package_num');
return $this->db->get()->row();
}
function fetch_service_details($where){
$this->db->select('services.price as fees,template_services.service_name');
$this->db->from('services');
$this->db->join('template_services','template_services.temp_service_id =
services.temp_service_id','LEFT');
$this->db->where($where);
return $this->db->get()->row();
}
В основном то, что я пытаюсь сделать, это поместить объект данных в переменную $array, которая представляет собой данные, поступающие из одной таблицы. Теперь я ввел данные из другого запроса в $array1. В конце концов все, что я сделал, это array_push в $array3 все данные из $array1 и $array2, чтобы объединить их, но МОЙ ВЫВОД ЭТО:
[
{
"data": {
"temp_service_id": "3",
"name": "health checkup",
"price": "10000",
"service_id": "41"
},
"data2": [
{
"fees": "2000",
"service_name": "Anaesthesiologist"
},
{
"fees": "300",
"service_name": "Andrologist"
}
]
}
]
Что мне здесь не хватает? я действительно запутался и не могу понять, как нажать массив data2. Заранее спасибо :)
$array['data2'] = $array1;
на$array['data']['data2'] = $array1;
, должно помочь - person Aksen P   schedule 25.11.2019