我需要获取在 PHP 中使用 PDO 插入的最后一行。我一直在搜索,发现 PDO::lastInsertId 但它不适用于 Oracle。
我有什么选择?其他方法可以做到这一点?我想使用 PDO 获取序列的当前值(在该表中,我使用序列来增加 ID),但我不知道是否可以。
更新1:
这是我的代码。
static function insertarProveedor($name, $address, $phone, $email) {
$con = conexionBD();
try {
$stmt = $con->prepare("INSERT INTO Proveedores (NOMBRE, DIRECCION, TELEFONO, EMAIL) VALUES (?, ?, ?, ?)
RETURNING OID_PROVEEDOR INTO :id");
$stmt->bindParam(1, $nombre);
$stmt->bindParam(2, $direccion);
$stmt->bindParam(3, $telefono);
$stmt->bindParam(4, $correo);
$stmt->bindParam('OID_PROVEEDOR', $id, PDO::PARAM_INT, 8);
} catch (PDOException $e) {
echo "Error".$e->GetMessage();
}
return $id;
}
我收到以下消息错误:
ErrorSQLSTATE[HY093]:无效参数号:混合命名参数和位置参数
注意:未定义变量:第 43 行 D:\xampp\htdocs\Gestor\include\inserciones.inc 中的 id
第 43 行是return $id;