nodejs+express的mongoose连接数据库表名自动加s

数据库自动加s进而导致访问不到数据库

项目文件结构如下

modules
 --topic.js

topic.js文件中,代码如下

const mongoose=require("mongoose");
const Schema=mongoose.Schema;
const topicSchema=new Schema({    
  title: { type: String },
  content: { type: String },
  author_id: { type: 'ObjectId' },
});
const Topic = mongoose.model('Topic', topicSchema);

export default Topic

在index.js文件中,代码如下

const express = require('express');
const router = express.Router();
const mongoose=require('mongoose');
const models=require('../models/topic');
require('express-mongoose');
const registeredUser=models.registeredUser;
mongoose.connect('mongodb://localhost:27017/myappdb');

router.get('/',function(req,res)
{    
res.send(registeredUser.find());
})
module.exports = router;

在mongoDB中生成的表名为topics,自动加了s image 意外发现虽然看起来连到了数据库(网页未报错),但是就是不能显示读到的数据。

最后发现是topic.js文件中使用mongoose.model()的参数不对 查询mongoose 的api如下 image mongoose API collection名称应该为第三个参数,若为缺省,会自动根据参数name的值以复数形式生成collection

所以应该改成

const Topic = mongoose.model('Topic', topicSchema, 'Topic');

export default Topic

修改后的数据表名就正确了

image

猜你喜欢

转载自blog.csdn.net/chern1992/article/details/81288030
今日推荐