用js代码操作数据库mogodb

1.创建相关的数据库集合

在 链接数据库的 命令行终端运行  

>use sh2001                            //创建库

switched to db sh2001

>db.createCollection('products')       //创建所需聚合集

{ "ok" : 1 }

>db.createCollection('users')

{ "ok" : 1 }

db.createCollection('carts')

{ "ok" : 1 }

db.createCollection('orders')

{ "ok" : 1 }

db.createCollection('banners')

{ "ok" : 1 }

db.createCollection('messages')

{ "ok" : 1 }

db.createCollection('activitys')

{ "ok" : 1 }

2.使用mongoose

用node安装cnpm i mongoose -S

2.1 链接数据库

const mongoose = require('mongoose');                  //导入mongise模块
 ​
const DB_URL = "mongodb://127.0.0.1:27017/sh2001"      //存放数据库的链接地址
// 后面两个不需要记忆,会自动提示
mongoose.connect(DB_URL, { useNewUrlParser: true, useUnifiedTopology: true });   //连接数据库
//根据不同的结果响应不同的数据
mongoose.connection.on('connected', () => {
  console.log('数据库链接成功')
})
​
mongoose.connection.on('disconnected', () => {
  console.log('数据库链接失败')
})
​
mongoose.connection.on('error', () => {
  console.log('数据库链接异常')
})
​
module.exports = mongoose;    //导出数据库连接的模板

 

2.创建数据库集合

     

新建文件夹和文件collection/Product.js

const mongoose = require('./../db');导入刚刚建立的db连接数据库的操作
​
const Schema = mongoose.Schema;    //创建模板并规定模板的有关类型  schema见前篇博客
​
const productSchema = new Schema({
  proid: { type: String },
  proname: { type: String },
  probrand: { type: String },
  brandimg: { type: String },
  proimg: { type: Array },
  price: { type: Number },
  detail: { type: String },
  stock: { type: Number },
  sales: { type: Number }
})
​
// 就会自动创建一个  数据库集合products
module.exports = mongoose.model('Product', productSchema);

 

3.插入数据

const Product = require('./../collection/Product')
​
/**
 * 命令行
 * db.products.insertOne({})
 * db.products.insertMany([{}, {}])
 * db.products.insert([{}, {}])
 * 
 * 代码
 * db.products.insertMany([{}, {}])
 */
​
Product.insertMany({
  proid: '1111',
  proname: 'Apple iPhone SE (A2298) 64GB 黑色 移动联通电信4G手机',
  probrand: 'iphone',
  brandimg: 'https://img10.360buyimg.com/imgzone/jfs/t17752/324/262367977/74875/fd9a74db/5a65c544N9fcaf6f7.png',
  proimg: [
    'https://img10.360buyimg.com/n1/s450x450_jfs/t1/96643/2/18618/145854/5e9738d5Ea3ddc9d9/694707618ef7b5cd.jpg',
    'https://img10.360buyimg.com/n1/s450x450_jfs/t1/98709/6/18653/102688/5e9738e3Ed573c9e4/6850f1a0c68bb4a7.jpg',
    'https://img10.360buyimg.com/n1/s450x450_jfs/t1/117670/38/1396/71194/5e9738e8E70c13df7/7b6d575c3001de7c.jpg'],
  price: 3199,
  detail: '详情描述',
  stock: 2000,
  sales: 100
}, (err) => {
  // nodejs 的错误优先回调
  if (err) throw err;
  console.log('插入成功')
})

注意:插入时貌似只能用insertMany()
     插入多条数据时要用json数组的形势进行插入

 

4.删除数据

 1 const Product = require('./../collection/Product')
 2  3 /**
 4  * 命令行 + 代码
 5  * product.deleteOne({key: value}) 单条
 6  * product.deleteMany({key: value}) 多条
 7  * product.deleteOne({}) 所有
 8  * 
 9  */
10 11 // Product.deleteOne({ proid: '1111' }, (err) => {
12 //   if (err) throw err;
13 //   console.log('删除成功')
14 // })
15 16 // Product.deleteMany({ proid: '1111'}, (err) => {
17 //   if (err) throw err;
18 //   console.log('删除成功')
19 // })
20 21 Product.deleteMany({}, (err) => {
22   if (err) throw err;
23   console.log('删除成功')
24 })
25 5.修改数据
26 const Product = require('./../collection/Product')
27 28 /**
29  * // 设置
30  * Product.updateOne({key1: value1}, { $set: { key2: value2, key3: value3}})
31  * Product.updateMany({key1: value1}, { $set: { key2: value2, key3: value3}})
32  * Product.updateMany({}, { $set: { key2: value2, key3: value3}})
33  * // 自增自减 num
34  * Product.updateOne({key1: value1}, { $inc: { key2: num}})
35  * Product.updateMany({key1: value1}, { $inc: { key2: num}})
36  * Product.updateMany({}, { $inc: { key2: num}})
37  * 
38  */
39 40 // 库存减一 销量加1
41 Product.updateOne({proid: '1111'}, { $inc: { stock: -1, sales: 1}}, (err) => {
42   if (err) throw err;
43   console.log('修改成功')
44 })

 

6.查询数据

 

 1 const Product = require("./../collection/product")
 2 
 3 
 4 //查询语句也有很多种
 5 /**
 6  * 
 7  * 
 8  * 
 9  * 
10  * 
11  * 
12  * 
13 */
14 
15 
16 //此查询时忽略其他只显示proname
17 
18 // Product.find({}, { _id: 0, proname: 1 }).exec((err, data) => {
19 //     if (err) throw err;
20 //     console.log(data)//打印查到的内容
21 // })
22 
23 //除了id以外都打印
24 // Product.find({}, { _id: 0 }).exec((err, data) => {
25 //     if (err) throw err;
26 //     console.log(data)//打印查到的内容
27 // })
28 
29 
30 //
31 Product.find({}).exec((err, data) => {
32     if (err) throw err;
33     console.log(data)//打印查到的内容
34 })

 

 

6.修改数据

 1 const Product = require("./../collection/product")
 2 
 3 
 4 
 5 //修改的方法有很多种
 6 /** 
 7  * 
 8  * 
 9  * User.updateOne({username: '吴大勋'}, {$set: {age: 20}}, err => { if (err) throw err; console.log('修改成功') })
10  * 
11  * */  
12 
13 Product.updateOne({prodid:"1111"},{$set:{prodid:"2222"}},(err)=>{
14     if(err) throw err;
15     console.log('修改成功')
16 })

 

posted @ 2020-06-04 15:20  书昀  阅读(441)  评论(0编辑  收藏  举报