I’m using a HTML form that captures user input for several fields, some of which can be left blank by the user, one particular field is called ‘pasref’. What I would like to be able to do, if at all possible, is if this field is left blank by the user, for the default value to become the text ‘Not Allocated’ and for this to be saved as part of the record to a mySQL database.
I just admit I’m fairly new to this type of programming and I’m not sure whether this can be done within the mySQL database or whether it needs to be done as part of the php script that saves each record. I just wondered whether it would be at all possible please that someone could show me what I need to do?
I’ve included my PHP script below if it helps.
<?php
require("phpfile.php");
// Gets data from URL parameters
$userid = $_GET['userid'];
$locationid = $_GET['locationid'];
$pasref = $_GET['pasref'];
$additionalcomments = $_GET['additionalcomments'];
// Opens a connection to a MySQL server
$connection = mysql_connect ("hostname", $username, $password);
if (!$connection) {
die('Not connected : ' . mysql_error());
}
// Set the active MySQL database
$db_selected = mysql_select_db($database, $connection);
if (!$db_selected) {
die ('Can\'t use db : ' . mysql_error());
}
// Insert new row with user data
$query = sprintf("INSERT INTO finds " .
" (userid, locationid, pasref, additionalcomments ) " .
" VALUES ('%s', '%s', '%s', '%s');",
mysql_real_escape_string($userid),
mysql_real_escape_string($locationid),
mysql_real_escape_string($pasref),
mysql_real_escape_string($additionalcomments));
$result = mysql_query($query);
if (!$result) {
die('Invalid query: ' . mysql_error());
}
?>
You can set the default value on the column of mysql. You need to execute a query something like this:
Change
varchar(100)to whatever length it should be for your field.Alternatively you could just set it in php:
Or finally you could put it as a default value in your form. Though the user would need to clear it if they want something else:
Finally just to note in your PHP you need to escape your inputs to the database with
mysql_real_escape_stringor use PDO with placeholders. As is you have a SQL injection vulnerability.It’s also better to use POST. Change the form method to
POSTin your HTML and reference$_POSTinstead of$_GET