Многократная вставка в базу данных не работает
Я пытаюсь вставить несколько строк в базу данных одновременно.
Пользователь может добавить до 5 новых строк для результатов анализа крови, которые будут вставлены в базу данных.
Есть кнопка добавить еще, чтобы позволить им сделать это.
У меня есть цикл для итерации каждой записи, но когда я нажимаю "Отправить", отправляется только одна запись. Первый, я не уверен, где я иду не так, и любая помощь будет оценена.
Цикл находится внизу этого блока кода, но я не уверен, что в этом проблема.
<?php
session_start();
if (!isset($_SESSION["currentUserID"])) header("Location: login.php");
include('dbConnect.php');
$queryStr=("SELECT * FROM category");
$dbParams=array();
// now send the query
$results = $db->prepare($queryStr);
$results->execute($dbParams);
$dropDown = "";
foreach($results as $category) {
$dropdown .= '<option value="' . $category["category_id"] . '">' . $category["category_name"] . '</option>';
}
?>
<html lang="en">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
<meta name="description" content="">
<meta name="author" content="">
<title>Welcome</title>
<TITLE>Category and Test</TITLE>
<head>
<!-- Help for code to create dynamic drop downs -->
<script src="https://code.jquery.com/jquery-2.1.1.min.js" type="text/javascript"></script>
<script>
//Referenced for help --lines 81- 95
//https://www.codeproject.com/Questions/893365/Use-data-pulled-out-from-one-mysql-table-and-inser
//https://stackru.com/questions/48270422/insert-values-into-database-from-form-with-drop-downs?noredirect=1#comment83524543_48270422
var numRows = 1;
function getTest(val,x) {
$.ajax({
type: "POST",
url: "get_test.php",
data:'category_id='+val,
success: function(data){
$("#test-list" + x).html(data);
}
});
}
function selectCategory(val) {
$("#search-box").val(val);
$("#suggesstion-box").hide();
}
// Referenced for help - https://www.youtube.com/watch?v=kBAPbCDGCuY
var maxRows=5;
var x = 1;
// add rows
$(document).ready(function(e)
{ // add new row or fields
$("#add").click(function(e)
{ // if less than 5 then continue to add a new row
if (x<=maxRows)
{ // add new row with all fields, update name with x to make unique and stop drop downs changing each others values
var html = '<div class="row" id="container"><label>Category:</label><select name="category' + x + '" id="category-list" class="demoInputBox" onChange="getTest(this.value,' + x +');"><?php echo $dropdown; ?></select><label>Test:</label><select name="test' + x + '" id="test-list' + x + '" class="demoInputBox"><option value="">Select Test</option></select><label>Result:</label><input id="resultchild" class="input" name="result' + x + '" type="double" required><label>Date:</label><input id="datechild" class="input" name="date' + x + '" type="date" required ><label>Low Boundary:</label><input id="lowchild" class="input" name="low' + x + '" type="double" required><label>High Boundary:</label><input id="highchild" class="input" name="high' + x + '" type="double" required><a href ="#" id="remove"> X </a>';
document.addTest1.count.value=x;
// update x
x++;
// add html below as new row
$("#container").append(html);
}
});
// take away rows
$("#container").on('click', '#remove', function(e)
{
$(this).parent('div').remove();
x--;
document.addTest1.count.value=x;
});
// populate values from first row
});
</script>
</head>
<body>
<!--
Reference for help -- lines 134 - 144
https://www.codeproject.com/Questions/893365/Use-data-pulled-out-from-one-mysql-table-and-inser
https://stackru.com/questions/48270422/insert-values-into-database-from-form-with-drop-downs?noredirect=1#comment83524543_48270422
-->
<div class="row" id="container">
<label>Category:</label>
<select name="category0" id="category-list" class="demoInputBox" onChange="getTest(this.value,0);">
<option value="">Select Category</option>
<?php
echo $dropdown;
?>
</select>
<form action="addTest.php" method="post" name="addTest1">
<input type="hidden" name ="count" value="0">
<label>Test:</label>
<select name="test0" id="test-list0" class="demoInputBox">
<option value="">Select Test</option>
</select>
<label>Result:</label><input id="result" class="input" name="result0" type="double" required>
<label>Date:</label><input id="date" class="input" id="date" name="date0" type="date" required>
<label>Low Boundary:</label><input id="low" class="input" name="low0" type="double" required>
<label>High Boundary:</label><input id="high" class="input" name="high0" type="double" required>
<a href ="#" id="add"> Add More</a>
<input class="submit" name="submit" type="submit" value="Submit">
</div>
</form>
<?php
if(isset($_POST['submit'])){
$count = $_POST['count'];
// for loop to iterate through each new row and insert into database
for ($x=0; $x<$count; $x++) {
$currentUser = $_SESSION["currentUserID"];
$currentBloodTest = $_POST['test'.$x];
$value = $_POST['result'.$x];
$date = $_POST['date'.$x];
$low = $_POST['low'.$x];
$high = $_POST['high'.$x];
$query = $db->prepare("INSERT INTO results (user_id, bloodtest_id, date, value, low_boundary, high_boundary)
VALUES (?, ?, ?, ?, ?, ?)");
$query->execute( array($currentUser, $currentBloodTest, $date, $value, $low, $high) );
echo "<br><br><span>Data Inserted successfully...!!</span>";
} //end of for loop
}
?>
</body>
</html>
1 ответ
Измените свою часть HTML на это.
<form action="addTest.php" method="post" name="addTest1">
<input type="hidden" name ="count" value="0">
<label>Test:</label>
<select name="test0" id="test-list0" class="demoInputBox">
<option value="">Select Test</option>
</select>
<label>Result:</label><input id="result" class="input" name="result[]" type="double" required>
<label>Date:</label><input id="date" class="input" id="date" name="date[]" type="date" required>
<label>Low Boundary:</label><input id="low" class="input" name="low[]" type="double" required>
<label>High Boundary:</label><input id="high" class="input" name="high[]" type="double" required>
<a href ="#" id="add"> Add More</a>
<input class="submit" name="submit" type="submit" value="Submit">
</div>
</form>
В коде на стороне сервера вы должны использовать foreach или использовать массивы, указанные в имени элементов управления вводом форм.
Посмотрите на это -> Несколько входов с одинаковым именем элемента управления в PHP