:pig_nose: node中使用MongoDB的实例
依赖于mongoose模块进行一系列的增删改查操作
1. 连接数据库
主要使用到connect函数,函数中还有一系列对应的操作可以参加官方文档进行配置
https://mongoosejs.com/docs/connections.html
:warning:一开始我一直报错
是由于我要连接的是test1数据库,但是我用账号不是这个数据库的的所有者所以认证失败了
{ MongoNetworkError: failed to connect to server [localhost:27017] on first connect [MongoError: Authentication failed.]
2. 设计集合的表结构
使用monoose中Schema实例对象进行集合结构的定义
3.封装成对应集合对象
使用model函数将上一步设计好的集合结构进行封装成对应的集合对象,得到集合对象之后就可以对集合对象中的数据进行操作
:warning:在model函数中第一个参数是设置集合的名字的通常有默认的操作
参数以大写字母开头,model函数会将对应的参数改成小写字母开头并且以复数结尾
Student ------>>>>> students
4.往集合对象中添加文档数据
利用上一步module中建立好的集合对象之后,使用new方法定义集合中新的文档对象,文档对象中的内容需要按照之前Schema中定义好的表的结构进行定义
5.文档对象的保存
使用回调函数监视数据是否插入成功
当文档插入成功之后,对应声明的集合也就产生在数据库中了
6.查询操作
借助model中封装好的集合对象,定义sql查询语句,调用find或者findOne函数进行查询操作
不知道是不是,每次都得使用Schema去定义好集合结构再去进行查询操作
https://mongoosejs.com/docs/api/query.html
7.删除操作
删除操作与查询操作不一样,贪婪的将符合条件的文档进行删除;而查询操作只会将查询到的其中一条给输出
8.更新操作
同样的使用集合对象的where函数构造查询语句,调用update方法只更新一个,而updateMany方法则是更新所有符合的文档;函数中传入需要更新的字段内容 **{$set{字段:更新的内容}}
代码进行模块化
:sa:1.数据库配置信息
:heavy_multiplication_x: 2.定义数据库集合对象
:bullettrain_front: 3.操作对应的集合
现在students变量就代表了数据库中students集合,然后查询MongoDB官方文档进行增删改查就可以了
结合数据库进行实例操作
1.数据库的查询操作
这里由于Mongodb数据库中文档的id信息由于分布式存储的原因,不太方便辨别;在数据展示时可以使用art-template模板中的 $index+1进行id信息的展示
数据库的配置信息文件
所有数据库集合collection结构化的文件
针对student封装好的增删改查的业务函数
封装好的插入函数
查询所有数据
查询单个数据
更新数据
删除数据
Last updated