mongoDB 中的数据未根据架构保存
Data not saved according to Schema in mongoDB
我正在尝试制作一个库存管理应用程序,我通过 mongoose 为 mongoDB 创建了一个架构,如下所示
const mongoose = require("mongoose");
const Product = mongoose.model(
"Product",
new mongoose.Schema({
id: Number,
barcode: String,
ProductName: String,
Price: Number,
Quantity: Number
})
);
module.exports = Product;
当我尝试通过 React 表单保存它时,它会根据模式发送数据。控制台日志看起来像这样
Console
但数据并没有完全保存,只保存了Id和barcode,其他元素没有保存。数据看起来像这样
data that has been saved as
我觉得我的server.js有问题是这样的
const express = require("express");
const bodyParser = require("body-parser");
const cors = require("cors");
const dbConfig = require("./auth/config/db.config");
const app = express();
const { verifySignUp, authJwt } = require("./auth/middlewares");
const authController = require("./auth/controllers/auth.controller");
const userController = require("./auth/controllers/user.controller")
var corsOptions = {
origin: "http://localhost:3000"
};
app.use(cors(corsOptions));
// parse requests of content-type - application/json
app.use(bodyParser.json());
// parse requests of content-type - application/x-www-form-urlencoded
app.use(bodyParser.urlencoded({ extended: true }));
const db = require("./auth/models");
db.mongoose
.connect(`mongodb://${dbConfig.HOST}:${dbConfig.PORT}/${dbConfig.DB}`, {
useNewUrlParser: true,
useUnifiedTopology: true
})
.then(() => {
console.log("Successfully connect to MongoDB.");
})
.catch(err => {
console.error("Connection error", err);
process.exit();
});
// simple route
app.get("/", (req, res) => {
res.json({ message: "cnct auth success!" });
});
// routes
require('./auth/routes/auth.routes')(app);
require('./auth/routes/user.routes')(app);
require('./InventoryManager/routes/store.routes')(app);
// set port, listen for requests
const PORT = process.env.PORT || 8080;
app.listen(PORT, () => {
console.log(`Server is running on port ${PORT}.`);
});
任何人都可以帮我解决这个问题吗?我真的想用 2 天的时间来解决这个问题,我们将不胜感激。如果还有什么需要看的,请询问并提供帮助。提前谢谢你
您要保存的对象
id: ,
barcode: ,
productName: ,
price: ,
quantity:
Mongoose 模式不同:
id: Number,
barcode: String,
ProductName: String,
Price: Number,
Quantity: Number
ProductName
、Price
、Quantity
不存在于您的对象中(大小写重要),并且这 3 个字段不是未保存在您的数据库中。
您需要根据您的架构更改您的对象。应该是:
id: 123,
barcode: "barcode",
ProductName: "name",
Price: 100,
Quantity: 2
(值只是示例)
你的问题是你的模式是用不同类型的案例编写的,例如:
“yourMongoField”到“YourMongoField”。
您只需将您的模式更新为下面给出的示例,一切都会正常进行。
id: Number,
barcode: String,
productName: String,
price: Number,
quantity: Number,
我正在尝试制作一个库存管理应用程序,我通过 mongoose 为 mongoDB 创建了一个架构,如下所示
const mongoose = require("mongoose");
const Product = mongoose.model(
"Product",
new mongoose.Schema({
id: Number,
barcode: String,
ProductName: String,
Price: Number,
Quantity: Number
})
);
module.exports = Product;
当我尝试通过 React 表单保存它时,它会根据模式发送数据。控制台日志看起来像这样
Console
但数据并没有完全保存,只保存了Id和barcode,其他元素没有保存。数据看起来像这样 data that has been saved as
我觉得我的server.js有问题是这样的
const express = require("express");
const bodyParser = require("body-parser");
const cors = require("cors");
const dbConfig = require("./auth/config/db.config");
const app = express();
const { verifySignUp, authJwt } = require("./auth/middlewares");
const authController = require("./auth/controllers/auth.controller");
const userController = require("./auth/controllers/user.controller")
var corsOptions = {
origin: "http://localhost:3000"
};
app.use(cors(corsOptions));
// parse requests of content-type - application/json
app.use(bodyParser.json());
// parse requests of content-type - application/x-www-form-urlencoded
app.use(bodyParser.urlencoded({ extended: true }));
const db = require("./auth/models");
db.mongoose
.connect(`mongodb://${dbConfig.HOST}:${dbConfig.PORT}/${dbConfig.DB}`, {
useNewUrlParser: true,
useUnifiedTopology: true
})
.then(() => {
console.log("Successfully connect to MongoDB.");
})
.catch(err => {
console.error("Connection error", err);
process.exit();
});
// simple route
app.get("/", (req, res) => {
res.json({ message: "cnct auth success!" });
});
// routes
require('./auth/routes/auth.routes')(app);
require('./auth/routes/user.routes')(app);
require('./InventoryManager/routes/store.routes')(app);
// set port, listen for requests
const PORT = process.env.PORT || 8080;
app.listen(PORT, () => {
console.log(`Server is running on port ${PORT}.`);
});
任何人都可以帮我解决这个问题吗?我真的想用 2 天的时间来解决这个问题,我们将不胜感激。如果还有什么需要看的,请询问并提供帮助。提前谢谢你
您要保存的对象
id: ,
barcode: ,
productName: ,
price: ,
quantity:
Mongoose 模式不同:
id: Number,
barcode: String,
ProductName: String,
Price: Number,
Quantity: Number
ProductName
、Price
、Quantity
不存在于您的对象中(大小写重要),并且这 3 个字段不是未保存在您的数据库中。
您需要根据您的架构更改您的对象。应该是:
id: 123,
barcode: "barcode",
ProductName: "name",
Price: 100,
Quantity: 2
(值只是示例)
你的问题是你的模式是用不同类型的案例编写的,例如: “yourMongoField”到“YourMongoField”。
您只需将您的模式更新为下面给出的示例,一切都会正常进行。
id: Number,
barcode: String,
productName: String,
price: Number,
quantity: Number,