web2py与谷歌应用引擎相当

时间:2010-12-22 18:05:11

标签: google-app-engine web2py bigtable

有没有办法使用应用引擎BigTable数据库生成类似于likecontainsstartswith运算符的查询?

所以我可以做类似的事情:

db(db.some_table.like('someting')).select()

使用web2py中的app引擎。

1 个答案:

答案 0 :(得分:7)

App引擎不支持全文搜索,所以答案很短。

使用web2py可以创建一个带有要搜索的关键字列表的计算字段。

 def tokenize(r): return [x.lower() for x in re.compile('\w+').findall(r.title)]

 db.define_table('data',
    Field('title'),
    Field('keywords','list:string',compute=tokenize,writable=False,readable=False))

在GAE上,关键字字段是StringListProperty()。

然后,您不是在标题中搜索,而是搜索关键字:

 rows = db(db.data.keywords.contains(my_keyword.lower())).select()

这适用于GAE,非常有效。现在的问题是,由于GAE“爆炸”索引问题,您不会习惯将它组合在复杂查询中。例如,您有N个关键字,并希望搜索两个关键字:

 rows = db(db.data.keywords.contains(my_keyword1.lower())&
           db.data.keywords.contains(my_keyword2.lower())).select()

您的索引大小变为N ^ 2。因此,您必须在本地执行更复杂的查询:

 query2=lambda r: my_keyword1.lower() in r.keywords
 rows = db(db.data.keywords.contains(my_keyword1.lower())).select().find(query2)

所有这些也适用于GAE而非GAE。它是便携式的。