解决mongoose对已经存在的集合查询,查询条件不起限制作用的问题
router.post('/api/getDataByName',function(req,res,next) {
var medicinename = req.body.medicinename;
var medicinecapital = req.body.medicinecapital
var medicineid = req.body.medicineid
var mongoose = require('mongoose');
const DB_URL="mongodb://localhost:27017/中医药数据库"
mongoose.connect(DB_URL)
var date = new Date()
const schema = mongoose.Schema();
const collection = mongoose.model(date,schema,medicinecapital);
collection.findOne({'药名': '不灰木'}).then(function(info) {
console.log(info)
})
目的是查询药名为不灰木的数据,该数据存在数据库中但是执行后发现查询返回的值是该集合中的第一条数据。限制条件不起任何作用。
若使用find()函数进行查询,限制条件不变但是却返回了该集合中的所有数据,限制条件同样不起任何作用。
解决方案如下:
定义schema的时候不能定义为空值,下面的这种写法虽然没有报错,但是无法通过其他的属性查询数据,只能使用_id查询数据才会发挥作用。
const schema = mongoose.Schema({});
经过实验,需要在定义的时候添加一些属性(一个或者多个都行),因为该集合中的数据都有的一个属性是”药名“,因此我便把”药名“定义,至于其他属性是否一定也要定义,在这里,你定义一个属性,如果一条数据里面有其他多个属性也是能正常查询的,只要有一个就行,没必要都定义一遍。
修改后如下:
const schema = new mongoose.Schema({
'药名':{
type: String,
required: true
}
});
修改后再通过”药名“进行查询就可以咯!!!
var medicinename = req.body.medicinename;
var medicinecapital = req.body.medicinecapital
var medicineid = req.body.medicineid
var date = new Date()
const collection = mongoose.model(date,schema,medicinecapital);
collection.findOne({
药名: "伯乐树"
}).then(function(info) {
console.log(info)
})
建议大家使用已存在的集合时最好也要手动在schema中添加几个属性。
|