コンテンツへスキップ
メニュー
この質問にフラグが付けられました
4 返信
31997 ビュー

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 )
アバター
破棄
著作者 最善の回答

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()
アバター
破棄
最善の回答
  • 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.


アバター
破棄
最善の回答

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

アバター
破棄
最善の回答

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

アバター
破棄
関連投稿 返信 ビュー 活動
0
9月 19
98
1
7月 17
4350
4
8月 16
8540
1
5月 16
5170
1
3月 16
5208