我正在尝试创建一个简单的html表单,通过MySQL保存信息但是我在连接数据库时遇到了一些问题。我认为$ db_selected = mysql_select_db(DB_NAME,$ link);给了我这个问题。 FYI DB_NAME是我想要使用的数据库表。
我的HTML
<form action="demo.php" method="post">
<div class="form-group">
<label for="firstname">First Name:</label>
<input type="text" class="form-control" id="firstname" name="first_name">
</div>
<div class="form-group">
<label for="lastname">Last Name:</label>
<input type="text" class="form-control" id="lastname" name="last_name">
</div>
<div class="form-group">
<label for="dob">Date of birth:</label>
<input type="password" class="form-control" id="dob" name="date_of_birth">
</div>
<div class="form-group">
<label for="pob">Place of birth:</label>
<input type="text" class="form-control" id="pob" name="place_of_birth">
</div>
<div class="form-group">
<label for="government">Your Local government:</label>
<input type="text" class="form-control" id="government" name="government">
</div>
<div class="form-group">
<label for="qualifications">Qualifications:</label>
<textarea class="form-control" rows="5" id="qualifications" name="qualifications"></textarea>
</div>
<div class="form-group">
<label for="skills">Skills:</label>
<textarea class="form-control" rows="5" id="skills" name="skills"></textarea>
</div>
<button type="submit" class="btn btn-default">Submit</button>
</form>
我的PHP
<?php
define('DB_NAME', 'forms1');
define('DB_USER', 'c88888');
define('DB_PASSWORD', '*******');
define('DB_HOST', 's********.com');
$link = mysqli_connect(DB_HOST, DB_USER, DB_PASSWORD);
$db_selected = mysqli_select_db(DB_NAME, $link);
if (!$db_selected) {
die('Can\'t use ' . DB_NAME . ': ' . mysqli_error());
}
$value = $_POST['first_name'];
$value2 = $_POST['last_name'];
$value3 = $_POST['date_of_birth'];
$value4 = $_POST['place_of_birth'];
$value5 = $_POST['government'];
$value6 = $_POST['qualifications'];
$value7 = $_POST['skills'];
$sql = "INSERT INTO demo (first_name, last_name, date_of_birth, place_of_birth, government, qualifications, skills) VALUES ('$value', '$value2', '$value3', '$value4', '$value5', '$value6', '$value7')";
if (!mysqli_query($sql)) {
die('Error: ' . mysqli_error());
}
mysqli_close();
?>
答案 0 :(得分:1)
只需将db_selected所在的代码更改为:
$db_selected = mysqli_select_db($link, DB_NAME);
并确保在使用预准备语句或mysqli_real_escape_string()
将数据库输入数据库之前转义您的值,最好使用('{$value1}', '{$value2'})
答案 1 :(得分:1)
尝试将DB_HOST提供给&#34; localhost&#34;,因为几乎每个服务器都将其数据库存储在localhost本身中。尝试以下代码连接到您的数据库,并确保提供正确的数据库名称。
<?php
header("Access-Control-Allow-Origin: *");
define('DB_NAME', 'name');
define('DB_USER', 'user');
define('DB_PASSWORD', '****');
define('DB_HOST', 'localhost');
$dbc = mysqli_connect(DB_HOST, DB_USER, DB_PASSWORD, DB_NAME);
if(!$dbc){
die('could not connect: ' .mysql_error());
}
?>
答案 2 :(得分:-2)
将SQL查询作为字符串写入时,使用反引号(`)分隔数据库字段。
您在单引号中使用'$value'
,这意味着PHP将其理解为文字$value
值,而不是变量。
您应该将查询更改为:
$sql = "INSERT INTO `demo` (`first_name`, `last_name`, `date_of_birth`, `place_of_birth`, `government`, `qualifications`, `skills`)
VALUES ('" . $value . "', '" . $value2 . "', '" . $value3 . "', '" . $value4 . "', '" . $value5 . "' , '" . $value6 . "', '" . $value7 . "')";