0

所以我试图在 web2py 中使用 smart_query 来查找数据库中的特定值,但我能找到的唯一解释是在 web2py 书中,而且不是很清楚。书中的示例 GET 请求格式如下:

def GET(search):
    try:
        rows = db.smart_query([db.person, db.pet], search).select()
        return dict(result=rows)
    except:
        ...

我很困惑我会用什么值代替 db.person 和 db.pet。这是书上所说的:

The method db.smart_query takes two arguments:
    a list of field or table that should be allowed in the query
    a string containing the query expressed in natural language

我认为第一个值是我正在搜索的数据库,但是我不知道第二个值是什么。这本书听起来应该是我正在搜索的字符串,但我认为这就是变量搜索的目的。

有人可以帮我理解每个论点到底应该做什么吗?

4

1 回答 1

0

的第一个参数smart_query是 DALTable和/或Field对象Table的列表(列表中的对象将简单地扩展为包括表的所有字段)。此列表确定哪些字段可以包含在查询中。

第二个参数是查询本身,它可以包括字段名称和比较运算符(以及它们的自然语言对应物)以及“and”和“or”来表达连接和析取。要了解允许的内容,您可以在此处检查相关代码。

SQLFORM.grid高级搜索小部件生成最终由 解析的查询,smart_query因此为了更好地了解如何生成此类查询,请尝试创建一个测试SQLFORM.grid并在 UI 中使用搜索小部件来查看它生成的查询。

于 2017-07-07T13:46:04.453 回答