Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/58.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
PHP、MySql、mysqli insert_id始终返回0_Php_Mysql_Mysqli_Insert Id - Fatal编程技术网

PHP、MySql、mysqli insert_id始终返回0

PHP、MySql、mysqli insert_id始终返回0,php,mysql,mysqli,insert-id,Php,Mysql,Mysqli,Insert Id,系统/开发规范 Windows 7 Ultimate x64 SP1+所有更新 PHP版本5.5.15非线程安全(x64实验版) MySQL服务器5.6(x64) Php mysqli 我正在执行一个存储过程,将用户名和密码插入一个带有自动增量id INT(11)PK字段的表中 PROCEDURE `user_account_create`(IN userName VARCHAR(32), IN userPasskey VARCHAR(254)) BEGIN START TRANSA

系统/开发规范

  • Windows 7 Ultimate x64 SP1+所有更新
  • PHP版本5.5.15非线程安全(x64实验版)
  • MySQL服务器5.6(x64)
  • Php mysqli
我正在执行一个存储过程,将用户名和密码插入一个带有自动增量id INT(11)PK字段的表中

PROCEDURE `user_account_create`(IN userName VARCHAR(32), IN userPasskey VARCHAR(254))
BEGIN
    START TRANSACTION;
    INSERT INTO user_account (`name`, passkey) VALUES (userName, userPasskey);
    IF (ROW_COUNT() = 1) THEN COMMIT; ELSE ROLLBACK; END IF;
    SELECT ROW_COUNT() AS affected_rows; -- Used for PHP mysqli's Connection and Statement affected_rows, and num_rows (Statement) fields.
END
简而言之,我在自己的课堂上包装了mysqli

namespace DataAccess\Broker {

    final class MySqliDb {
        private $conn;

        public function __construct($dbHost, $dbUser, $dbPass, $dataBase) {
            $this->conn = new \mysqli($dbHost, $dbUser, $dbPass, $dataBase);}

        public function ExecuteStatement($cmdText, array $paramValue = null) {
            $affected = -1;
            $stmt = $this->CreateStatement($cmdText, paramValue);
            $stmt->execute();
            // echo 'insert_id' . $this->conn->insert_id;
            $stmt->store_result();
            $affected = $stmt->affected_rows;
            stmt->close();
            return $affected;
        }

        // ... other functions that utilse CreateStatement below

        private function CreateStatement($cmdText, array $paramValue = null) {
            $stmt = $this->conn->prepare($cmdText);

            if ($paramValue !== null) {
                $params = [];
                foreach ($paramValue as $p => &$v) {$params[$p] = &$v;}
                call_user_func_array([$stmt, 'bind_param'], $params);
            }
            return $stmt;
        }

    }  // class
} // namespace
在index.php页面上进行测试

use \DataAccess\Broker\MySqliDb as mysqldb;
$db = new mysqldb('127.0.0.1', 'root', '', 'thedb');
$types = 'ss'; $user_name = 'its_me'; $pass_key = 'a-hashed-password';
echo 'Affected Rows: ' . $db->ExecuteStatement('CALL user_account_create(?,?)', [$types, $user_name, $pass_key]);
将产生,受影响的行:1

插入成功。我也需要此命令的insert id,但mysqli连接和语句的insert_id均为0。从var_转储

连接的var_转储:

object(mysqli)#2 (19) {
["affected_rows"] => int(1)
["client_info"] => string(79) "mysqlnd 5.0.11-dev - 20120503 - $Id: xxx$" ["client_version"] => int(50011)
["connect_errno"] => int(0) ["connect_error"] => NULL
["errno"] => int(0) ["error"] => string(0) "" ["error_list"] => array(0) { }
["field_count"] => int(1)
["host_info"] => string(20) "127.0.0.1 via TCP/IP" ["info"] => NULL
["insert_id"] => int(0)
["server_info"] => string(6) "5.6.20" ["server_version"] => int(50620)
["stat"] => NULL
["sqlstate"] => string(5) "HY000"
["protocol_version"] => int(10)
["thread_id"] => int(6)
["warning_count"] => int(0)}
语句的var_转储:

object(mysqli_stmt)#3 (10) {
["affected_rows"] => int(1)
["insert_id"] => int(0)
["num_rows"] => int(1)
["param_count"] => int(6)
["field_count"] => int(1)
["errno"] => int(0) ["error"] => string(0) "" ["error_list"] => array(0) { }
["sqlstate"] => string(5) "00000"
["id"] => int(1)}
有趣的是,有一个字段“id”,它从我的表中的
id
字段返回所需的id。有人知道为什么insert_id返回0吗

感谢和问候,
njc

尝试使用变量编写存储过程,而不是调用
row\u count()
两次:

PROCEDURE `user_account_create`(IN userName VARCHAR(32), IN userPasskey VARCHAR(254))
BEGIN
    START TRANSACTION;
    INSERT INTO user_account (`name`, passkey) VALUES (userName, userPasskey);
    IF ((@rc := ROW_COUNT) = 1) THEN COMMIT; ELSE ROLLBACK; END IF;
    SELECT @rc AS affected_rows; -- Used for PHP mysqli's Connection and Statement affected_rows, and num_rows (Statement) fields.
END;

我想第二个调用是指
if
语句。

选择最后一个插入ID()给你什么我想
if
语句影响
行计数()。更新后立即将值分配给变量,只需使用该变量。@hjpotter92,SELECT LAST_INSERT_ID()会为我提供(自动增量)ID。在阅读了下面Gorden和Spencer的回复后,我已调整了存储过程。我将添加到下面的回答中。+1。应该在SQL语句之后立即引用ROW_COUNT()函数。后续语句可以更改或“清除”由
ROW\u COUNT()
函数返回的值。我认为实际上是
COMMIT
语句清除了它。也可以使用过程变量来保存结果,而不是用户定义的变量。在插入之后,我立即输入以下内容,在提交之前,在\u id=LAST\u INSERT\u id()中设置并设置row\u c=row\u COUNT()。在过程结束时,选择in_id作为插入_id,选择row_c作为受影响的_行。从MySqlWorkbench中可以得到正确的结果。但是在php中仍然没有插入id。谢谢你们两位。我会继续尝试你的建议。