从猫鼬模型传递嵌套的JSON数据不起作用

时间:2018-07-12 12:32:05

标签: javascript json node.js mongoose mongoose-schema

我正在将嵌套的JSON数据推送到数据库。这就是我的架构,

const mongoose = require('mongoose');
// original Schema

const dataSourceSchema = mongoose.Schema({

    _id: mongoose.Schema.Types.ObjectId,
    name: { type: String, required: true, unique: true },
    type: { type: String, required: true },
    projectId: { type: mongoose.Schema.Types.ObjectId, ref: 'Project', required: true },
    config:{type: String, required: true}

});

module.exports = mongoose.model('DataSource', dataSourceSchema);

我想将以下json数据传递给我的dataSourceSchema,

{
“name”:”JdbcSourceConnector”,
"type" :"string",
“config”: {
“connector.class”:” io.confluent.connect.jdbc.JdbcSourceConnector”,
“tasks.max”:1,
“connection.url”:”<connection to connect to database along with username and password>”,
“mode”:”incrementing”,
“incrementing.column.name”:”<incrementing column name in table>”,
“topic.prefix”:”test-mysql-jdbc-”
}
}

但不接受,会产生强制转换错误或“,”。

所以我尝试了这个

const dataSourceSchema = mongoose.Schema({

    _id: mongoose.Schema.Types.ObjectId,
    name: { type: String, required: true, unique: true },
    type: { type: String, required: true },
    projectId: { type: mongoose.Schema.Types.ObjectId, ref: 'Project', required: true },
    config:{ 
    connector.class:{ type: String, required: true },
tasks.max:{ type: String, required: true },
connection.url:{ type: String, required: true },
mode:{ type: String, required: true },
incrementing.column.name:{ type: String, required: true },
topic.prefix:{ type: String, required: true }
}

});

此架构也给我错误“,”。

如果我只传递原始模式中提到的字符串,则数据将存储在db中。 但我想传递嵌套的json数据,请向正确的方向引导我。 我还尝试了stringify数据,但无法正常工作。

1 个答案:

答案 0 :(得分:1)

正如我所看到的那样,错误在于定义您的方案和您接近答案的第二个方案。更改您的架构,如下所示:

const dataSourceSchema = mongoose.Schema({
      _id: mongoose.Schema.Types.ObjectId,
      name: { type: String, required: true, unique: true },
      type: { type: String, required: true },
      projectId: { type: mongoose.Schema.Types.ObjectId, ref: 'Project', required: true },
      config:{ 
            connectorClass:{ type: String, required: true },
            tasksMax:{ type: String, required: true },
            connectionUrl:{ type: String, required: true },
            mode:{ type: String, required: true },
            incrementingColumnName:{ type: String, required: true },
            topicPrefix:{ type: String, required: true }
      }
});

我建议进行更改,因为猫鼬不了解其架构的键列中的点表示法,因此您收到的错误是您所提到的。

如果出于某种原因要使用点表示法,请将密钥封装在“中,而不要使用代码段中出现的特殊字符。

P.s。 -不要忘记更改json中的键名