How can I get the last insert id with doctrine 2 ORM? I didn't find this in the documentation of doctrine, is this even possible?
相关问题
- Views base64 encoded blob in HTML with PHP
- Laravel Option Select - Default Issue
- PHP Recursively File Folder Scan Sorted by Modific
- Can php detect if javascript is on or not?
- Using similar_text and strpos together
A bit late to answer the question. But,
If it's a MySQL database
should
$doctrine_record_object->id
work ifAUTO_INCREMENT
is defined in database and in your table definition.If you're not using entities but Native SQL as shown here then you might want to get the last inserted id as shown below:
For databases with sequences such as PostgreSQL please note that you can provide the sequence name as the first parameter of the
lastInsertId
method.For more information take a look at the code on GitHub here and here.
Calling flush() can potentially add lots of new entities, so there isnt really the notion of "lastInsertId". However Doctrine will populate the identity fields whenever one is generated, so accessing the id field after calling flush will always contain the ID of a newly "persisted" entity.
I had to use this after the flush to get the last insert id:
You can access the id after calling the persist method of the entity manager.
You do need to flush in order to get this id.
Syntax Error Fix: Added semi-colon after $entityManager->flush() is called.