如何从PDO获取最后插入的插入行ID

快乐先生

我正在使用PHP中的mvc结构,我想检索最后插入的行ID。

我创建了以下sql代码:

$sql = "INSERT INTO song (artist, track, link) VALUES (:artist, :track, :link)";
$query = $this->db->prepare($sql);
$query->execute(array(':artist' => $artist, ':track' => $track, ':link' => $link));

echo $query->lastInsertId(); // To retrieve last inserted row ID.

但不幸的是我遇到了这个错误: Fatal error: Call to undefined method PDOStatement::lastInsertId()

我也尝试过此堆栈链接,但不适用于我,因此,如果您能帮助我获取ID,我将非常高兴。

我也在这里共享我的controller.php文件。

/**
 * This is the "base controller class". All other "real" controllers extend this class.
 */
class Controller{
    /**
     * @var null Database Connection
     */
    public $db = null;

    /**
     * Whenever a controller is created, open a database connection too. The idea behind is to have ONE connection
     * that can be used by multiple models (there are frameworks that open one connection per model).
     */
    function __construct(){
        $this->openDatabaseConnection();
    }

    /**
     * Open the database connection with the credentials from application/config/config.php
     */
    private function openDatabaseConnection(){
        // set the (optional) options of the PDO connection. in this case, we set the fetch mode to
        // "objects", which means all results will be objects, like this: $result->user_name !
        // For example, fetch mode FETCH_ASSOC would return results like this: $result["user_name] !
        // @see http://www.php.net/manual/en/pdostatement.fetch.php
        $options = array(PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_OBJ, PDO::ATTR_ERRMODE => PDO::ERRMODE_WARNING);

        // generate a database connection, using the PDO connector
        // @see http://net.tutsplus.com/tutorials/php/why-you-should-be-using-phps-pdo-for-database-access/
        $this->db = new PDO(DB_TYPE . ':host=' . DB_HOST . ';dbname=' . DB_NAME, DB_USER, DB_PASS, $options);
    }

    /**
     * Load the model with the given name.
     * loadModel("SongModel") would include models/songmodel.php and create the object in the controller, like this:
     * $songs_model = $this->loadModel('SongsModel');
     * Note that the model class name is written in "CamelCase", the model's filename is the same in lowercase letters
     * @param string $model_name The name of the model
     * @return object model
     */
    public function loadModel($model_name){
        require 'application/models/' . strtolower($model_name) . '.php';
        // return new model (and pass the database connection to the model)
        return new $model_name($this->db);
    }
}
安德鲁西

你快到了。

如果您查看lastInsertId的手册页,则会在数据库句柄上调用它-您当前正在语句中调用它。

您只需要致电:

$this->db->lastInsertId();

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章

来自分类Dev

获取最后插入行的 id

来自分类Dev

获取插入行的ID

来自分类Dev

获取插入行的ID

来自分类Dev

获取最后的插入行 mysql

来自分类Dev

插入行并获取生成的ID

来自分类Dev

获取最后插入的ID

来自分类Dev

如何从Laravel 4获取最后的插入ID

来自分类Dev

如何使用Hibernate获取最后插入的ID

来自分类Dev

如何获取最后插入的行的ID

来自分类Dev

Codeigniter:如何获取最后插入的ID?

来自分类Dev

如何使用AJAX获取最后插入的ID?

来自分类Dev

如何获取特定ID的最后插入记录?

来自分类Dev

PHP MySQL PDO:获取最后插入的ROW而不是ID

来自分类Dev

如何从插入方法Laravel 5.1获取最后插入的ID

来自分类Dev

如何在多个记录插入中获取最后插入的ID?

来自分类Dev

PostgreSQL函数:获取更新或插入行的ID

来自分类Dev

插入行后从游标获取生成的ID

来自分类Dev

在调用 lastInsertId() 以获取 PDO 中最后插入的 ID 之前是否必须插入新记录?

来自分类Dev

获取插入行的行号

来自分类Dev

获取插入行的PID

来自分类Dev

获取Postgresql的最后插入ID

来自分类Dev

异常获取最后插入的 id

来自分类Dev

如果找不到ID,如何插入行?

来自分类Dev

如何插入 ID +1 并获取最后一个 ID?

来自分类Dev

如何获取最后插入的记录

来自分类Dev

如何获取最后插入的主键

来自分类Dev

如何获取最后插入的主键

来自分类Dev

如何获得插入行PDO PHP的自动增量主键?

来自分类Dev

如何获取插入的最后一行的id(自动递增)