Ранее я публиковал аналогичный вопрос о передаче данных JSON в раскрывающееся меню с помощью PHP. Как я могу упорядочить массив данных из запроса API в СПИСОК ОПЦИЙ ВЫБОРА HTML?
Прямо сейчас я хотел бы ВСТАВИТЬ данные JSON в базу данных MySQL.
Ниже мой код api_redcap.php для вызова данных с другого веб-сервера:
<?php
$data = array(
'token' => '4B0D42AB9D061C0FADD724D2E908349D',
'content' => 'report',
'format' => 'json',
'report_id' => '71',
'rawOrLabel' => 'label',
'rawOrLabelHeaders' => 'label',
'exportCheckboxLabel' => 'false',
'returnFormat' => 'json');
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'http://redcap-virtualbox/redcap/api/');
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_VERBOSE, 0);
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true);
curl_setopt($ch, CURLOPT_AUTOREFERER, true);
curl_setopt($ch, CURLOPT_MAXREDIRS, 10);
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, 'POST');
curl_setopt($ch, CURLOPT_FRESH_CONNECT, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query($data, '', '&'));
$output = curl_exec($ch);
$json = json_decode($output);
?>
Ниже мой вывод из api_redcap.php:
[{"project_code":"16001","dept":"Orthopaedic Surgery (ORTHO)","group":"","name":"Jameson Lua Yao Chung"},{"project_code":"16002","dept":"Rheumatology Allergy & Immunology (RAI)","group":"","name":"Koh Ee Tzun"},{"project_code":"16003","dept":"Orthopaedic Surgery (ORTHO)","group":"","name":"Ang Wei Luong"},{"project_code":"16004","dept":"Rheumatology Allergy & Immunology (RAI)","group":"","name":"Lim Xin Rong"},{"project_code":"16005","dept":"Physiotherapy (PT)","group":"","name":"Li Kun Man"}]
Имя моей таблицы называется PROJECT_CODE в базе данных MySQL, а атрибуты следующие:
Table Name - PROJECT_CODE Field Name: PROJECT_code, DEPARTMENT, REQUESTOR,
Я хотел бы вставить переменные project_code, dept и name из JSON в поля таблицы MySQL соответственно. Пожалуйста помоги. Спасибо
@SloanThrasher Спасибо, но не могли бы вы показать мне образец кода о том, как выполняется вставка MySQL для json. Используете foreach?



![Безумие обратных вызовов в javascript [JS]](https://i.imgur.com/WsjO6zJb.png)


$json = json_decode($output, true);
foreach($json as $val)
{
$project_code = $val['project_code'];
$dept = $val['dept'];
$name = $val['name'];
/*
* Generate insert query as below
* "INSERT INTO MyGuests (project_code, dept, name) VALUES ($project_code, $dept, $name);";
*/
}
Кроме того, вы можете вставить несколько записей в один цикл Пожалуйста, проверьте ссылку ниже https://www.w3schools.com/php/php_mysql_insert_multiple.asp
В справочной ссылке даны 3 разных метода, поэтому вы можете использовать любой подходящий для вас
Вы очень помогли @Jaydp
Переменная $ json должна быть массивом, к которому вы можете получить доступ, как и к любому другому объекту массива. Вам просто нужно выполнить MyQSL INSERT после получения значений. Если вы хотите увидеть структуру массива, используйте
echo "<p>json array:<pre>".print_r($json,true)."</pre></p>\n";сразу после оператораjson_decode.