首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >pyDatalog:询问查询时,‘对象与查询的类不兼容’

pyDatalog:询问查询时,‘对象与查询的类不兼容’
EN

Stack Overflow用户
提问于 2013-08-27 21:56:58
回答 2查看 188关注 0票数 0

我正在开发一个使用pyDatalog查询sqlite数据库的程序。数据库中的键表为Event,其定义如下:

代码语言:javascript
复制
class Event(Base):
  __tablename__ = 'Event'

  id = Column('id', Integer, primary_key = True)
  eventType = Column('eventType', Integer, ForeignKey('EventType.id'))
  dateTime = Column('dateTime', DateTime)

  def __init__(self, eventType, dateTime):
    self.eventType = eventType
    self.dateTime = dateTime

  def __repr__(self):
    return "<Event(%d, %d, %s)>" % (self.id, self.eventType, self.dateTime)

然后,每个事件都会引用一个包含更多信息的详细信息表。

我希望能够对序列中的每个事件运行一系列查询。规则集是使用pyDatalog.load()从外部文件加载的

我遇到麻烦的部分是将对每个事件id的引用从python传递到datalog中。我一直收到错误消息"TypeError: Object与被查询的类不兼容“。

为了进行调试,我已经将规则简化为以下内容:

代码语言:javascript
复制
+ parent(bill, 'John Adams')
ancestor(X,Y) <= parent(X,Y)
ancestor(X,Y) <= parent(X,Z) & ancestor(Z,Y)

getEvent(EvtId, Evt) <= (Event.id[Evt] == EvtId)

请求查询的代码如下所示(属于一个更大的类):

代码语言:javascript
复制
def validateEvent(self, event):
  # validate the event instance 'event'
  print "validating event: %s" % (event)
  #query = 'parent(bill, X)'
  query = 'getEvent(' + str(event.id) + ', Evt)'
  print query
  print pyDatalog.ask(query)

如果我取消对"query='parent(bill,X)'“行的注释,它可以正常工作(它打印(bill,'John Adams')元组),但是对于"query =‘getEvent(...)”行,它在上面显示的最后一行仍然失败,并显示上面的错误。

有人知道这个错误是什么意思吗,以及如何正确地将对事件id的引用传递到pyDatalog中?

EN

回答 2

Stack Overflow用户

发布于 2013-08-28 05:01:01

此错误是在pyDatalog解析前缀谓词时生成的,例如(Event.idEvt == EvtId):这意味着Evt既不是Event的实例,也不是pyDatalog变量。

因此,我可以想象您在这个内联pyDatalog语句中得到的错误。

代码语言:javascript
复制
getEvent(EvtId, Evt) <= (Event.id[Evt] == EvtId)

我不能解释如何在这一行(使用pyDatalog 0.13)上得到错误:

代码语言:javascript
复制
print pyDatalog.ask(query)
票数 0
EN

Stack Overflow用户

发布于 2013-08-28 16:09:43

我已经设法通过重新阅读文档解决了这个问题。将pyDatalog功能添加到基类后,使用

代码语言:javascript
复制
Base = declarative_base(cls=pyDatalog.Mixin, metaclass=pyDatalog.sqlMetaMixin)

您还需要将会话与基类相关联,如下所示:

代码语言:javascript
复制
Session = sessionmaker(bind=engine)
session = Session()
Base.session = session

修复了这个问题之后,上面的例子就可以正常工作了。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/18467511

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档