Como retornar o id gerado apos um insert com PDO

12/09/2016

É possível pegar o id gerado em um insert com PDO. Sem precisar fazer algo com max(id) em select no mysql?

$sql = "insert into participantes
                (nome, cpf)
                values(:nome, :cpf)";
        $stmt = $this->db->prepare($sql);
        $stmt->bindParam(":nome", $nome, PDO::PARAM_STR);
        $stmt->bindParam(":cpf", $cpf, PDO::PARAM_STR);
        $stmt->execute();

Samuel Lopes

Currículo

Melhor resposta

13/09/2016

Oi Samuel,

Você pode usar $this->db->lastInsertId() depois do execute, se a versão do PHP for maior que 5.1.

Estevão Dias

Currículo
Responder Citar

Outras Respostas

13/09/2016

Ramon Guimarães

pow legal, isso ajudou muito!

Vlw Estevão!
Responder Citar

13/09/2016

Diego Souza Currículo

Muito maneiro! Me ajudou aqui também!
Responder Citar

13/09/2016

Devmedia Currículo

Muito legal, galera!
Responder Citar

13/09/2016

Diego Souza Currículo

Resolveu para você Samuel?
Responder Citar

13/09/2016

Samuel Lopes Currículo

Resolveu muito D+. Muito Obrigado!
Responder Citar

14/09/2016

Raphael Sobreira

O ideal não é fazer uma consulta no banco e retornar esse id? Pois em caso de múltiplos usuários utilizando o sistema poderia ocasionar em um id errado. Me corrija por favor se eu estiver errado..
Responder Citar

14/09/2016

Jetomaz

Quando temos muitos usuários inserindo dados no banco nem sempre o ultimo registro da tabela vai ser o id com o dados que nos inserimos, desta forma existe uma função no PHP que identifica a nossa conexão com o banco de forma unica e nos retorna o ID que foi gerado após o nosso insert é a mysql_insert_id.

Neste artigo do DevMedia o Rafael Silva explica como funciona.
http://www.devmedia.com.br/funcao-mysql-insert-id-recuperando-id-do-mysql-no-php/22243

Espero ter ajudado
Responder Citar

14/09/2016

Samuel Lopes Currículo

Mas a função acima não faz o mesmo que mysql_insert_id?
E está função não da para usar com pdo, ou da?
Responder Citar