-3

我正在尝试在 PHP 中运行 SQL 查询。使用以下代码:

$sql="INSERT into members (forename, surname, dob_day, dob_month, dob_year, gender, address, invested, patrol_type, patrol, dr_address, 

parent1_contact1_title, parent1_contact1_forename, parent1_contact1_surname, parent1_contact1_email, parent1_contact1_address, parent1_contact1_home, parent1_contact1_mobile, parent1_contact1_other, 

parent1_contact2_title, parent1_contact2_forename, parent1_contact2_surname, parent1_contact2_email, parent1_contact2_address, parent1_contact2_home, parent2_contact1_mobile, parent1_contact2_other, 

parent2_contact1_title, parent1_contact1_forename, parent1_contact1_surname, parent1_contact1_email, parent1_contact1_address, parent1_contact1_home, parent1_contact1_mobile, parent1_contact1_other, 

parent1_contact2_title, parent1_contact2_forename, parent1_contact2_surname, parent1_contact2_email, parent1_contact2_address, parent1_contact2_home, parent2_contact1_mobile, parent1_contact2_other

) values ('".addslashes($_POST["forename"])."', '".addslashes($_POST["surname"])."', '".addslashes($_POST["dob_day"])."', '".addslashes($_POST["dob_month"])."', '".addslashes($_POST["dob_year"])."', '".addslashes($_POST["gender"])."', '".addslashes($_POST["address"])."', '".addslashes($_POST["invested"])."', '".addslashes($_POST["patrol_type"])."', '".addslashes($_POST["patrol"])."', '".addslashes($_POST["dr_address"])."', 

'".addslashes($_POST["parent1_contact1_title"])."', '".addslashes($_POST["parent1_contact1_forename"])."', '".addslashes($_POST["parent1_contact1_surname"])."', '".addslashes($_POST["parent1_contact1_email"])."', '".addslashes($_POST["parent1_contact1_address"])."', '".addslashes($_POST["parent1_contact1_home"])."', '".addslashes($_POST["parent1_contact1_mobile"])."', '".addslashes($_POST["parent1_contact1_other"])."', 

'".addslashes($_POST["parent1_contact2_title"])."', '".addslashes($_POST["parent1_contact2_forename"])."', '".addslashes($_POST["parent1_contact2_surname"])."', '".addslashes($_POST["parent1_contact2_email"])."', '".addslashes($_POST["parent1_contact2_address"])."', '".addslashes($_POST["parent1_contact2_home"])."', '".addslashes($_POST["parent1_contact2_mobile"])."', '".addslashes($_POST["parent1_contact2_other"])."', 

'".addslashes($_POST["parent2_contact2_title"])."', '".addslashes($_POST["parent1_contact2_forename"])."', '".addslashes($_POST["parent1_contact2_surname"])."', '".addslashes($_POST["parent1_contact2_email"])."', '".addslashes($_POST["parent1_contact2_address"])."', '".addslashes($_POST["parent1_contact2_home"])."', '".addslashes($_POST["parent1_contact2_mobile"])."', '".addslashes($_POST["parent1_contact2_other"])."'

) ";

但我收到一条错误消息:Column count doesn't match value count at row 1

我找不到错误在哪里 - 任何人都可以找到这个吗?

4

5 回答 5

1

我将您的查询复制到文本编辑器中。我使用逗号作为分隔符将它分成几行,我有 43 列和 35 个值。
在表中使用更少的列并以通用模式拆分记录,如下所示:

  Table students:
    id, forename, surname, details, parent1_id, parent2_id, etc..
  Table parents:
    id (used in table students), name, contact details, etc..
于 2013-09-30T08:13:32.373 回答
0

您的插入查询不止一次包含这些列:

parent1_contact2_title, parent1_contact2_forename, parent1_contact2_surname, parent1_contact2_email, parent1_contact2_address, parent1_contact2_home, parent2_contact1_mobile, parent1_contact2_other

但不要在查询中出现两次。因此,您指定的列数与您提供的值不同。

于 2013-09-30T08:15:22.093 回答
0

您的列名有错误,其中一些是重复的:

$sql="INSERT into members (forename, surname, dob_day, dob_month, dob_year, gender, address, invested, patrol_type, patrol, dr_address, 

parent1_contact1_title, parent1_contact1_forename, parent1_contact1_surname, parent1_contact1_email, parent1_contact1_address, parent1_contact1_home, parent1_contact1_mobile, parent1_contact1_other, 

parent1_contact2_title, parent1_contact2_forename, parent1_contact2_surname, parent1_contact2_email, parent1_contact2_address, parent1_contact2_home, parent2_contact1_mobile, parent1_contact2_other, 

