python - 使用 pyDAL 进行多字段过滤

标签 python pydal

编辑:我想我解决了它,我添加了答案。

我正在使用 python 编写 REST API, Falcon 作为 web 框架,pyDAL 作为 MySQL 的 DAL。

我想使用在 get 请求的查询字符串中获取的字段进行过滤(where 语句)。

例如我收到以下获取请求:

http://127.0.0.1:5000/users?firstName=FirstN&id=1

我希望 pyDAL 将查询生成以下 SQL:

SELECT * FROM users WHERE firstName = 'FirstN' AND id = '1'

我找不到可以做到这一点的东西,因为 pyDAL 想要接收类似这样的东西:

self.db((self.db.users.id == 1) & (self.db.users.firstName == 'FirstN')).select()

但是我不能指定字段,因为我不知道我要过滤哪个字段,这就是我写这个的原因:

def on_get(self, req, resp):
    if req.query_string is not '':
        input = req.query_string
        sql = 'SELECT * FROM users WHERE '
        sql += ' AND '.join(['{col} = \'{value}\''.format(col=item.split('=')[0], value=item.split('=')[1]) for item in input.split('&')])
        resp.body = json.dumps(self.db.executesql(sql, as_dict=True))
    else:
        resp.body = json.dumps(self.db(self.db.users).select().as_dict())

但我认为这很糟糕,应该是一个更好的原因。

最佳答案

我创建了一个接收 Table 对象和查询字符串的函数,并执行以下操作:

def generate_filter(table, query_string):
    statement = True
    for field in query_string.split('&'):
        field = field.split('=')
        statement &= getattr(table, field[0]) == field[1]
    return statement

比我执行:

self.db(generate_filter(self.db.users, req.query_string)).select().as_dict()

关于python - 使用 pyDAL 进行多字段过滤,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38836394/

相关文章:

python - 理解 python 线程错误

python - pandas python 中的嵌套循环

python - 使用 SimpleImputer 后 Dataframe 变成 numpy 数组。我希望它返回一个 dataframe

python - 将数据从 LabView 发送到 Python 并返回

python - 如何在Python中读取文件并将其转换为二进制图像

count - 在 pyDAL 中创建 HAVING COUNT(column) > 2 子句

python - 检索记录 MySql 数据库 PyDAL