ошибка mysqli — bind_param: количество переменных не совпадает

Я получаю следующую ошибку, но я пересчитал все снова и снова, и все, кажется, в порядке. У кого-нибудь есть идеи по этому поводу?

Ошибка:

Предупреждение: mysqli_stmt :: bind_param () [mysqli-stmt.bind-param]: Количество
переменные не соответствуют количеству параметров в подготовленном утверждении в
/home/ambnews/public_html/invoice/response.php онлайн
204

Код:

// invoice customer information
// billing
$customer_name = $mysqli->real_escape_string($_POST['customer_name']); // customer name
$customer_email = $mysqli->real_escape_string($_POST['customer_email']); // customer email
$customer_address_1 = $mysqli->real_escape_string($_POST['customer_address_1']); // customer address
$customer_address_2 = $mysqli->real_escape_string($_POST['customer_address_2']); // customer address
$customer_town = $mysqli->real_escape_string($_POST['customer_town']); // customer town
$customer_county = $mysqli->real_escape_string($_POST['customer_county']); // customer county
$customer_postcode = $mysqli->real_escape_string($_POST['customer_postcode']); // customer postcode
$customer_phone = $mysqli->real_escape_string($_POST['customer_phone']); // customer phone number

//shipping
$customer_name_ship = $mysqli->real_escape_string($_POST['customer_name_ship']); // customer name (shipping)
$customer_address_1_ship = $mysqli->real_escape_string($_POST['customer_address_1_ship']); // customer address (shipping)
$customer_address_2_ship = $mysqli->real_escape_string($_POST['customer_address_2_ship']); // customer address (shipping)
$customer_town_ship = $mysqli->real_escape_string($_POST['customer_town_ship']); // customer town (shipping)
$customer_county_ship = $mysqli->real_escape_string($_POST['customer_county_ship']); // customer county (shipping)
$customer_postcode_ship = $mysqli->real_escape_string($_POST['customer_postcode_ship']); // customer postcode (shipping)

$query = "INSERT INTO store_customers (
name,
email,
address_1,
address_2,
town,
county,
postcode,
phone,
name_ship,
address_1_ship,
address_2_ship,
town_ship,
county_ship,
postcode_ship
) VALUES (
'".$customer_name."',
'".$customer_email."',
'".$customer_address_1."',
'".$customer_address_2."',
'".$customer_town."',
'".$customer_county."',
'".$customer_postcode."',
'".$customer_phone."',
'".$customer_name_ship."',
'".$customer_address_1_ship."',
'".$customer_address_2_ship."',
'".$customer_town_ship."',
'".$customer_county_ship."',
'".$customer_postcode_ship."'
);
";

/* Prepare statement */
$stmt = $mysqli->prepare($query);
if($stmt === false) {
trigger_error('Wrong SQL: ' . $query . ' Error: ' . $mysqli->error, E_USER_ERROR);
}

print_r($stmt->bind_param(
'sssssssissssss',
$customer_name,$customer_email,$customer_address_1,$customer_address_2,$customer_town,$customer_county,$customer_postcode,
$customer_phone,$customer_name_ship,$customer_address_1_ship,$customer_address_2_ship,$customer_town_ship,$customer_county_ship,$customer_postcode_ship));

/* Bind parameters. TYpes: s = string, i = integer, d = double,  b = blob */
$stmt->bind_param(
'sssssssissssss',
$customer_name,$customer_email,$customer_address_1,$customer_address_2,$customer_town,$customer_county,$customer_postcode,
$customer_phone,$customer_name_ship,$customer_address_1_ship,$customer_address_2_ship,$customer_town_ship,$customer_county_ship,$customer_postcode_ship);

/* Execute statement */
$stmt->execute();

if($stmt->execute()){
//if saving success
echo json_encode(array(
'status' => 'Success',
'message' => 'Customer has been created successfully!'
));
} else {
// if unable to create invoice
echo json_encode(array(
'status' => 'Error',
'message' => 'There has been an error, please try again.'
// debug
//'message' => 'There has been an error, please try again.<pre>'.$mysqli->error.'</pre><pre>'.$query.'</pre>'
));
}

//close database connection
$mysqli->close();

0

Решение

Вы должны взглянуть на руководство:

  1. Вы не должны избегать своих значений, когда используете готовый оператор, так как вы будете добавлять буквенные обратные слэши в свои данные.
  2. Вы не должны вставлять свои переменные в запрос, а использовать вместо них заполнители (вопросительные знаки в mysqli). Это связано с вашими ценностями.

Итак, ваш запрос будет:

$query = "INSERT INTO store_customers (
name,
email,
// etc.
) VALUES (
?,
?,
// etc.
);
";

И вы связываете свои ценности:

$stmt->bind_value(
'sssssssissssss',
$_POST['customer_name'],
$_POST['customer_email'],
// etc.
);

Обратите внимание, что я использую bind_value() вместо bind_param() поскольку это, кажется, используется только один раз, поэтому нет необходимости связывать параметры, вы можете связать значения напрямую. Это не должно иметь значение, хотя.

0

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]