CoffeeScript - MongoDB

MongoDB là một cơ sở dữ liệu định hướng tài liệu, đa nền tảng cung cấp, hiệu suất cao, tính khả dụng cao và khả năng mở rộng dễ dàng. MongoDB hoạt động dựa trên khái niệm về bộ sưu tập và tài liệu. Để biết thêm thông tin, hãy đọc Hướng dẫn về MongoDB của chúng tôi .

Trong chương này, bạn sẽ học cách giao tiếp với cơ sở dữ liệu MongoDB bằng CoffeeScript.

Cài đặt

Cơ sở dữ liệu MongoDB có thể được tích hợp với CoffeeScript bằng cách sử dụng trình điều khiển Node.js 2.0 của MongoDB. Trước hết, bạn cần cài đặt MongoDB trong hệ thống của mình, bằng cách tham khảo chương môi trường của hướng dẫn MongoDB của chúng tôi.

Sau khi cài đặt MongoDB thành công, hãy duyệt qua bin thư mục (nếu bạn chưa đặt đường dẫn) và khởi động dịch vụ MongoDB như hình bên dưới.

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

Cuối cùng cài đặt trình điều khiển MongoDB và các phụ thuộc của nó bằng cách thực hiện lệnh NPM sau trong dấu nhắc lệnh.

npm install mongodb --save

Kết nối với MongoDB

Để kết nối với MongoDB, trước hết hãy tạo MongoClient bằng cách sử dụng điều này, gọi connect()chức năng. Hàm này chấp nhận url và một hàm gọi lại làm tham số.

Sau mã CoffeeScript cho thấy cách kết nối với máy chủ MongoDB. Nếu máy chủ MongoDB đang chạy trong hệ thống của bạn, chương trình này sẽ thiết lập một kết nối với máy chủ.

#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

Lưu đoạn mã trên vào một tệp có tên connect_db.coffeevà thực hiện nó như hình dưới đây. Nếu cơ sở dữ liệu được tạo thành công thì nó sẽ đưa ra thông báo sau

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

Tạo Bộ sưu tập

Một bộ sưu tập trong MongoDB chứa các tài liệu mà chúng tôi lưu trữ trong đó. Bạn có thể tạo một bộ sưu tập bằng cách sử dụngcollection()chức năng. Hàm này chấp nhận một đối số chuỗi đại diện cho tên của bộ sưu tập mà chúng ta muốn tạo.

Sau mã CoffeeScript cho thấy cách tạo một bộ sưu tập trong MongoDB. Trong trường hợp có bất kỳ lỗi nào, chúng sẽ được hiển thị trên bảng điều khiển.

#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

Lưu đoạn mã trên vào một tệp có tên create_collection.coffeevà thực hiện nó như hình dưới đây. Nếu bộ sưu tập được tạo thành công thì nó sẽ đưa ra thông báo sau

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

Chèn tài liệu

Bạn có thể chèn tài liệu vào một bộ sưu tập trong MongoDB mà bạn cần gọi một hàm có tên insert() bằng cách chuyển danh sách các tài liệu cần được chèn, dưới dạng các tham số.

Mã CoffeeScript sau cho biết cách chèn tài liệu vào một bộ sưu tập có tên My_collection. Trong trường hợp có bất kỳ lỗi nào, chúng sẽ được hiển thị trên bảng điều khiển.

#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

Lưu đoạn mã trên vào một tệp có tên insert_documents.coffeevà thực hiện nó như hình dưới đây. Nếu tài liệu được chèn thành công thì nó sẽ đưa ra thông báo sau

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

Đọc tài liệu

Bạn có thể truy xuất các tài liệu được lưu trữ trong MongoDB bằng một hàm có tên find(). Mã CoffeeScript sau đây cho thấy cách truy xuất các bản ghi được lưu trữ trong 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

Lưu đoạn mã trên vào một tệp có tên read_documents.coffeevà thực hiện nó như hình dưới đây. Chương trình này truy xuất tài liệu cần thiết trong bộ sưu tập được chỉ định và hiển thị nó như hình dưới đây.

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

Bạn cũng có thể đọc tất cả các tài liệu hiện có trong một bộ sưu tập cụ thể bằng cách thực thi find() hàm mà không truyền bất kỳ đối số nào cho nó như được hiển thị bên dưới.

#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

Lưu đoạn mã trên vào một tệp có tên read_all_documents.coffeevà thực hiện nó như hình dưới đây. chương trình này truy xuất tất cả các tài liệu trong bộ sưu tập được chỉ định và hiển thị nó như hình dưới đây.

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' } ]

Cập nhật tài liệu

Bạn có thể cập nhật các tài liệu được lưu trữ trong MongoDB bằng một hàm có tên update(). Sau mã CoffeeScript cho thấy cách cập nhật các bản ghi được lưu trữ trong 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

Chương trình này cập nhật thành phố của nhân viên tên Ram từ Hyderabad đến Delhi.

Lưu đoạn mã trên vào một tệp có tên update_documents.coffeevà thực hiện nó như hình dưới đây. chương trình này truy xuất các tài liệu trong bộ sưu tập được chỉ định và hiển thị nó như hình dưới đây.

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

Sau khi cập nhật, nếu bạn thực hiện read_documents.coffee chương trình, sau đó bạn sẽ thấy rằng tên thành phố của người tên Ram được cập nhật từ Hyderabad đến Delhi.

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' } ]

Xóa tài liệu

Bạn có thể xóa tất cả các tài liệu khỏi bộ sưu tập bằng cách sử dụng remove()chức năng. Mã CoffeeScript sau cho thấy cách xóa tất cả các bản ghi được lưu trữ trong 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

Lưu đoạn mã trên vào một tệp có tên delete_documents.coffeevà thực hiện nó như hình dưới đây. chương trình này xóa tất cả các tài liệu trong bộ sưu tập được chỉ định hiển thị các thông báo sau.

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

Sau khi xóa, nếu bạn thực hiện lệnh read_documents.coffee chương trình, sau đó bạn sẽ nhận được một bộ sưu tập rỗng như hình dưới đây.

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