-1

我有一点问题,很抱歉打扰你,但我看了很多,找不到一个好的答案。当用户在我的页面上提交数据时,数据会发送到我的 mysql 服务器并被存储,mysql 会给它一个 auto_increment id。当用户提交时,我希望 mysql 分配给他们提交的 id 被回显。任何人都可以帮忙吗?

这是我的代码:

<?php $con=mysqli_connect('host','username','pass','db');
if (mysqli_connect_errno())
  {
  echo "Failed to connect to MySQL: " . mysqli_connect_error();
  }

$sql="INSERT INTO subusers (username, date, ip)
VALUES
('$_POST[username]','$_POST[date]','$_POST[ip]')";
if (!mysqli_query($con,$sql))
  {
  die('Error: ' . mysqli_error($con));
  }
echo "1 record added", mysql_insert_id();
mysqli_close($con);
?>

这就是将他们的数据发送到服务器的代码,当它发送并从服务器获取 id 时,我希望它回显 id。

4

3 回答 3

2

问题是您正在混合mysqlmysqli语法。

您应该mysql_insert_id()在代码中替换为mysqli_insert_id($con).

现在你应该有正确的计数。

除此之外,您还有一个 sql 注入问题。您应该切换到带有绑定变量的预处理语句,而不是$_POST直接在查询中注入变量。

于 2013-07-01T01:35:43.433 回答
0

查看mysql_insert_idmysqli_insert_id(对于 PHP 的更新版本)。

例如。 echo mysql_insert_id()

于 2013-07-01T01:23:23.163 回答
0

php函数

mysql_insert_id()
mysqli_insert_id()

将返回插入的最后一行的主键。

于 2013-07-01T01:31:18.870 回答