NodeJS与mongoDB JSONFormat问题

时间:2017-03-04 12:12:34

标签: json node.js mongodb mongoose

我是NodeJS和MongoDb的新手。我在jsonObject上面临一个问题。

第1步:我已经在我的ubuntu 16.04系统中成功安装了NodeJS和MongoDB。

第2步:我在项目文件夹中使用package.json文件创建了所有服务器设置。

第3步:我创建了server.js文件,如下所示。

server.js 文件

    express = require('express'),
    routes = require('./api/routes/todoListRoutes');
    mongoose = require('mongoose'),
    Task = require('./api/models/todoListModels'),
    bodyParser = require('body-parser');
    app = express(),
    port = process.env.PORT || 3000,
    mongoose.Promise = global.Promise;
    mongoose.connect('mongodb://localhost/Tododb');
    app.use(bodyParser.urlencoded({ extended: true }));
    app.use(bodyParser.json());
    routes(app);
    app.listen(port);
    console.log('todo list RESTful API server started on: ' + port);

然后我创建了用于存储记录的模型文件。

todoListModels.js

    'use strict';
    var mongoose = require('mongoose');
    var Schema = mongoose.Schema;


    var TaskSchema = new Schema({
      name: {
        type: String,
        Required: 'Kindly enter the name of the task'
      },
      Created_date: {
        type: Date,
        default: Date.now
      },
      status: {
        type: [{
          type: String,
          enum: ['pending', 'ongoing', 'completed']
        }],
        default: ['pending']
      }
    },{ versionKey: false }//Updated);

    module.exports = mongoose.model('Tasks', TaskSchema);

todoListRoutes.js

'use strict';
module.exports = function(app) {
  var todoList = require('../controllers/todoListController');
  app.route('/tasks').get(todoList.list_all_tasks).post(todoList.create_a_task);
  app.route('/tasks/:taskId').get(todoList.read_a_task).put(todoList.update_a_task).delete(todoList.delete_a_task);
};

todoListController.js

'use strict';


mongoose = require('mongoose'),
Task = mongoose.model('Tasks');

exports.list_all_tasks = function(req, res) {
  Task.find({}, function(err, task) {
    if (err)
      res.send(err);
    res.json(task);
  });
};

exports.create_a_task = function(req, res) {
  var new_task = new Task(req.body);
  new_task.save(function(err, task) {
    if (err)
      res.send(err);
    res.json(task);
  });
};


exports.read_a_task = function(req, res) {
  Task.findById(req.params.taskId, function(err, task) {
    if (err)
      res.send(err);
    res.json(task);
  });
};


exports.update_a_task = function(req, res) {
  Task.findOneAndUpdate(req.params.taskId, req.body, {new: true}, function(err, task) {
    if (err)
      res.send(err);
    res.json(task);
  });
};


exports.delete_a_task = function(req, res) {
  Task.remove({
    _id: req.params.taskId
  }, function(err, task) {
    if (err)
      res.send(err);
    res.json({ message: 'Task successfully deleted' });
  });
};

然后我通过nodemon server.js运行节点服务器 服务器成功运行。 然后,我尝试使用POST MAN Application从数据库中获取数据。

所以,我确实喜欢下面,

GET 方法:localhost:3000 / tasks

它成功运行并产生了结果。

如下所示,

[
  {
  "_id": "58ba4c9c03e10b16d140775f",
   "name": "Karthik",
   "__v": 0,
   "status": [
   "pending"
  ],
  "Created_date": "2017-03-04T05:11:56.590Z"
}]

我的问题在这里,

1)我这里没有创建 __ v id 字段。那它为什么会来? 2)然后我需要在 Created_date 字段中使用正确的日期格式。比如“dd-MM-yyyy hh:mm”。怎么做?

帮助将不胜感激。谢谢。

更新

当我尝试安装时刻时,会发生以下错误

  

notsup SKIPPING OPTIONAL DEPENDENCY:不支持的fsevents@1.1.1平台:想要{“os”:“darwin”,“arch”:“any”}(当前:{“os”:“linux”,“arch” : “64”})

1 个答案:

答案 0 :(得分:1)

1.  "_id": "58ba4c9c03e10b16d140775f"

这是由mongodb为您插入的每个文档创建的默认唯一ID,mongo将创建一个_id,默认设置为索引键。

如需更多参考,请阅读advantage of _id

2."__v": 0

versionKey是Mongoose首次创建时在每个文档上设置的属性。此键值包含文档的内部修订版。 versionKey选项是一个字符串,表示用于版本控制的路径。

open this for more details

3."Created_date": "2017-03-04T05:11:56.590Z"

是mongodb保存日期的默认格式.Mongodb使用ISO格式存储日期。如果您想以这种方式保存日期,您可以以字符串格式存储日期,或者您可以以ISO格式保存,但是当您获取文档时,您可以使用Moment等模块来显示格式化您的日期想。