PHP MYSQL FORMS - PullRequest
       4

PHP MYSQL FORMS

0 голосов
/ 24 августа 2009

Я хочу использовать гиперссылку на одной странице для загрузки сведений на другую страницу формы, а затем обновить таблицу базы данных, используя значения полей формы.

У меня есть 2 PHP-страницы. Один возвращает bet_id последних 10 записей запроса MYSQL, а другой возвращает все значения полей для определенной записи в форму, предоставляя конечному пользователю возможность обновить значения полей. Я могу связать их так, чтобы, когда я нажимаю на строку 3 (bet_id = 3) таблицы на первой странице, я перехожу на вторую страницу, используя bet_id '3' в запросе MYSQL, используемом на второй странице, чтобы предварительно заполните поля формы правильными значениями.

У меня проблемы с обновлением базы данных новыми значениями, которые я ввел, когда нажал кнопку «Обновить ставку» в форме. Поля, которые я показываю в форме страницы 2, это «punter_id» и «category_id». Кто-нибудь может подсказать, что может пойти не так? Я не получаю никаких ошибок, когда нажимаю кнопку «Обновить ставку», но значения полей формы просто возвращаются к тому, что они были изначально, и таблица базы данных не обновляется запросом, объявленным в $ query (см. Ниже).

Код включен ниже:

<?php require_once('../Connections/punters_c.php'); ?>
<?php

mysql_select_db($database_punters_c, $punters_c);

$query_Recordset1 = "SELECT bet_id, punter_id,category_id FROM betslip where bet_id =".intval($_REQUEST['bet_id']);
$Recordset1 = mysql_query($query_Recordset1, $punters_c) or die(mysql_error());
$row_Recordset1         = mysql_fetch_assoc($Recordset1);
$totalRows_Recordset1     = mysql_num_rows($Recordset1);


function GetSQLValueString($theValue, $theType, $theDefinedValue = "", $theNotDefinedValue = "") 
{
$theValue = (!get_magic_quotes_gpc()) ? addslashes($theValue) : $theValue;

switch ($theType) {
case "text":
  $theValue = ($theValue != "") ? "'" . $theValue . "'" : "NULL";
  break;    
case "long":
case "int":
  $theValue = ($theValue != "") ? intval($theValue) : "NULL";
  break;
case "double":
  $theValue = ($theValue != "") ? "'" . doubleval($theValue) . "'" : "NULL";
  break;
case "date":
  $theValue = ($theValue != "") ? "'" . $theValue . "'" : "NULL";
  break;
case "defined":
  $theValue = ($theValue != "") ? $theDefinedValue : $theNotDefinedValue;
  break;
}
return $theValue;
}
$editFormAction = $_SERVER['PHP_SELF'];
if (isset($_SERVER['QUERY_STRING'])) {
$editFormAction .= "?" . htmlentities($_SERVER['QUERY_STRING']);
}
?>
<?

if ((isset($_POST["apply"])) && ($_POST["apply"] == "update_betslip_detail")){

    $query = sprintf("UPDATE betslip SET category_id = '%d' WHERE bet_id = %d", mysql_real_escape($_POST['category_id']), mysql_real_escape($_POST['bet_id'])
                                                            );

mysql_select_db($database_punters_c, $punters_c);
$Result1 = mysql_query($query, $punters_c) or die('Connection error to MYSQL occurred: '.(mysql_error()));

    header("Location: /update_betslip_test.php");

}
else 
{
    echo "bet detail not updated";
}
?>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"     "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1" />
<title>Untitled Document</title>
</head>

<body>
<form action="<?php echo $editFormAction; ?>" method="POST" enctype="multipart/form-data" name="update_betslip_detail">

<input type="text" name="bet id" id = "bet_id" value="<?php echo  $row_Recordset1['bet_id']; ?>"/>
<input type="text" name="category_id" id = "category_id" value="<?php echo $row_Recordset1['category_id']; ?>"/>


<input type="hidden" name= "apply" value="update_betslip_detail"/>

<input type="submit" value="Update bet"/>
</form>

<p><a href="update_betslip_test.php">Back to Update page </a></p>
</body></html>
<?php
mysql_free_result($Recordset1);
?>

Ответы [ 2 ]

0 голосов
/ 25 августа 2009

Попробуйте удалить следующий атрибут из формы:

enctype="multipart/form-data"

Поскольку вы не загружаете файлы одновременно, вам не нужно их устанавливать. Это дикое предположение, но я не вижу ничего плохого в вашем коде. Если массив $ _POST не заполняется ключами, вы никогда не получите ваш запрос UPDATE.

Поведение предполагает, что вы не попадаете в этот блок:

if ((isset($_POST["apply"])) && ($_POST["apply"] == "update_betslip_detail")){

Так что вы также можете попробовать поместить этот бит кода перед ним:

<code>echo '<pre>';
print_r($_POST);
echo '
'; умереть;

Чтобы убедиться, что массив заполнен тем, что вы ожидаете.

0 голосов
/ 24 августа 2009

Ваши страницы имеют отношение мастер-деталь, верно? В любом случае я думаю, что эта строка является проблемой:

$query = sprintf("UPDATE betslip SET category_id = '%d' WHERE bet_id = %d", mysql_real_escape($_POST['category_id']), mysql_real_escape($_POST['bet_id']));

(1) вы ставите кавычки вокруг чисел, (2) mysql_real_escape () возвращает строку. По сути, вы пытаетесь поместить строковые значения в числовые заполнители, которые sprintf (), вероятно, проигнорирует. Следовательно, ваш запрос, на самом деле, выглядит следующим образом:

UPDATE betslip SET category_id = '' WHERE bet_id = <number>;

Попробуйте изменить код на следующее:

$query = sprintf("UPDATE betslip SET category_id = %d WHERE bet_id = %d", intval(mysql_real_escape($_POST['category_id'])), intval(mysql_real_escape($_POST['bet_id'])));
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...