#javascript #json #mongodb #jsonschema
#javascript #json #mongodb #jsonschema
Вопрос:
Я создаю проверку ДОМАШНЕЙ коллекции, где у меня есть тип комнат (двухместные, одноместные, с ванной комнатой), и проверка должна позволять добавлять все перечисленные элементы.
"rooms.type": {bsonType: ["ensuite", "double", "single"]},
Это то, что у меня есть в валидаторе
db.createCollection("home", {
validator : {
$jsonSchema : {
bsonType: "object",
required: ["address.line1", "address.town", "rooms.type",
"rooms.qty", "rooms.price"],
properties: {
"address.line1": {bsonType: "string"},
"address.town": {bsonType: "string"},
"rooms.type": {bsonType: ["ensuite", "double", "single"]},
"rooms.qty": {bsonType: "int", minimum: 0},
"rooms.price": {bsonType: ["double"], minimum: 0},
}}}})
Я получаю сообщение об ошибке, которое
"ok" : 0,
"errmsg" : "Unknown type name alias: ensuite",
"code" : 2,
"codeName" : "BadValue"
Я ожидаю, что массив room.type разрешит один или все атрибуты в группе, указанной в схеме.
Ответ №1:
Вы можете указать, что тип rooms.type
должен быть «массив», с минимальным 1 элементом в массиве, и что каждый элемент этого массива должен быть перечислением следующим образом:
"rooms.type": {
type: "array",
minItems: 1,
items: {
enum: ["ensuite", "double", "single"]
}
}
У MongoDB есть документация по $ jsonSchema, но вы можете найти более подробную информацию в спецификации проверки схемы JSON, связанной с документацией MongoDB.
Ответ №2:
Вы также можете указать схему таким образом:
db.createCollection('home', {
validator: {
$jsonSchema: {
bsonType: 'object',
required: ['address', 'rooms'],
properties: {
address: {
bsonType: 'object',
additionalProperties: false,
required: ['line1', 'town'],
properties: {
line1: {
bsonType: 'string'
},
town: {
bsonType: 'string'
}
}
},
rooms: {
bsonType: 'object',
additionalProperties: false,
required: ['type', 'qty', 'price'],
properties: {
type: {
bsonType: 'string',
enum: ["ensuite", "double", "single"]
},
qty: {
bsonType: 'int',
minimum: 0
},
price: {
bsonType: 'array',
items: {
bsonType: 'double',
minimum: 0
}
}
}
}
}
}
}
});