• Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 282
  • Last Modified:

php form problem, cant insert new record to table

hey everyone
im  kinda new to php and mysql and im having trouble inserting new record in to my database table. im not throwing the php code in the same html page. so i have the form in adduser.html then when user add all fields and submit it will go to adduser.php
in adduser.php i was able to check all inputs but cant send them to the database....
any ideas?


### ------HTML FORM--------- ###
<form action="adduser.php" method="post">
First name:<br>
<input type="text" name="fname"><br>
Last name:<br> 
<input type="text" name="lname"><br>
Email:<br> 
<input type="text" name="email"><br>
Password:<br> 
<input type="password" name="password"><br>
School/University:<br>
<input type="text" name="school_name"><br>
City:<br> 
<input type="text" name="city"><br>
State:<br> 
<input type="text" name="state">
 
<INPUT type="submit" value="send"><INPUT type="reset">
 
###----- PHP-----###
 
<?php
include 'config.php';      
include 'opendb.php';
/* Check all form inputs using check_input function */
$fname        = check_input($_POST['fname'], "Enter your first name.");
$lname        = check_input($_POST['lname'], "Enter your last name.");
$password     = check_input($_POST['password'], "Enter your pass.");
$email        = check_input($_POST['email'], "Enter your Email.");
$school_name  = check_input($_POST['school_name'], "Enter your School Name.");
$city         = check_input($_POST['city'], "Enter your City.");
$state        = check_input($_POST['state'], "Enter your State.");
 
 
/* If e-mail is not valid show error message */
if (!preg_match("/([\w\-]+\@[\w\-]+\.[\w\-]+)/", $email))
{
    show_error("E-mail address not valid");
}
else{
$data = "INSERT INTO users VALUES ('NULL', '$fname', '$lname', '$password', '$email', '$school_name', '$city', '$state')";
$query = mysql_query($data);
  if(!$query)
  {
     die(mysql_error());
  }
  else
  {
    
    /* Redirect page */
	/*header('Location: thanks.html');*/
 
 
  } 
echo "<TD valign='top'><br /><center><b>You successed!";
echo "<br>";
}
 
 
 
/* Functions I used to check */
function check_input($data, $problem='')
{
    $data = trim($data);
    $data = stripslashes($data);
    $data = htmlspecialchars($data);
    if ($problem && strlen($data) == 0)
    {
        show_error($problem);
    }
    return $data;
}
 
function show_error($myError)
{
?>
    <html>
    <body>
 
    <b>Please correct the following error:</b><br />
    <?php echo $myError; ?>
 
    </body>
    </html>
<?php
exit();
}
?>

Open in new window

0
colin0292
Asked:
colin0292
  • 6
  • 6
  • 3
  • +1
1 Solution
 
OpalelementCommented:
Is it returning any mysql error?
0
 
Loganathan NatarajanLAMP DeveloperCommented:
Try to print the Insert query and check the syntax.

$data = "INSERT INTO users VALUES ('NULL', '$fname', '$lname', '$password', '$email', '$school_name', '$city', '$state')";
 
echo $data;
 
$query = mysql_query($data);

Open in new window

0
 
colin0292Author Commented:
Opalelement it did not return any error
0
Free Tool: Path Explorer

An intuitive utility to help find the CSS path to UI elements on a webpage. These paths are used frequently in a variety of front-end development and QA automation tasks.

One of a set of tools we're offering as a way of saying thank you for being a part of the community.

 
colin0292Author Commented:
logudotcom it didn't echo $data
0
 
OpalelementCommented:
It would have to echo $data... Are you sure you put it in the right spot?

A test URL would be good:)
0
 
colin0292Author Commented:
i think i did put it in the right spot


  } 
echo "<TD valign='top'><br /><center><b>You successed!";
 
echo $data;
 
echo "<br>";
}

Open in new window

0
 
fsze88Commented:
you can try

$data = "INSERT INTO users (ffield, fname, lname, password, email, school_name, city, state) VALUES ('NULL', '$fname', '$lname', '$password', '$email', '$school_name', '$city', '$state')";
0
 
OpalelementCommented:
It goes between lines 41 and 42... Between these:
$data = "INSERT INTO users VALUES ('NULL', '$fname', '$lname', '$password', '$email', '$school_name', '$city', '$state')";
$query = mysql_query($data);

Open in new window

0
 
colin0292Author Commented:
didn't work fsze88
0
 
fsze88Commented:
will it caused by missing database link?
$link = mysql_connect('localhost', 'username', 'password');
mysql_query( $data, $link );
??
0
 
OpalelementCommented:
There would be an error if it wasn't connected to the database. With mysql_query, you don't need to pass the link.
0
 
colin0292Author Commented:
Opalelement now it echos $data but still not to database
and about my connection
i have two includes

include 'config.php';      
include 'opendb.php';
see the code below..

============config.php===========
<?php
// This is an example of config.php
$dbhost = 'localhost';
$dbuser = 'colin';
$dbpass = '*****';
$dbname = 'rating';
?>
 
 
============opendb.php==============
<?php
// This is an example opendb.php
$conn = mysql_connect($dbhost, $dbuser, $dbpass) or die('Error connecting to mysql');
mysql_select_db($dbname);
?>

Open in new window

0
 
OpalelementCommented:
Can you copy and paste the $data that was echoed?
0
 
colin0292Author Commented:
Opalelement i think you got this but what should i do with the null thing since the user_id is set to be auto_inc in the table


INSERT INTO users VALUES ('NULL', 'aliiiiiiiiiiiiii', 'rtyu', '123456', 'fghj@dfgh.com', 'dfghjkl;', 'ertyuio', 'cv')Incorrect integer value: 'NULL' for column 'user_id' at row 1
0
 
fsze88Commented:
you can try omit insert id field

$data = "INSERT INTO users ( fname, lname, password, email, school_name, city, state) VALUES ( '$fname', '$lname', '$password', '$email', '$school_name', '$city', '$state')";

0
 
OpalelementCommented:
Take null out of single quotes. That makes it so you are passing the word "null", not a null value. So it should be:
$data = "INSERT INTO users VALUES (NULL, '$fname', '$lname', '$password', '$email', '$school_name', '$city', '$state')";

Open in new window

0
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

Join & Write a Comment

Featured Post

Free Tool: Path Explorer

An intuitive utility to help find the CSS path to UI elements on a webpage. These paths are used frequently in a variety of front-end development and QA automation tasks.

One of a set of tools we're offering as a way of saying thank you for being a part of the community.

  • 6
  • 6
  • 3
  • +1
Tackle projects and never again get stuck behind a technical roadblock.
Join Now