簡體   English   中英

PHP:返回最后插入的ID on語句

[英]PHP : return last inserted Id on statement

所以我想獲取並返回查詢中最后插入的ID。 我成功獲取了最后插入的ID,但是嘗試將其返回到index.php文件時遇到了一些問題

這是我的方法代碼:

        public function InsertUserCard(UserCard $uc)
        {
            if(!$this->DuplicateUserCard($uc))
            {
                $stmt = $this->conn->prepare("INSERT INTO ".$this->table_name."
                                             (user_id, card_id, barcode, barcode_format, created_at, updated_at) 
                                             VALUES(?, ?, ?, ?, ?, ?)");
                if ($stmt == FALSE)
                {
                    die($this->conn->error);
                }
                else  
                {
                    $user_id = NULL;
                    $card_id = NULL;
                    $barcode = NULL;
                    $barcode_format = NULL;
                    $created_at = NULL;
                    $updated_at = NULL;
                    $stmt->bind_param("iissss", $user_id, $card_id, $barcode, $barcode_format, $created_at, $updated_at);
                    $user_id = $uc->getUserId();
                    $card_id =  $uc->getCardId();
                    $barcode = $uc->getBarcode();
                    $barcode_format = $uc->getBarcodeFormat();
                    $created_at = $uc->getCreatedAt();
                    $updated_at = $uc->getUpdatedAt();

                    $stmt->execute();
                    $result = $this->conn->insert_id;   <-- This is how I get the last inserted id
                    $stmt->close();
                }

                // Check for successful insertion
                if ($result) 
                {
                    // User card successfully inserted
                    return USER_CARD_INSERTED_SUCCESSFULLY;
                } 
                else 
                {
                    // Failed to insert user card
                    return USER_CARD_INSERT_FAILED;
                }
            }
            else
            {
                return USER_CARD_ALREADY_EXISTED;
            }
        }

這是我的index.php文件

$app->post('/user/card/rev', 'authenticate', function() use ($app) 
{
            // check for required params
            verifyRequiredParams(array('user_id', 'card_id', 'barcode', 'barcode_format', 'created_at', 'updated_at'));

            global $user_id;

            $response = array();
            $timestamp = time();
            $now = date("Y-m-d H:i:s", $timestamp);
            $uc = new UserCard();
            $uc->setUserId($user_id);
            $uc->setCardId($app->request->post('card_id'));
            $uc->setBarcode($app->request->post('barcode'));
            $uc->setBarcodeFormat($app->request->post('barcode_format'));
            $uc->setCreatedAt($app->request->post('created_at'));
            $uc->setUpdatedAt($app->request->post('updated_at'));


            // choose card from db by user
            $UserCardDB = new UserCardDB(MySqlDb::getInstance()->connect());
            $UserCard = $UserCardDB->InsertUserCard($uc);

            if ($UserCard == USER_CARD_INSERTED_SUCCESSFULLY) 
            {
                $response["error"] = false;
                $response["message"] = "User Card added successfully";
                $response["current_timestamp"] = $timestamp;
                $response["current_date"] = $now;
                $response["last_inserted_id"] = SHOULD_BE_HERE;
                echoRespnse(201, $response);
            } 

});

如您所見,我想將最后插入的id放在$response["last_inserted_id"] ,但是我不知道該怎么做。

有任何想法嗎 ?

謝謝:)

我想你的陳述倒退了

$inserted_id = $this->conn->insert_id;
$result = $stmt->execute();

在准備好的語句中, execute是運行SQL的內容。 因此,您無法獲取尚未插入的內容的ID。

$result = $stmt->execute();
$inserted_id = $this->conn->insert_id;

您也不會將數據存儲在任何可用的位置( $inserted_id是函數的局部變量)。 考慮制作一個像$this->inserted_id這樣的類變量,並制作一個將返回該值的函數。

在您的方法中嘗試以下方法:

    public function InsertUserCard(UserCard $uc)
    {
        if(!$this->DuplicateUserCard($uc))
        {
            $stmt = $this->conn->prepare("INSERT INTO ".$this->table_name."
                                         (user_id, card_id, barcode, barcode_format, created_at, updated_at) 
                                         VALUES(?, ?, ?, ?, ?, ?)");
            if ($stmt == FALSE)
            {
                die($this->conn->error);
            }
            else  
            {
                $user_id = NULL;
                $card_id = NULL;
                $barcode = NULL;
                $barcode_format = NULL;
                $created_at = NULL;
                $updated_at = NULL;
                $stmt->bind_param("iissss", $user_id, $card_id, $barcode, $barcode_format, $created_at, $updated_at);
                $user_id = $uc->getUserId();
                $card_id =  $uc->getCardId();
                $barcode = $uc->getBarcode();
                $barcode_format = $uc->getBarcodeFormat();
                $created_at = $uc->getCreatedAt();
                $updated_at = $uc->getUpdatedAt();
            }

            // Check for successful insertion
            if ($stmt->execute()) 
            {
                $result = $this->conn->insert_id;
                $stmt->close();
                return $result;
            } 
            else 
            {
                // Failed to insert user card
                return USER_CARD_INSERT_FAILED;
            }
        }
        else
        {
            return USER_CARD_ALREADY_EXISTED;
        }
    }

並在您index.php中:

$app->post('/user/card/rev', 'authenticate', function() use ($app) 
{
            // check for required params
            verifyRequiredParams(array('user_id', 'card_id', 'barcode', 'barcode_format', 'created_at', 'updated_at'));

            global $user_id;

            $response = array();
            $timestamp = time();
            $now = date("Y-m-d H:i:s", $timestamp);
            $uc = new UserCard();
            $uc->setUserId($user_id);
            $uc->setCardId($app->request->post('card_id'));
            $uc->setBarcode($app->request->post('barcode'));
            $uc->setBarcodeFormat($app->request->post('barcode_format'));
            $uc->setCreatedAt($app->request->post('created_at'));
            $uc->setUpdatedAt($app->request->post('updated_at'));


            // choose card from db by user
            $UserCardDB = new UserCardDB(MySqlDb::getInstance()->connect());
            $UserCard = $UserCardDB->InsertUserCard($uc);

            if (($UserCard != "USER_CARD_INSERT_FAILED") and ($UserCard != "USER_CARD_ALREADY_EXISTED"))
            {
                $response["error"] = false;
                $response["message"] = "User Card added successfully";
                $response["current_timestamp"] = $timestamp;
                $response["current_date"] = $now;
                $response["last_inserted_id"] = $UserCard;
                echoRespnse(201, $response);
            } 

});

在您的方法代碼中,而不是使用$inserted_id使用$_SESSION變量$ _SESSION ['inserted_id']。 現在您將可以在index.php中使用它

$response["last_inserted_id"] = $_SESSION['inserted_id '];  

按照我的理解,由於功能以return $result;終止, return $result; // Check for successful insertion將永遠不會運行return $result; 有條件之前。 因此,永遠不會返回USER_CARD_INSERTED_SUCCESSFULLY。

在我的函數中,通常返回一個數組,例如:

 $result = array( "status" => $status, "id" => $id );
 return $result;

並且,主要是:

 $result = my_function();

 $status = $result['status'];
 $id = $result['id'];

希望對您有所幫助!

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM