首页
学习
活动
专区
圈层
工具
发布
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    React、TypeScript、NodeJS 和 MongoDB 搭建 Todo App

    在本教程中,我们将在服务器和客户端使用 TypeScript、React、NodeJS、Express 和 MongoDB 从头开始构建一个 Todo 应用程序。 我们从设计 API 开始。...用 NodeJS, Express, MongoDB 和 TypeScript 设计 API 启动 创建 Todo 类型 创建 Todo 模块 创建 API 控制器 获取、新增、更新和删除 Todo 创建...在终端上运行这个命令,创建一个新的 NodeJS 应用程序: yarn init 它会询问几个问题,然后初始化应用程序。你可以通过向命令中添加 -y 标志来跳过。...控制器、类型和路由也在它们各自以它们命名的的文件夹中。 现在,我们需要配置 tsconfig.json,使编译器运行我们的首选项。...最后,我们使用 TypeScript、React、NodeJs、Express 和 MongoDB 完成了一个 Todo 应用程序的构建。 附上源代码。 谢谢阅读!

    19.2K30

    Nodejs和Mongodb的连接器Mongoose

    Mongoose是MongoDB的一个对象模型工具,是基于node-mongodb-native开发的MongoDB nodejs驱动,可以在异步的环境下执行。...Mongoose,因为封装了对MongoDB对文档操作的常用处理方法,让NodeJS操作Mongodb数据库变得easy、easy、So easy!...,后面我们会学习如何创建文档并插入内容。 在MongoDB中,多个Document可以组成Collection(以下简称集合),多个集合又可以组成数据库。...文档 —— 是MongoDB的核心概念,是键值对的一个有序集,在JavaScript里文档被表示成对象。同时它也是MongoDB中数据的基本单元,非常类似于关系型数据库管理系统中的行,但更具表现力。...集合 —— 由一组文档组成,如果将MongoDB中的一个文档比喻成关系型数据库中的一行,那么一个集合就相当于一张表。

    8K41

    在nodejs中创建child process

    在nodejs中创建child process 简介 nodejs的main event loop是单线程的,nodejs本身也维护着Worker Pool用来处理一些耗时的操作,我们还可以通过使用nodejs...在child_process模块中,可以同步创建进程也可以异步创建进程。同步创建方式只是在异步创建的方法后面加上Sync。 创建出来的进程用ChildProcess类来表示。...子进程将会在message事件中,将该handle传递给Callback函数,从而可以在子进程中进行处理。...exec和execFile是以新的进程执行新的命令,并且带有callback。他们的区别就在于在windows的环境中,如果要执行.bat或者.cmd文件,没有shell终端是执行不了的。...我们看一个在windows中使用spawn和exec的例子: // 仅在 Windows 上。

    4.9K30

    在nodejs中事件循环分析

    在上一篇文章在chromev8中的JavaScript事件循环分析中分析到,在chrome中的js引擎是通过执行栈和事件队列的形式来完成js的异步操作。...值得注意的是,poll阶段在执行poll queue中的回调时实际上不会无限的执行下去。...运行环境中的各种复杂的情况会导致在同步队列里两个方法的顺序随机决定。但是,在一种情况下可以准确判断两个方法回调的执行顺序,那就是在一个I/O事件的回调中。...总结 相比在chrome中执行js代码,在node中的执行更加纯粹一些,异步执行的内容是通过加入队列的形式来实现效果,脚本代码的执行周期也很干净,timer-I/O callbacks-idle, prepare-poll-check-close...the-nodejs-event-loop https://nodejs.org/en/docs/guides/event-loop-timers-and-nexttick/

    5.8K00

    在NodeJS中玩转Protocol Buffer

    二进制协议对于电脑来说更容易解析,在解析速度上是http这样的文本协议不可比拟的。 有tcp和udp两种选择,在一些场景下,udp传输的效率会更高。...在NodeJS中实践Protocol Buffer协议 选择支持protobuf的NodeJS第三方模块 protobuf.js Google protobuf js protocol-buffers...根据star数和文档完善程度两方面综合考虑,我们决定选择protobuf.js一个栗子 我打算使用 Protobuf 和NodeJS开发一个十分简单的例子程序。...XML 需要从文件中读取出字符串,再转换为 XML 文档对象结构模型。之后,再从 XML 文档对象结构模型中读取指定节点的字符串,最后再将这个字符串转换成指定类型的变量。...参考文档 Google Protocol Buffer 的使用和原理 Protobuf 语法指南

    3.9K10

    MongoDB查询(数组、内嵌文档和$where)

    如果是精确匹配的方式,MongoDB的处理方式是完全相同的匹配,即顺序与数量都要一致,上述中第一条文档和查询条件的顺序不一致,第三条文档比查询条件文档多一个元素,都没有被匹配成功!...如果实际中,在查询某个数组时,需要按其长度范围进行查询,这里推荐的做法是:在这个文档中额外增加一个“size”键,专门记录其中数组的大小,在对数组进行"$push"操作同时,将这个“size”键值加1。...但这个方式和修改器"$addToSet"没法配合使用,因为你无法判断这个元素是否添加到了数组中!...我们可以看出,使用"$where"其实就是写了一个javascript函数,MongoDB在查询时,会将每个文档转换成一个javascript对象,然后扔到这个函数中去执行,通过返回结果来判断其是否匹配...在实际使用中,尽量避免使用”$where" 条件操作符,因为其性能很差!在执行过程中,需要把每个档案转化为javascript对象!

    6.8K20

    在NodeJS中玩转Protocol Buffer

    二进制协议对于电脑来说更容易解析,在解析速度上是http这样的文本协议不可比拟的。 有tcp和udp两种选择,在一些场景下,udp传输的效率会更高。...在NodeJS中实践Protocol Buffer协议 选择支持protobuf的NodeJS第三方模块 protobuf.js ? Google protobuf js ?...根据star数和文档完善程度两方面综合考虑,我们决定选择protobuf.js一个栗子 ? 我打算使用 Protobuf 和NodeJS开发一个十分简单的例子程序。 该程序由两部分组成。...XML 需要从文件中读取出字符串,再转换为 XML 文档对象结构模型。之后,再从 XML 文档对象结构模型中读取指定节点的字符串,最后再将这个字符串转换成指定类型的变量。...参考文档 Google Protocol Buffer 的使用和原理 Protobuf 语法指南

    4.2K90

    MongoDB 数组在mongodb 中存在的意义

    在MOGNODB 的文档设计和存储中,存在两个部分 1 嵌套 2 数组,所以如果想设计好一个MONGODB 在理解业务,读写比例,查询方式后,就需要介入到更深层次的理解嵌套的查询方式,嵌套多层后的性能问题...MONGODB 中的数组是属于同类型数据的元素集合,每个数组中的元素代表这个数组中同样属性的不同值,其实我们可以理解为,在一个JSON 中,有行和行列集合的存在,本身JSON可以通过数组的方式,在一个平面里面表达一个列的集合...相当于对每个ducument 中的数据进行元素的计算,这样就可以得到每个数据库的被打分的个数, 而第二组设计则无法进行分析的和统计。...数组在一部分应用设计中适合进行数据查询,而另外一点就是数组的缺点,就是对数组中的数据进行更新,尤其是高频次,大量的数据更新和数据的添加。 下面就是针对ORACLE 添加在数组中添加一个数据元素。...数组在MONGODB 中存在的意义很大,在很多设计中都可以通过数组的使用降低查询的复杂度和降低建立索引的SIZE。

    6.6K20

    在Docker中安装MongoDB

    “docker run -p 27017:27017 -v /data/mongo:/data/db --name mongodb -d mongo” 在上面的命令中,几个命令参数的详细解释如下: -p...外部可以直接通过 宿主机 ip:27017 访问到 mongo 的服务 -v 为设置容器的挂载目录,这里是将本机的“/data/mongo”目录挂载到容器中的/data/db中,作为 mongodb 的存储目录...studiot 3T下载地址:https://studio3t.com/download/ 5.创建mongo用户 可以看到一个空的mongo数据库,有一个不太完美的地方在于我们的mongo没有任何账户密码,在裸奔...指定验证启动mongo容器:docker run -p 27017:27017 -v /data/mongo:/data/db --name mongodb -d mongo --auth 也就是在之前的启动命令后面加上...--auth:需要密码才能访问容器服务 此时强行访问,可以看到提示,没有授权 这里我们在连接的地方指定一下账户密码 再来查询,已经正确查询出来之前添加的用户信息 7.创建一个业务数据库和对应的读写账户

    8.7K11

    MongoDB使用update和save方法来更新集合中的文档

    MongoDB 使用 update() 和 save() 方法来更新集合中的文档。接下来让我们详细来看下两个函数的应用及其区别。...update : update的对象和一些更新的操作符(如$,$inc...)等,也可以理解为sql update查询内set后面的 upsert : 可选,这个参数的意思是,如果不存在update的记录...实例 我们在集合 col 中插入如下数据: >db.col.insert({ title: 'MongoDB 教程', description: 'MongoDB 是一个 Nosql...方法通过传入的文档来替换已有文档,_id 主键存在就更新,不存在就插入。...实例 以下实例中我们替换了 _id 为 56064f89ade2f21f36b03136 的文档数据: >db.col.save({     "_id" : ObjectId("56064f89ade2f21f36b03136

    5.1K00

    在MongoDB中实现聚合函数

    这种数据库有多种不同的类型,比如文档结构存储、键值结构存储、图结构、对象数据库等等。 我们在本文中使用的NoSQL是MongoDB,它是一种开源的文档数据库系统,开发语言为C++。...这篇文章描述了在MongoDB存储的文档上使用MapReduce来实现通用的聚合函数,如sum、average、max、min、variance和standard deviation;聚合的典型应用包括销售数据的业务报表...的实现 我们提供了一个查询的样例集,这些查询使用聚合函数、过滤条件和分组从句,及其等效的MapReduce实现,即MongoDB实现SQL中GROUP BY的等效方式。...在MongoDB存储的文档上执行聚合操作非常有用,这种方式的一个限制是聚合函数(比如,SUM、AVG、MIN、MAX)需要通过mapper和reducer函数来定制化实现。...在MongoDB中,更复杂的聚合函数也可以通过使用MapReduce功能实现。

    5.3K70

    Wiredtiger 在MONGODB 中的疑问

    MongoDB 中也有类似MYSQL 的数据库引擎的插件化的概念,虽然MYSQL 被ORACLE 搞得现在对这个数据库的引擎认知都存在于INNODB,但实际上MYSQL 在之前的存储引擎还是丰富多彩的,...实际上在MONGODB 中,快速的返回结果其实cursors的功劳不小,首先不要用传统的数据库思维来去想MONGODB,他返回的数据结果集,要比传统的数据结果集大的多,(言外之意就是MONGODB 处理的数据量...中,删除操作应该好好考虑如何处理。...和 oplog 在记录日志的物理顺序是否一致。...这也是由于两者在对MONGODB 数据库在功能上的主责不同。一个是负责系统crash后的恢复,自然以结果为ORDER ,而OPLOG 则是要对 REPL负责,所以操作的顺序是ORDER。

    2.5K20

    信息检索中“禁止文档”的过滤新方法

    信息检索中“禁止文档”的过滤内容所有者投入大量精力来消除可能对客户产生不利影响的不良内容。不良内容可以采取多种形式,例如假新闻、付费评论、垃圾邮件、攻击性语言等。...然而,过滤算法容易出现两种类型的错误:(1) 误报(即过滤非 f-docs)和 (2) 漏报(即在结果中包含 f-docs)。通常,排序质量和过滤精度是独立衡量的。...然而,过滤后保留在排序列表中的 f-docs 数量及其排名位置会严重影响排序分数和过滤分数。因此,在做出过滤决策时,评估系统的排序质量是可取的。...在我们的论文中,我们分析了可用于衡量搜索结果排序和过滤质量的指标类型。...虽然我们的 LTRF 模型在排序和过滤方面取得了成功,但检索列表中 f-docs 的数量仍然过高。改进 LTRF 模型是一个开放的挑战,我们希望我们的工作能鼓励其他研究人员来解决它。

    14900

    信息检索中过滤禁止文档的新方法

    在某国际学术会议上,某机构的智能购物研究团队发表了一篇关于存在禁止文档时的信息检索(IR)论文。重点在于同时优化两个需求:检索与客户请求相关的内容,并过滤掉禁止文档。...过滤算法的挑战过滤算法容易出现两类错误:(1)误报(即过滤非禁止文档)和(2)漏报(即在结果中包含禁止文档)。通常,排名质量和过滤准确性是独立测量的。...然而,过滤后排名列表中剩余的禁止文档数量及其排名位置严重影响排名分数和过滤分数。因此,需要在做出过滤决策时评估系统的排名质量。...nDCG分数对各个列表项的分数求和,因此包含禁止文档的排名列表的分数将反映列表中禁止文档的数量、它们在排名中的相对位置及其禁止程度。...虽然LTRF模型在排名和过滤方面取得了成功,但检索列表中禁止文档的数量仍然过高。改进LTRF模型是一个开放的挑战,希望工作能鼓励其他研究人员解决它。

    15210

    MongoDB聚合索引在实际开发中的应用场景-嵌套文档的聚合查询

    MongoDB 支持嵌套文档,即一个文档中可以包含另一个文档作为其字段。在聚合查询中,可以通过 $unwind 操作将嵌套文档展开,从而进行更灵活的查询和统计。...例如,假设我们有一个包含用户信息和订单信息的集合 users,每个文档包含以下字段:user_id:用户IDname:用户名orders:订单列表,每个订单包含以下字段:order_id:订单IDorder_date...:订单日期total_amount:订单总金额我们可以使用聚合索引和聚合框架来查询每个用户最近的订单信息。..."$_id", name: 1, order_id: 1, order_date: 1, total_amount: 1 } }])上面的聚合操作将嵌套文档展开后按照用户...ID和订单日期进行排序,然后通过 $group 操作获取每个用户最近的订单信息,并通过 $project 操作排除 _id 字段并重命名 user_id 字段,得到最终的结果。

    6.6K20

    在 Nodejs 中 ES Modules 使用入门讲解

    删除标志也是将 ESM 变为稳定性而迈出的重要一步,根据 Nodejs 官方的发布说明,有望在今年下半年(10 月左右)删除 Nodejs 12 中的警告,届时 Node 14 将会成为 LTS。...导出 export 用于对外输出模块,可导出常量、函数、文件等,相当于定义了对外的接口,两种导出方式: export: 使用 export 方式导出的,导入时要加上 {} 需预先知道要加载的变量名,在一个文件中可以使用多次...as 别名导入:在导入时可以重命名在 export 中定义的接口。 单个或多个导入:根据需要导入 export 定一个的一个或多个接口。 import { add } from '....v14.3.0 发布支持顶级 Await 和 REPL 增强功能。...', 2000); export default function() { return 'this is a module'; } 在 index.js 中可以像如下形式进行动态导入: console.log

    3.6K20
    领券