鍍金池/ 問答/數(shù)據(jù)庫  HTML/ koa 讀取 mongodb 數(shù)據(jù)時遇到無法獲取數(shù)據(jù)

koa 讀取 mongodb 數(shù)據(jù)時遇到無法獲取數(shù)據(jù)

問題

findAddUsers.js 中 find() 時,可以正常讀取數(shù)據(jù),但 return 時就沒有數(shù)據(jù)了

代碼

findAddUsers.js

const mongoose = require('mongoose')

let Schema = mongoose.Schema

let UserSchema = new Schema({
    name: String,
    age: Number
})

let temp = mongoose.model('temp', UserSchema)

exports.findAllUsers = async () => {
    let query = temp.find()

    let res = [1,2,3]

    await query.exec(function (err, users) {
        if (!err) {
            res = users
            // console.log(res) // 這里可以打印出數(shù)據(jù)
        }
    })
    // console.log(res)  // 這里 res 為空,沒有任何值
    return res
}

app.js

const Koa = require('koa')
const app = new Koa()

const router = require('./router/router.js')

const mongoose = require('mongoose')
mongoose.connect('mongodb://localhost/db1')

app
    .use(router.home.routes())
    .use(router.home.allowedMethods())

app.listen(3000, () => {
    console.log('running')
})

router.js

const Router = require('koa-router')
const router = new Router()

const controller = require('../controller/user.js')

module.exports = {
    home: router.get('/', controller.getAllUsers) 
}

user.js

const userHelper = require('../dbhelp/findAllUsers.js')

module.exports = {
    getAllUsers: async (ctx, next) => {
        ctx.body = await userHelper.findAllUsers()
    }
}
回答
編輯回答
冷眸
await query.exec(function (err, users) {
        if (!err) {
            res = users
            // console.log(res) // 這里可以打印出數(shù)據(jù)
        }
    })

你這里要寫成 同步方式 而不是 異步語法

2017年4月14日 09:25
編輯回答
胭脂淚
exports.findAllUsers = async () => {
    return await temp.find()
}
2018年7月3日 14:16