gpt4 book ai didi

json - NodeJS 与 mongoDB JSONFormat 问题

转载 作者:太空宇宙 更新时间:2023-11-04 00:26:27 25 4
gpt4 key购买 nike

我是 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运行 Node 服务器服务器成功运行。然后,我尝试使用 POST MAN 应用程序从数据库中获取数据。

所以,我确实喜欢下面的内容,

GET方法:localhost:3000/tasks

它成功运行并产生结果。

如下所示,

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

我的问题就在这里,

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

我们将不胜感激。谢谢。

更新

当我尝试安装 moment 时,出现以下错误

notsup SKIPPING OPTIONAL DEPENDENCY: Unsupported platform for fsevents@1.1.1: wanted {"os":"darwin","arch":"any"} (current: {"os":"linux","arch":"x64"})

最佳答案

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 之类的模块。以您想要的任何格式显示日期。

关于json - NodeJS 与 mongoDB JSONFormat 问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42595860/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com