php - mysql插入查询不起作用

标签 php mysql insert

<分区>

我有这个页面从 html 表单插入数据。没有错误显示,但也没有插入数据。这是我的代码。

<?php 
mysql_connect("localhost","root","");
mysql_select_db("hcp");

$queryUserType = "select * from user_type";
$resultUserType = mysql_query($queryUserType) or die(mysql_error());

$queryTitle = "select * from name_titles";
$resultTitle = mysql_query($queryTitle) or die(mysql_error());

$time = time();
$date = date("d-m-y");
$nowDateTime=$time.$date;

if($_REQUEST['btnUserSubmit'])
{
    $queryInsertUser="INSERT INTO  users (`title_id`, `first_name`, `last_name`, `email`, `utid`, `residence_address1`, `residence_address2`, `residence_city`, `residence_state`, `residence_country`, `residence_zipcode`, `phone_no`, `username`, `password`, `created`, `date_of_birth`, `gender` ) VALUES ('".mysql_real_escape_string($_REQUEST['$rowTitle[0]'])."', '".mysql_real_escape_string($_REQUEST['txtFirstName'])."', '".mysql_real_escape_string($_REQUEST['txtLastName'])."', '".mysql_real_escape_string($_REQUEST['txtEmail'])."', '".mysql_real_escape_string($_REQUEST['rowUserType[0]'])."', '".mysql_real_escape_string($_REQUEST['txtAddressLine1'])."', '".mysql_real_escape_string($_REQUEST['txtAddressLine2'])."', '".mysql_real_escape_string($_REQUEST['txtCity'])."', '" .mysql_real_escape_string($_REQUEST['txtState'])."', '".mysql_real_escape_string($_REQUEST['txtCountry'])."', '".mysql_real_escape_string($_REQUEST['txtPhone'])."', '".mysql_real_escape_string($_REQUEST['txtUserName'])."', '".mysql_real_escape_string($_REQUEST['txtUserPassword'])."', '".$nowDateTime."', '".mysql_real_escape_string($_REQUEST['txtdateofbirth'])."', '".mysql_real_escape_string($_REQUEST['rdGender'])."');";

$resultinsert=mysql_query($queryInsertUser) or die(mysql_error());
}
?>

我不认为页面重定向有任何问题。表单验证仍然存在。在这个表中,只有email,utid,username,password这四个字段是NOT NULL。剩下的是 Null 允许的。

最佳答案

如您所见,您缺少的字段 11,见下文:

<?php
$QueryCol   = array('title_id',             // Field 1
                    'first_name',           // Field 2
                    'last_name',            // Field 3
                    'email',                // Field 4
                    'utid',                 // Field 5
                    'residence_address1',   // Field 6
                    'residence_address2',   // Field 7
                    'residence_city',       // Field 8
                    'residence_state',      // Field 9
                    'residence_country',    // Field 10
                    'residence_zipcode',    // Field 11
                    'phone_no',             // Field 12
                    'username',             // Field 13
                    'password',             // Field 14
                    'created',              // Field 15
                    'date_of_birth',        // Field 16
                    'gender');              // Field 17

$QueryData  = array((isset($_REQUEST[$rowTitle[0]])      ? $_REQUEST[$rowTitle[0]]          : null),    // Field 1
                    (isset($_REQUEST['txtFirstName'])    ? $_REQUEST['txtFirstName']        : null),    // Field 2
                    (isset($_REQUEST['txtLastName'])     ? $_REQUEST['txtLastName']         : null),    // Field 3
                    (isset($_REQUEST['txtEmail'])        ? $_REQUEST['txtEmail']            : null),    // Field 4
                    (isset($_REQUEST[$rowUserType[0]])   ? $_REQUEST[$rowUserType[0]]       : null),    // Field 5
                    (isset($_REQUEST['txtAddressLine1']) ? $_REQUEST['txtAddressLine1']     : null),    // Field 6
                    (isset($_REQUEST['txtAddressLine2']) ? $_REQUEST['txtAddressLine2']     : null),    // Field 7
                    (isset($_REQUEST['txtCity'])         ? $_REQUEST['txtCity']             : null),    // Field 8
                    (isset($_REQUEST['txtState'])        ? $_REQUEST['txtState']            : null),    // Field 9
                    (isset($_REQUEST['txtCountry'])      ? $_REQUEST['txtCountry']          : null),    // Field 10
                                                                                                        // Field 11
                    (isset($_REQUEST['txtPhone'])        ? $_REQUEST['txtPhone']            : null),    // Field 12
                    (isset($_REQUEST['txtUserName'])     ? $_REQUEST['txtUserName']         : null),    // Field 13
                    (isset($_REQUEST['txtUserPassword']) ? $_REQUEST['txtUserPassword']     : null),    // Field 14
                    $nowDateTime,                                                                       // Field 15
                    (isset($_REQUEST['txtdateofbirth'])  ? $_REQUEST['txtdateofbirth']      : null),    // Field 16
                    (isset($_REQUEST['rdGender'])        ? $_REQUEST['rdGender']            : null);    // Field 17

foreach($QueryData as $Key => $Value){
    $QueryData[$Key] = mysql_real_escape_string($Value);
}

$QueryInsertUser    =   'INSERT INTO users (`'.implode('`, `', $QueryCol).'`)'.
                        'VALUES ("'.implode('", "', $QueryData).'")';
$resultinsert       =   mysql_query($QueryInsertUser)
                        or die(mysql_error());

?>

提示:

  1. 停止使用 $_REQUEST。使用 $_GET 或 $_POST
  2. 避免像您一样使用大线。您无法快速找到错误。
  3. 使用数组编写更少的代码。
  4. 使用array_walk函数将函数映射到数组中的每个条目。
  5. 使您的代码易于阅读,更易于调试
  6. 这样的变量 $_REQUEST['$Blabla'] 将不起作用,因为使用 ' 对解析变量不起作用,请使用 "而不是 $_REQUEST["{$ Blabla}"]。但是,要避免这种情况,因为 PHP 需要解析,这意味着需要更多的动力,请改用 $_REQUEST[$Blabla]
  7. 在开发过程中,我建议在您的脚本顶部添加以下几行:

    error_reporting(-1);
    ini_set('display_errors', 'On');
    

    它将显示所有错误。即使不是真正的错误。它将帮助您编写适用于任何地方的完美代码和标准代码。

  8. 对于每个 $_POST、$_GET、$_REQUEST、$_FILES 等,使用函数 isset因为它会产生错误。
  9. 请记住,每个错误都会使页面加载时间加倍。尝试创建一个包含 10000 行且没有错误的页面,平均时间可能为 0.01 秒。每行都有一个错误,可能需要 0.5 秒。看那个。

关于php - mysql插入查询不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10302702/

相关文章:

php - 查询为空错误

php Curl 发布到 PHPBB

sql - 共享一张 table 还是不共享一张 table ?

php - 编写双连接来获取产品的子类别

php - 解析 mysql 错误消息 - 这是正确的方法吗?

php - 在 Woocommerce 中以编程方式创建新订单

javascript - 当我选择同一标签的新复选框时,第二个标签的复选框不会取消选择选项

php - 在 PHP 函数中打开数据库连接

php - 建立评级系统 : database structure involve user_id?

mysql - PDO 获取多个插入 ID