bulk update/delete entities of different kind in db.run_in_transaction

Posted by Ray Yun on Stack Overflow See other posts from Stack Overflow or by Ray Yun
Published on 2010-05-04T09:14:21Z Indexed on 2010/05/04 9:18 UTC
Read the original article Hit count: 228

Here goes pseudo code of bulk update/delete entities of different kind in single transaction. Note that Album and Song entities have AlbumGroup as root entity.

class AlbumGroup:
  pass
class Album:
  group = db.ReferenceProperty(reference_class=AlbumGroup,collection_name="albums")
class Song:
  album = db.ReferenceProperty(reference_class=Album,collection_name="songs")

def bulk_update_album_group(album_group):
  updated = [album_group]
  deleted = []
  for album in album_group.albums:
    updated.append(album)
    for song in album.songs:
      if song.is_updated:
        updated.append(song)        
      if song.is_deleted:
        deleted.append(song)
  db.put(updated)
  db.delete(deleted)

a = AlbumGroup.all().filter("...").get()

# bulk update/delete album group. for simplicity, album cannot be deleted.

db.run_in_transaction(bulk_update_album_group,a)

But I met a famous "Only Ancestor Queries in Transactions" error at the iterating reference properties like album.songs or album_group.albums. I guess ancestor() filter does not help because those entities are modified in memory.

  • Should I not to iterate reference property in transaction function and always provide them as function parameters like def bulk_update_album_group(updated,deleted): ???
  • Is there any good coding pattern for this situation?

© Stack Overflow or respective owner

Related posts about google-app-engine

Related posts about google-datastore