📜  CoffeeScript-MongoDB

📅  最后修改于: 2020-10-26 05:54:12             🧑  作者: Mango


MongoDB是一个跨平台的,面向文档的数据库,可提供高性能,高可用性和易扩展性。 MongoDB致力于收集和文档的概念。有关更多信息,请阅读我们的MongoDB教程

在本章中,您将学习如何使用CoffeeScript与MongoDB数据库进行通信。

安装

MongoDB数据库可以使用MongoDB的Node.js 2.0驱动程序与CoffeeScript集成。首先,请参考我们的MongoDB教程的环境一章,在系统中安装MongoDB。

安装MongoDB后,成功浏览其bin文件夹(如果尚未设置路径)并启动MongoDB服务,如下所示。

C:\Program Files\MongoDB\Server\3.2\bin> mongod

最后,通过在命令提示符下执行以下NPM命令,安装MongoDB驱动程序及其依赖项。

npm install mongodb --save

连接到MongoDB

为了连接到MongoDB,首先使用此方法创建MongoClient,然后调用connect()函数。此函数接受url和回调函数作为参数。

以下CoffeeScript代码显示了如何连接到MongoDB服务器。如果您的系统中正在运行MongoDB服务器,则此程序将建立与服务器的连接。

#Requiring the Mongodb package
mongo = require 'mongodb'

#Creating a MongoClient object
MongoClient = mongo.MongoClient

#Preparing the URL
url = 'mongodb://localhost:27017/testdb'

#Connecting to the server
MongoClient.connect url, (err, db) ->
  if err
    console.log 'Unable to connect . Error:', err
  else
    console.log 'Connection established to', url
    #Close connection
    db.close()
  return

将上面的代码保存在名为connect_db.coffee的文件中,并如下所示执行它。如果数据库创建成功,它将给出以下消息

c:\> coffee connect_db.coffee
coffee connect_db.collection
Connection established to mongodb://localhost:27017/testdb

创建收藏

MongoDB中的集合包含我们存储在其中的文档。您可以使用collection()函数创建一个集合。该函数接受一个字符串参数,该字符串参数表示我们要创建的集合的名称。

以下CoffeeScript代码显示了如何在MongoDB中创建集合。如有任何错误,它们将显示在控制台上。

#Requiring the Mongodb package
mongo = require 'mongodb'

#Creating a MongoClient object
MongoClient = mongo.MongoClient

#Preparing the URL
url = 'mongodb://localhost:27017/testdb'

#Connecting to the server
MongoClient.connect url, (err, db) ->
  if err
    console.log 'Unable to connect . Error:', err
  else
    console.log 'Connection established to', url
    
    #Create collection
    col = db.collection('My_collection')
    console.log "Collection created successfully."
    
    #Close connection
    db.close()
  return

将上面的代码保存在名为create_collection.coffee的文件中,并如下所示执行它。如果成功创建了集合,它将给出以下消息

c:/> coffee create_collection.coffee
Connection established to mongodb://localhost:27017/testdb
Collection created successfully.

插入文件

您可以在插页在MongoDB中,你需要通过传递所需要要插入文档的列表,作为参数来调用一个名为插入函数()集合文件。

以下CoffeeScript代码显示了如何将文档插入到名为My_collection的集合中。如有任何错误,它们将显示在控制台上。

#Sample JSON Documents
doc1 = {name: 'Ram', age: 26, city: 'Hyderabad'}
doc2 = {name: 'Rahim', age: 27, city: 'Banglore'}
doc3 = {name: 'Robert', age: 28, city: 'Mumbai'}

#Requiring the Mongodb package
mongo = require 'mongodb'

#Creating a MongoClient object
MongoClient = mongo.MongoClient

#Preparing the URL
url = 'mongodb://localhost:27017/testdb'

#Connecting to the server
MongoClient.connect url, (err, db) ->
  if err
    console.log 'Unable to connect . Error:', err
  else
    console.log 'Connection established to', url  
  #Creating collection
  col = db.collection('My_collection')
    
  #Inserting documents
  col.insert [doc1,doc2,doc3], (err, result) ->
    if err
      console.log err
    else
      console.log "Documents inserted successfully"
    #Close connection
    db.close()
    return
  return

将上面的代码保存在一个名为insert_documents.coffee的文件中,并如下所示执行它。如果文档插入成功,则会显示以下消息

c:/> coffee insert_documents.coffee
Connection established to mongodb://localhost:27017/testdb
Documents inserted successfully

阅读文件

您可以使用名为find()的函数检索MongoDB中存储的文档。以下CoffeeScript代码显示了如何检索存储在MongoDB中的记录。

#Requiring the Mongodb package
mongo = require 'mongodb'

#Creating a MongoClient object
MongoClient = mongo.MongoClient

#Preparing the URL
url = 'mongodb://localhost:27017/testdb'

