使用nodejs连接数据库mongoose

启动数据库:打开命令行,执行:net start mongodb、mongod
停止数据库:打开命令行,执行:net stop mongodb、mongod
先下载第三方模块mongoose :npm i mongoose
连接案例

const mongoose = require('mongoose')
const dburl = 'mongodb://localhost:27017/dbname'
mongoose.connect(dburl).then(()=>{
    console.log('连接成功');
    
}).catch(()=>{
    console.log('连接失败');
    
})

如果连接的数据库不存在,mongodb会在第一次插入数据的时候自动给我们创建

接下来=>创建集合·增(和MySQLmysql创建表一样)
创建集合主要分为俩步:

  • 创建集合规则
  • 应用集合规则,创建集合
    =>创建文档(相当于像表中插入数据)
    也分俩步:
  • new 集合() 创建文档实例
  • 调用save方法保存
    案例:
//创建集合规则
const usersname = new mongoose.Schema({
    name: { type: String, required: true },
    createTime: { type: Date, default: Date.now },
    sex: String,
    avatar: String,
    vip: Boolean,
})
//应用集合规则,创建集合
const User = mongoose.model('User',usersname,'User')
//创建文档实例
const y = new User({
    name:'哈哈哈哈',
    sex:'男',
    avatar:'lol',
    vip:true
})
//调用save方法保存
y.save()

(Schema 是什么
在 Mongoose 中,所有数据都由一个 Schema 开始创建。每一个 schema 都映射到一个 Mongodb 的集合(collection),并定义了该集合(collection)中的文档(document)的形式)

插入文件的另一种方式:可以使用集合构造函数的create方法来插入文档(推荐用这个),范例:

// [ 回调函数形式
User.create({
  name: 'ww',
  age: 19,
  isMarry: true
}, (err, user) => {
  cnosole.log(user)
})
// ] 回调函数形式

// [ Promise 形式
User.create({
  name: 'ww',
  age: 19,
  isMarry: true
}).then(doc => {
  console.log(doc)
})
// ] Promise 形式

// [ async await 形式 (推荐)
;(async () => {
  const ww = await User.create({
    name: 'zl',
    age: 59,
    isMarry: true
  })
  console.log(ww)
})()
// ] async await 形式

向数据库中导入数据:

  • 导入数据:mongoimport -d 数据库名称 -c 集合名称 --file 要导入的文件路径

=>删除数据操作
删除单个:

User.findOneAndDelete({ 条件 }).then...
  • 返回的是被删除的文档
  • 如果匹配到多条,删除第一条

删除多个:

User.deleteMany({}).then(result => console.log(result))

!!!一定不要忘记带条件,如果不带就是无条件删除该集合中所有数据

返回值是本次删除操作的信息对象,形如:{ n: 2, ok: 1, deletedCount: 2 }

  • n:表示匹配的条数
  • ok:表示本次删除操作是否执行成功,1:成功,0:失败
  • deletedCount:代表已经被删除的条数
  • 补充说明:当本次删除操作异常时,n和deletedCount就有可能不一致

=>修改数据
更新单个:

User.updateOne({name: '李四'}, {age: 120, name: '李狗蛋'}).then(result => console.log(result))

返回值是更新信息对象,形如:{ n: 1, nModified: 1, ok: 1 }

  • n:表示匹配的条数
  • nModified:表示已经更新的条数
  • ok:表示本次更新操作是否执行成功,1:成功,0:失败

更新多个:

User.updateMany({}, {age: 300}).then(result => console.log(result))

返回值和updateOne一样

=>查询数据

  • find():查找多个,返回的是数组,不管有多少个,返回的都是数组
  • findOne():查找一个,返回的是一个文档,如果匹配到多条,返回第一条
  • 共同点:它们都返回Promise对象,既然返回的是Promise对象,那么就推荐使用async/await关键字去调用,都可以带查询条件
  • 大于、小于:
User.find({ age: { $gt: 18, $lt: 40 } }).then(users => console.log(users))

包含:

User.find({ hobbies: { $in: ['敲代码'] } }).then(users => console.log(users))

筛选字段(_id会默认带上,如果不要在前面加个-):

User.find().select('name age').then(users => console.log(users))

排序:

// 升序
User.find().sort('age').then(users => console.log(users))
// 降序
User.find().sort('-age').then(users => console.log(users))

分页,跳过n条(skip),查n条(limit)

// 获取第4页的数据
User.find().skip(3 * 10).limit(10).then(users => console.log(users))
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,384评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,845评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,148评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,640评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,731评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,712评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,703评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,473评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,915评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,227评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,384评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,063评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,706评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,302评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,531评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,321评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,248评论 2 352

推荐阅读更多精彩内容