我有以下pouchdb查询,我在这里看不到任何问题,但是会引发错误Cannot sort on field(s) "createTime" when using the default index
。关于如何解决这个问题的任何想法?每次查询时都必须执行createIndex
吗?
let getData = () => {
let re = new RegExp('2017-09-06')
db.createIndex({
index: {
fields: ['createTime'],
}
}).then((result)=>{
return db.find({
selector: {createTime: {$regex:re}},
fields: ['createTime'],
sort: ['createTime']
}).then(function (result) {
// handle result
debugger
}).catch(function (err) {
console.log(err)
debugger
});
})
}
最佳答案
我真的不知道为什么,但是用'gt:null'添加选择器似乎可以解决我的问题。我正在使用pouchDB v 6.4.1。你可以试试这些吗?
db.createIndex({
index: {
fields: ['createTime'],
}
}).then((result) => {
return db.find({
selector: {
$and: [
{ createTime: {'$gt': null} },
{ createTime: {'$regex': new RegExp('2017-09-06')}} }
]
},
fields: ['createTime'],
sort: ['createTime']
}
);