[英]How do I insert a row when MySQL database table is empty?
我希望这不是重复的问题。 我到处搜寻,找到无济于事的答案。
我想插入表格的一行中。 听起来很简单,但是如果表为空,它将无法正常工作。 我不知道为什么。 只要表中有一行,它就可以正常工作。 任何帮助表示赞赏。 谢谢。
我的代码:
<?php
$fname = $_POST['fname'];
$mi = $_POST['mi'];
$lname = $_POST['lname'];
$phone = $_POST['phone'];
$email = $_POST['email'];
$add1 = $_POST['add1'];
$add2 = $_POST['add2'];
$city = $_POST['city'];
$state = $_POST['state'];
$zip = $_POST['zip'];
$con = mysqli_connect("localhost","database_username","database_password","database");
$sql1 = "INSERT INTO employee (fname, mi, lname, phone, email, add1, add2, city, state, zip) VALUES ('$fname', '$mi', '$lname', '$phone', '$email', '$add1', '$add2', '$city', '$state', '$zip')";
mysqli_query($con,$sql1);
mysqli_close($con);
?>
您的代码是正确的,但有时数据可能具有一些特殊字符,例如\\ /?。 等等,因此建议您更改代码中的所有变量
$fname = $_POST['fname'];
至
$fname = addslashes($_POST['fname']);
然后尝试它会完成
您没有逃避这些值。 如果任何值包含撇号,您的查询将失败。 由于它们来自帖子,因此您必须使用mysqli_real_escape_string
。
使用以下执行来插入行
mysqli_query($con,$sql1);
musqli_execute($sql1);
经过数小时的尝试后,我使它正常工作...最终,我最终首先检查了一个空表,然后在表为空的情况下重新创建了该表。
我不知道为什么会这样,但这是我的代码……有点不雅致,但是我找不到更好的解决方案。 我知道我没有逃避自己的价值观。 我待会儿。 现在,我只是想解决这个困扰我好几天的问题。
<?php
$fname = $_POST['fname'];
$mi = $_POST['mi'];
$lname = $_POST['lname'];
$phone = $_POST['phone'];
$email = $_POST['email'];
$add1 = $_POST['add1'];
$add2 = $_POST['add2'];
$city = $_POST['city'];
$state = $_POST['state'];
$zip = $_POST['zip'];
$con = mysqli_connect("localhost","username","password","database");
if (!$con) {
die('Could not connect: ' . mysql_error());
}
$sql = 'CREATE TABLE employee'
. ' ('
. ' fname text,'
. ' mi varchar(1),'
. ' lname text,'
. ' email varchar(100),'
. ' phone varchar(15)'
. ' add1 varchar(100),'
. ' add2 varchar(100),'
. ' city varchar(100),'
. ' state varchar(25)'
. ' zip varchar(10),'
. ' );';
$sql1 = "INSERT INTO employee (fname, mi, lname, phone, email, add1, add2, city, state, zip,) VALUES ('$fname', '$mi', '$lname', '$phone', '$email','$add1', '$add2', '$city', '$state', '$zip')";
$sql2 = "SELECT * FROM employee";
$sql3 = mysqli_query($con,"SELECT count(*) FROM employee");
if ($sql3 == FALSE) {
trigger_error(mysql_error()." in ".$sql3);
exit();
}
else
{
$result = mysqli_fetch_array($sql3);
}
if($result[0] != 0)
{
mysqli_query($con,$sql1);
}
else
{
mysqli_query($con,$sql);
mysqli_query($con,$sql1);
}
mysqli_close($con);
?>
如果变量是字符串,则对查询中的每个变量使用“ .. $ fname。”。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.