IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> 踩坑解决mongoose对已经存在的集合查询,查询条件不起限制作用的问题 -> 正文阅读

[大数据]踩坑解决mongoose对已经存在的集合查询,查询条件不起限制作用的问题

解决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);//最后一个参数是集合的名字
	
	// 模糊查询测试
	// var key = '桉油'
	// const reg = new RegExp(key, '桉油')
	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中添加几个属性。

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2021-12-24 18:32:57  更:2021-12-24 18:35:38 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年9日历 -2024/9/19 9:57:14-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码