繁体   English   中英

获取自动增量ID MySQL

[英]Get auto increment id mysql

如何获取mysql查询的自动递增的用户ID。 我用mysql_insert_id()尝试了一下,但是没有用。

    if(isset($_COOKIE['username'])){
    $cookie = $_COOKIE['username'];
    header('Location: http://' . $_SERVER['HTTP_HOST'] . '/source/main.html');
}
else{
    $message = array();
    if (!empty($_POST)) {
        if (
            empty($_POST['f']['username'])

        ) {
            $message['error'] = 'Es wurden nicht alle Felder ausgefüllt.';
        } 
        $mysqli = @new mysqli('localhost', 'user', 'pw', 'loginsystem');
            if ($mysqli->connect_error) {
                $message['error'] = 'Datenbankverbindung fehlgeschlagen: ' . $mysqli->connect_error;
            }
            $query = sprintf(
                "INSERT INTO users (username)
                SELECT * FROM (SELECT '%s') as new_user
                WHERE NOT EXISTS (
                    SELECT username FROM users WHERE username = '%s'
                ) LIMIT 1;",
                $mysqli->real_escape_string($_POST['f']['username']),

                $mysqli->real_escape_string($_POST['f']['username'])

            );
            $id = mysql_insert_id();

            $mysqli->query($query);
            if ($mysqli->affected_rows == 1) {
                $message['success'] = 'Neuer Benutzer (' . htmlspecialchars($_POST['f']['username']) . ') wurde angelegt, <a href="login.php">weiter zur Anmeldung</a>.';
                header('Location: http://' . $_SERVER['HTTP_HOST'] . '/source/main.html');
            } else {

            }
            $t = time() + 60; //* 60 * 24 * 1000;
            setcookie("username", $_POST['f']['username'], $t);
            setcookie("userid", $id , $t);
            // cookie setzen
            $mysqli->close();
        }
}
?>

您正在使用mysqli而不是mysql

尝试$id = $mysqli->insert_id; 经过查询之后才可以。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM