Overslaan naar inhoud
Menu
Je moet geregistreerd zijn om te kunnen communiceren met de community.
Deze vraag is gerapporteerd
4 Antwoorden
31548 Weergaven

I have a button that when clicked imports records from an external source. It then loops through the records and uses .create to create the new records on the model in the database from the imported records. However it doesn't seem to commit them until its completed the loop of all imported records. Is there anyway to force the commit after each iteration?

object.create( template )
Avatar
Annuleer
Auteur Beste antwoord

While Sah's answer appears like it should work I did some more research and found a much simpler answer for my scenario.

All I had to do was use the current environment variable and cursor and run commit(). See below.

self.env.cr.commit()
Avatar
Annuleer
Beste antwoord
  • self.env.cr.commit() commits the transaction's buffered write operations.
  • self.env.cr.savepoint() sets a transaction savepoint to rollback to.
  • self.env.cr.rollback() cancels the transaction's write operations since the last commit, or all if no commit was done.


Avatar
Annuleer
Beste antwoord

commit the code by 

self.env.cr.commit()

If you have too many records in for loop then commit every 100 or 1000th record

count += 1
if count == 100:
_logger.info('100 records created ')
self.env.cr.commit()
count = 0

Avatar
Annuleer
Beste antwoord

add this to py file
#top of the file
from odoo import api, fields, models, _, modules
from odoo.http import request
#before for loop
r = modules.registry.RegistryManager.get(dbname)
cr = r.cursor()
#inside loop
cr.commit()
#make sure you close cr at the end of the function scope
cr.close()

Let me know if there is any error with your log file

Avatar
Annuleer
Gerelateerde posts Antwoorden Weergaven Activiteit
0
sep. 19
98
1
jul. 17
4075
4
aug. 16
8240
1
mei 16
4896
1
mrt. 16
4925