Python-Storm Orm многие ко многим - PullRequest
       28

Python-Storm Orm многие ко многим

1 голос
/ 11 декабря 2011

Я использую python-storm в качестве orm. Набор ссылок «многие ко многим» вызывает у меня головную боль: (

Это соответствующие объекты:

class Author(object):
    __storm_table__ = "author"
    id = Int(primary=True)
    name = Unicode()
    institution_id = Int()
    institution = Reference(institution_id, Institution.id)

    def __init__(self, name):
        self.name = name


class Paper(object):
    __storm_table__ = "paper"
    id = Int(primary=True)
    name = Unicode()
    conference_id = Int()
    conference = Reference(conference_id, Conference.id)

    def __init__(self, name):
        self.name = name

class AuthorPapers(object):
    __storm_table__ = "authorpapers"
    __storm_primary__ = "author_id", "paper_id"
    author_id = Int()
    paper_id = Int()

Соответствующая таблица sqlite выглядит следующим образом

store.execute("CREATE TABLE if not exists author (id INTEGER PRIMARY KEY, name VARCHAR, institution_id INTEGER, FOREIGN KEY (institution_id) REFERENCES institution(id))")

store.execute("CREATE TABLE if not exists paper (id INTEGER PRIMARY KEY, name VARCHAR, conference_id INTEGER, FOREIGN KEY (conference_id) REFERENCES conference(id))")

store.execute("CREATE TABLE if not exists authorpapers (author_id INTEGER, paper_id INTEGER, PRIMARY KEY (author_id, paper_id))")

Теперь скажите, если у вас есть два автора, сотрудничавших на бумаге

a = Author(u"Steve Rogers")
b = Author(u"Captain America")

и бумага

p6 = Paper(u"Bunga Bunga")

Так что теперь я хочу связать обоих авторов с помощью

Author.papers = ReferenceSet(Author.id, AuthorPapers.author_id, Paper.id, AuthorPapers.paper_id)

и делает это

a.papers.add(p6)
b.papers.add(p6)

Это, кстати, говорит, что он должен работать в учебнике шторма ... но я получаю

  File "/usr/lib64/python2.7/site-packages/storm/references.py", line 376, in add
    self._relation2.link(remote, link, True)
  File "/usr/lib64/python2.7/site-packages/storm/references.py", line 624, in link
    pairs = zip(self._get_local_columns(local.__class__),
  File "/usr/lib64/python2.7/site-packages/storm/references.py", line 870, in _get_local_columns
    for prop in self.local_key)
  File "/usr/lib64/python2.7/site-packages/storm/references.py", line 870, in <genexpr>
    for prop in self.local_key)
  File "/usr/lib64/python2.7/site-packages/storm/properties.py", line 53, in __get__
    return self._get_column(cls)
  File "/usr/lib64/python2.7/site-packages/storm/properties.py", line 97, in _get_column
    attr = self._detect_attr_name(cls)
  File "/usr/lib64/python2.7/site-packages/storm/properties.py", line 82, in _detect_attr_name
    raise RuntimeError("Property used in an unknown class")
RuntimeError: Property used in an unknown class

И сейчас я не могу понять это.

1 Ответ

4 голосов
/ 11 декабря 2011

Я не очень знаком с storm, но, глядя на пример документации , похоже, это просто проблема, связанная с порядком, в котором передаются аргументы ReferenceSet. Я пытался использовать это:

Author.papers = ReferenceSet(Author.id, AuthorPapers.author_id, AuthorPapers.paper_id, Paper.id)

вместо этого:

Author.papers = ReferenceSet(Author.id, AuthorPapers.author_id, Paper.id, AuthorPapers.paper_id)

и исключений не было.

...