gpt4 book ai didi

php - 在更新数据库时如何使用 php pdo 添加自动 inreement

转载 作者:行者123 更新时间:2023-11-29 21:32:28 27 4
gpt4 key购买 nike

我有这个 php 来更新上次登录和登录次数当我仅更新上次登录时间时,它正在工作,但如果我添加登录计数,它将显示错误。我希望每当用户注销时,它都会在当前计数中添加 + 1示例最后登录计数为 3,注销时它将添加 1 并更改为 4

<?php
session_start();

$db_host = "localhost";
$db_user = "root";
$db_pass = "thhdfhhfh";
$db_name = "users";

try {
$time = date('Y-m-d h:i:s');
$username = $_SESSION['username'];

$db_conn = new PDO("mysql:host={$db_host};dbname={$db_name}",$db_user,$db_pass);
$db_conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

$stmt = $db_conn->prepare("UPDATE users SET lastlogin = :lastlogin, logincount = :logincount + :add WHERE username = '$username'");
$stmt->bindParam(':lastlogin', $time);
$stmt->bindParam(':add', 1);
$stmt->execute();
session_destroy();
header('location:index.php');


}
catch(PDOException $e)
{
echo "Error:" . $e->getMessage();
}
$db_conn = null;


?>

最佳答案

您的问题是这样的:

$stmt = $db_conn->prepare("UPDATE users SET lastlogin = :lastlogin, logincount = :logincount + :add WHERE username = '$username'");
$stmt->bindParam(':lastlogin', $time);
$stmt->bindParam(':add', 1);

您的查询中有 3 个参数:laSTLoginlogincountadd。当您仅初始化 laSTLoginadd 时。

因此,logincount 从未初始化。

由于您总是将计数增加 1,因此请尝试以下操作:

$stmt = $db_conn->prepare("UPDATE users SET lastlogin = :lastlogin, logincount = logincount + 1 WHERE username = '$username'");
$stmt->bindParam(':lastlogin', $time);

作为旁注:当您使用 username = '$username' 将用户名直接解析到查询中时,您就有点放弃使用准备好的语句的想法。

您还应该为此使用一个参数:

$stmt = $db_conn->prepare("UPDATE users SET lastlogin = :lastlogin, logincount = logincount + 1 WHERE username = :username");
$stmt->bindParam(':lastlogin', $time);
$stmt->bindParam(':username', $username);

关于php - 在更新数据库时如何使用 php pdo 添加自动 inreement,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35150480/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com