ដើម្បី​ស្រង់​យក​​ទិន្នន័យ​ដែល​ជា​ឯកសារ​នៅ​ខាងដើម​គេ​បំផុត យើង​ចាំបាច់​ត្រូវ​ប្រើប្រាស់​វិធី​ឈ្មោះ findOne() ដោយ​ធ្វើ​ដូច​ខាងក្រោម​នេះ៖

 

import express from 'express'
import path from 'path'

const app = express()
const port = process.env.PORT || 3000
const __dirname = path.resolve()
 
import index from './routes/index.js'
import backend from './routes/backend.js'
import mydb from './models/connectMongoDB.js'

app.use('/',async function(req,res,next){
    req.mydb = await mydb
    req.__dirname = __dirname
    next()
})

app.set('views', path.join(__dirname, 'views'))
app.set('view engine', 'ejs')
app.use(express.static(path.join(__dirname, 'public')))
app.use(express.urlencoded({extended:false}))
app.use(express.json())
                                  
app.use('/',index) 
app.use('/backend',backend) 

app.listen(port,function(){
    console.log(`This application is listening to the port: ${port}`)
})

 

/* ./routes/index.js */
import express from 'express'
import func from '../models/mongodb.js'
const index = express.Router()

index.use(func)

index.get('/',(req,res)=>{
    res.render('base',req.data)
})
 
export default index

 

//models/mongodb.js

function func(req,res,next){
    req.mydb.collection("users").findOne({},function(err, result) {
        if (err) throw err
        req.data = {}
        req.data.message = JSON.stringify(result)
        next()
    })
}

export default func

 

ដើម្បីស្រង់​យក​ទិន្នន័យ​ទាំងអស់ ចេញ​ពី​បណ្តុំទិន្នន័យ​ណាមួយ យើង​ចាំបាច់​ត្រូវ​ប្រើប្រាស់​វិធី​ឈ្មោះ find() គឺ​ដូច​គ្នា​ទៅ​​នឹង​បញ្ជា SELECT * នៅ​ក្នុង​ភាសា SQL ដែរ​។ ពិនិត្យ​កម្មវិធី​ខាង​ក្រោម​នេះ៖

 

//models/mongodb.js

function func(req,res,next){
    req.mydb.collection("users").find({}).toArray(function(err, result) {
        if (err) throw err
        req.data = {}
        req.data.message = JSON.stringify(result)
        next()
    })
}

export default func

 

//models/mongodb.js

function func(req,res,next){
    req.mydb.collection("users").find({},{projection:{ _id:0,name:0}}).toArray(function(err, result){
        if (err) throw err
        req.data = {}
        req.data.message = JSON.stringify(result)
        next()
    })
}

export default func