#Connecting to the server
MongoClient.connect url, (err, db) ->
  if err
    console.log 'Unable to connect . Error:', err
  else
    console.log 'Connection established to', url    
    #Creating collection object
    col = db.collection('My_collection')    
    #Inserting Documents
    col.find({name: 'Ram'}).toArray (err, result)->
      if err
        console.log err
      else 
      console.log 'Found:', result            
      #Closing connection
      db.close()
      return
  return

将上面的代码保存在名为read_documents.coffee的文件中,并如下所示执行它。该程序在指定的集合中检索所需的文档,并显示如下所示。

C:\> coffee read_documents.coffee
Connection established to mongodb://localhost:27017/testdb
Found: [ { _id: 56e269c10478809c3009ad1e,
    name: 'Ram',
    age: 26,
    city: 'Hyderabad' } ]

您还可以通过执行find()函数而不将任何参数传递给它来读取特定集合中存在的所有文档,如下所示。

#Requiring the Mongodb package
mongo = require 'mongodb'

#Creating a MongoClient object
MongoClient = mongo.MongoClient

#Preparing the URL
url = 'mongodb://localhost:27017/testdb'

#Connecting to the server
MongoClient.connect url, (err, db) ->
  if err
    console.log 'Unable to connect . Error:', err
  else
    console.log 'Connection established to', url    
    #Creating collection object
    col = db.collection('My_collection')    
    #Reading all Documents
    col.find().toArray (err, result)->
      if err
        console.log err
      else 
      console.log 'Found:', result            
      #Closing connection
      db.close()
      return
  return

将上面的代码保存在一个名为read_all_documents.coffee的文件中,并如下所示执行它。该程序检索指定集合中的所有文档,并显示如下所示。

C:\> coffee read_all_documents.coffee
Connection established to mongodb://localhost:27017/testdb
Found: [ { _id: 56e2c5e27e0bad741a68c03e,
    name: 'Ram',
    age: 26,
    city: 'Hyderabad' },
  { _id: 56e2c5e27e0bad741a68c03f,
    name: 'Rahim',
    age: 27,
    city: 'Banglore' },
  { _id: 56e2c5e27e0bad741a68c040,
    name: 'Robert',
    age: 28,
    city: 'Mumbai' } ]

更新文件

您可以使用名为update()的函数更新MongoDB中存储的文档。以下CoffeeScript代码显示了如何更新MongoDB中存储的记录。

#Get mongo client object
MongoClient = require('mongodb').MongoClient
#Connecting to mongodb
url = 'mongodb://localhost:27017/testdb'
MongoClient.connect url, (err, db) ->
  if err
    console.log 'Unable to connect . Error:', err
  else
    console.log 'Connection established to', url    
    #Creating collection
    col = db.collection('My_collection')
    #Reading Data
    col.update {name:'Ram'},{$set:{city:'Delhi'}},(err, result)->
      if err
        console.log err
      else 
      console.log "Document updated"    
      
      #Closing connection
      db.close()
      return
  return

此程序将名为Ram的员工城市从海得拉巴更新到德里。

将上面的代码保存在一个名为update_documents.coffee的文件中,并如下所示执行它。该程序将检索指定集合中的文档并显示如下所示。

C:\> coffee update_documents.coffee
Connection established to mongodb://localhost:27017/testdb
Document updated

更新后,如果执行read_documents.coffee程序,则会观察到名为Ram的人的城市名称已从海得拉巴更新为德里

C:\> coffee Read_all_documents.coffee
Connection established to mongodb://localhost:27017/testdb
Found: [ { _id: 56e2c5e27e0bad741a68c03e,
    name: 'Ram',
    age: 26,
    city: 'Delhi' },
  { _id: 56e2c5e27e0bad741a68c03f,
    name: 'Rahim',
    age: 27,
    city: 'Banglore' },
  { _id: 56e2c5e27e0bad741a68c040,
    name: 'Robert',
    age: 28,
    city: 'Mumbai' } ]

删除文件

您可以使用remove()函数从集合中删除所有文档。以下CoffeeScript代码显示了如何删除MongoDB中存储的所有记录。

#Get mongo client object
MongoClient = require('mongodb').MongoClient
#Connecting to mongodb
url = 'mongodb://localhost:27017/testdb'
MongoClient.connect url, (err, db) ->
  if err
    console.log 'Unable to connect . Error:', err
  else
    console.log 'Connection established to', url    
    #Creating collection
    col = db.collection('My_collection')
    #Deleting Data
    col.remove()
    console.log "Document deleted"
      
    #Closing connection
    db.close()      
  return

将上面的代码保存在一个名为delete_documents.coffee的文件中,并如下所示执行它。此程序将删除显示以下消息的指定集合中的所有文档。

C:\> coffee delete_documents.coffee
Connection established to mongodb://localhost:27017/testdb
Document deleted

删除后,如果执行read_documents.coffee程序,则将得到一个空集合,如下所示。

C:\> coffee Read_all_documents.coffee
Connection established to mongodb://localhost:27017/testdb
Found: [ ]