用Python的Storm制作ORM

-1 投票
1 回答
1462 浏览
提问于 2025-04-15 16:16

这个问题是基于这个讨论帖,因为我发现Storm让我可以重用我的SQL架构。

在Storm中,如何解决以下错误信息?

这段代码是基于Jason的回答和Storm的手册。

import os, pg, sys, re, psycopg2, storm
from storm.locals import *
from storm import *

class Courses():
    subject = Unicode()

database = create_database("postgres://naa:123@localhost:5432/tk")
store = Store(database)

course = Courses()
course.subject = 'abcd'
store.add(course)

它给你返回了

Traceback (most recent call last):                                            
  File "<stdin>", line 13, in <module>
  File "/usr/lib/python2.6/dist-packages/storm/store.py", line 245, in add
    obj_info = get_obj_info(obj)
  File "/usr/lib/python2.6/dist-packages/storm/info.py", line 40, in get_obj_info 
    obj_info = ObjectInfo(obj)
  File "/usr/lib/python2.6/dist-packages/storm/info.py", line 162, in __init__
    self.cls_info = get_cls_info(type(obj))
  File "/usr/lib/python2.6/dist-packages/storm/info.py", line 51, in get_cls_info
    cls.__storm_class_info__ = ClassInfo(cls)
  File "/usr/lib/python2.6/dist-packages/storm/info.py", line 69, in __init__
    raise ClassInfoError("%s.__storm_table__ missing" % repr(cls))
storm.exceptions.ClassInfoError: <type 'instance'>.__storm_table__ missing

这让我觉得可能缺少某个模块。在Storm中没有名为instance的模块。

1 个回答

4

我就不说连接的细节了,因为我对Postgres不是很熟悉。

from storm.locals import *

class Courses(object):
    __storm_table__ = 'courses'
    pkey = Int(primary=True)
    course_nro = Unicode()

course = Courses()
course.course_nro = 'abcd'
store.add(course)
store.commit()

当然,如果你想在一行里完成构造和初始化,可以使用pysistenceexpandos

from storm.locals import *
from pysistence import Expando

class Courses(Expando):
    __storm_table__ = 'courses'
    pkey = Int(primary=True)
    course_nro = Unicode()

course = Courses(course_nro='abcd')
store.add(course)
store.commit()

撰写回答