注意:这个问题是根据我在这里的最后一个问题
以下 SQL 语法有什么问题?
$sql = "ALTER TABLE products ADD ".$supplier_name_ . $p." varchar(500) AFTER supplier_info_1";
它产生以下错误:
您的 SQL 语法有误;请查看与您的 MariaDB 服务器版本对应的手册,了解要使用的正确语法 靠近第 1 行的"阵列"varchar(500( AFTER supplier_info_1">
更新:
supplier_name_ . $p
来自这个 for 循环:
// supplier info
$supplier_name_1 = $_POST['supplier_name_1'];
$supplier_sending_1 = $_POST['supplier_sending_1'];
$supplier_guarantee_1 = $_POST['supplier_guarantee_1'];
$supplier_price_1 = $_POST['supplier_price_1'];
$supplier_colors_1 = $_POST['supplier_colors_1'];
$supplier_info_1 = array($supplier_name_1, $supplier_sending_1, $supplier_guarantee_1, $supplier_price_1, $supplier_colors_1);
$proSupply_1 = json_encode($supplier_info_1);
for($p=2;$p<=5;$p++){
$supplier_name_ . $p = $_POST['supplier_name_'.$p.''];
$supplier_sending_ . $p = $_POST['supplier_sending_'.$p.''];
$supplier_guarantee_ . $p = $_POST['supplier_guarantee_'.$p.''];
$supplier_price_ . $p = $_POST['supplier_price_'.$p.''];
$supplier_colors_ . $p = $_POST['supplier_colors_'.$p.''];
$supplier_info_ . $p = array($supplier_name_ . $p, $supplier_sending_ . $p, $supplier_guarantee_ . $p, $supplier_price_ . $p, $supplier_colors_ . $p);
$proSupply_ . $p = json_encode($supplier_info_ . $p);
if(!empty($supplier_name_ . $p)&&(!empty($supplier_sending_ . $p))&&(!empty($supplier_guarantee_ . $p))&&(!empty($supplier_price_ . $p))&&(!empty($supplier_colors_ . $p))){
$sql = "ALTER TABLE products ADD '.$supplier_name_ . $p.' varchar(500) AFTER supplier_info_1";
if ($con->query($sql) === TRUE){
$insert_suppliers = "
INSERT INTO `products` (`supplier_info_" . $p . "`)
VALUES ('$proSupply_" . $p . "')
";
$run_suppliers = mysqli_query($con,$insert_suppliers);
if(!$run_product){
error_reporting(E_ALL);
die(mysqli_error($con));
}
}else{
error_reporting(E_ALL);
die(mysqli_error($con));
}
}
}
在MariaDB
这里,ADD COLUMN 仅在添加的列出现在表中最后时才适用。 有关此内容的更多详细信息,请查看手册链接。
因为在您的代码中,您每次都在"supplier_info_1"之后插入/创建新列。这是错误的原因。
您应该使该列动态化。
if($p == 2){
$sql = "ALTER TABLE products ADD '.$supplier_name_ . $p.' varchar(500) AFTER supplier_info_1";
} else if($p > 2) {
$i = $p-1;
$sql = "ALTER TABLE products ADD '.$supplier_name_ . $p.' varchar(500) AFTER supplier_info_".$i;
}
问题出在你的语法上
$sql = "ALTER TABLE products ADD '.$supplier_name_ . $p.' varchar(500) AFTER supplier_info_1";
我看到您使用 for 循环在表中添加表字段并在 SQL 查询中使用 AFTER supplier_info_1"
。
一旦插入字段后supplier_info_1"
将更改为更新的字段。
因此,解决方案是获取最后一个输入字段并在此处打印。
我希望它有所帮助!