gpt4 book ai didi

python - 如何在 python couchdb 中过滤更改

转载 作者:太空宇宙 更新时间:2023-11-03 15:48:55 25 4
gpt4 key购买 nike

我正在使用 python-couchdb 库通过连续源监听数据库中的更改。我想应用一个过滤器,只提供那些键 read 等于 true 的文档。

通过正常的 HTTP GET 请求,我得到了想要的结果。但我无法弄清楚如何通过couchdb-python库来做到这一点。这是我编写的自定义过滤器:

def read_true_filter():
return """function(doc, req) {
if(doc.read === true) {
return true;
}
return false;
}
"""

以下是我尝试聆听变化的方式:

db_changes = db.changes(
feed='continuous',
include_docs=True,
heartbeat=1000,
since=last_seq_id,
filter=read_true_filter
)

但这给了我错误:

Traceback (most recent call last):
File "../src/couch_pull_pipeline.py", line 87, in <module>
db_changes = db.changes(
File "/Users/sanyam/venv/lib/python3.5/site-packages/couchdb/client.py", line 1027, in _changes
_, _, data = self.resource.get('_changes', **opts)
File "/Users/sanyam/venv/lib/python3.5/site-packages/couchdb/http.py", line 546, in get
return self._request('GET', path, headers=headers, **params)
File "/Users/sanyam/venv/lib/python3.5/site-packages/couchdb/http.py", line 581, in _request
credentials=self.credentials)
File "/Users/sanyam/venv/lib/python3.5/site-packages/couchdb/http.py", line 421, in request
raise ServerError((status, error))
couchdb.http.ServerError: (400, ('bad_request', 'filter parameter must be of the form `designname/filtername`'))

在请求中添加 designname 很简单,但我找不到使用 couchdb 客户端执行此操作的等效项。

是否可以使用 python 库,或者我应该使用简单的 HTTP 请求,或者更好的想法是在 couchdb 服务器本身上安装过滤器? (根据我到目前为止所读到的内容,由于性能原因,在 couchdb 中使用该过滤器并不是一个好主意。)

有人可以告诉我我做错了什么/如何解决吗?

最佳答案

我明白了这一点。我在数据库中制作了一个设计文档,我想在其中过滤内容,例如:

{
"_id": "_design/read_validator",
"_rev": "1-bd5fb337899a0eaf485b2112b439cc30",
"filters": {
"read_only_true": "function(doc, req) {if(doc.read === true) {return true;}return false;}"
}
}

这里read_validator是设计文档,其中包括返回docs的过滤器,其中read属性设置为true。在 couchdb python 客户端中,在获得连续馈送的同时,我将过滤器资源路径作为字符串 design_document_name/filter_name 给出,其中 design_document_name 是在数据库中创建的设计文档的名称(在本例中为 read_validator),filter_name 是过滤器的名称(在本例中为 read_only_true)。所以,连接是这样的:

db_changes = db.changes(
feed='continuous',
include_docs=True,
heartbeat=1000,
since=last_seq_id,
filter="read_validator/read_only_true"
)

这里db_changes将是一个连续的提要生成器,通过它可以通过迭代获取所有文档,其中read键等于true .

关于python - 如何在 python couchdb 中过滤更改,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41503606/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com