parent2_contact1_title, parent1_contact1_forename, parent1_contact1_surname, parent1_contact1_email, parent1_contact1_address, parent1_contact1_home, parent1_contact1_mobile, parent1_contact1_other, 

parent1_contact2_title, parent1_contact2_forename, parent1_contact2_surname, parent1_contact2_email, parent1_contact2_address, parent1_contact2_home, parent2_contact1_mobile, parent1_contact2_other

) 

例如parent1_contact1_forename重复,将列名修复为相关

于 2013-09-30T08:16:34.397 回答
0

这是因为您的表格中的列数和您在表格中提供的数值不同。错误表示 sql 语句中指定的列数与提供的值数不匹配。
例如,如果我有一个名称test和列如下的表:
1)。标识
2)。名称
3)。4岁
)。Sex
Now 让我们在这个表中创建插入数据

$con = mysqli_connect("host","user","pass","dbName");
if(!$con)
die();
$res = mysqli_query($con,"INSERT INTO test(id,name,age,sex) VALUES(abc,xyz,pqr)");
//the query statement will generate an error similar to your's because the number
//of parameters to be filled does not match the values supplied
于 2013-09-30T08:18:38.210 回答
0

这些是您的数据库字段:

$sql="INSERT into members (
forename, 
surname, 
dob_day, 
dob_month, 
dob_year, 
gender, 
address, 
invested, 
patrol_type, 
patrol, 
dr_address, 
parent1_contact1_title, 
parent1_contact1_forename, 
parent1_contact1_surname, 
parent1_contact1_email, 
parent1_contact1_address, 
parent1_contact1_home, 
parent1_contact1_mobile, 
parent1_contact1_other, 
parent1_contact2_title, 
parent1_contact2_forename, 
parent1_contact2_surname, 
parent1_contact2_email, 
parent1_contact2_address, 
parent1_contact2_home, 
parent2_contact1_mobile, 
parent1_contact2_other, 
parent2_contact1_title, 
parent1_contact1_forename, 
parent1_contact1_surname, 
parent1_contact1_email, 
parent1_contact1_address, 
parent1_contact1_home, 
parent1_contact1_mobile, 
parent1_contact1_other, 
parent1_contact2_title, 
parent1_contact2_forename, 
parent1_contact2_surname, 
parent1_contact2_email, 
parent1_contact2_address, 
parent1_contact2_home, 
parent2_contact1_mobile, 
parent1_contact2_other

这些是您尝试存储的值:

'".addslashes($_POST["forename"])."', 
 '".addslashes($_POST["surname"])."', 
 '".addslashes($_POST["dob_day"])."', 
 '".addslashes($_POST["dob_month"])."', 
 '".addslashes($_POST["dob_year"])."', 
 '".addslashes($_POST["gender"])."', 
 '".addslashes($_POST["address"])."', 
 '".addslashes($_POST["invested"])."', 
 '".addslashes($_POST["patrol_type"])."', 
 '".addslashes($_POST["patrol"])."', 
 '".addslashes($_POST["dr_address"])."',
 '".addslashes($_POST["parent1_contact1_title"])."', 
 '".addslashes($_POST["parent1_contact1_forename"])."', 
 '".addslashes($_POST["parent1_contact1_surname"])."', 
 '".addslashes($_POST["parent1_contact1_email"])."', 
 '".addslashes($_POST["parent1_contact1_address"])."', 
 '".addslashes($_POST["parent1_contact1_home"])."', 
 '".addslashes($_POST["parent1_contact1_mobile"])."', 
 '".addslashes($_POST["parent1_contact1_other"])."', 
 '".addslashes($_POST["parent1_contact2_title"])."', 
 '".addslashes($_POST["parent1_contact2_forename"])."', 
 '".addslashes($_POST["parent1_contact2_surname"])."', 
 '".addslashes($_POST["parent1_contact2_email"])."', 
 '".addslashes($_POST["parent1_contact2_address"])."', 
 '".addslashes($_POST["parent1_contact2_home"])."', 
 '".addslashes($_POST["parent1_contact2_mobile"])."', 
 '".addslashes($_POST["parent1_contact2_other"])."',
 '".addslashes($_POST["parent2_contact2_title"])."', 
 '".addslashes($_POST["parent1_contact2_forename"])."', 
 '".addslashes($_POST["parent1_contact2_surname"])."', 
 '".addslashes($_POST["parent1_contact2_email"])."', 
 '".addslashes($_POST["parent1_contact2_address"])."', 
 '".addslashes($_POST["parent1_contact2_home"])."', 
 '".addslashes($_POST["parent1_contact2_mobile"])."', 
 '".addslashes($_POST["parent1_contact2_other"])."'

您的复制/粘贴出现问题,或者由于大量重复数据而需要检查您的数据库结构。

于 2013-09-30T08:23:44.717 回答