我正在为 vue.js应用使用 NeDB ,但是当我第二次尝试保存数据时发生了以下错误。
>错误是:
“无法插入未定义的键,它违反了唯一约束。”
我正在使用 electron-vue 开发该应用。
我检查了数据库文件,发现没有生成_id字段。我认为_id字段应自动生成。
src \ renderer \ datastore.js
import Datastore from 'nedb'
import path from 'path'
import { remote } from 'electron'
export default new Datastore({
autoload: true,
filename: path.join(remote.app.getPath('userData'), '/data.db')
})
src \ renderer \ main.js
import db from './datastore'
Vue.prototype.$db = db
src \ renderer \ components \ MyApp.vue
<template>
<div>
<form v-on:submit.prevent="insertShelf">
<ul>
<li>
<label>Shelf Number</label>:
<input type="text" name="shelfNum" v-model="newInput.shelfNum">
</li>
<ul v-for="(book, index) in newInput.books">
<li>
<label>Title</label>:
<input type="text" name="title" v-model="book.title">
</li>
<li>
<label>Author</label>:
<input type="text" name="author" v-model="book.author">
</li>
</ul>
<input type="submit" value="Submit">
</form>
</div>
</template>
<script>
export default {
data () {
return {
newInput: {
shelfNum: '',
books: [
{
title: '',
author: ''
}
]
},
shelfList: []
}
},
watch: {
shelfList: {
handler: function () {
this.$db.insert(JSON.stringify(this.shelfList), function (err, newDoc) {
console.log('err', err)
console.log('newDoc', newDoc)
})
}
}
},
methods: {
insertShelf: function () {
this.shelfList.push({
shelfNum: this.newInput.shelfNum,
books: this.newInput.books
})
this.newInput = {
shelfNum: '',
books: [
{
title: '',
author: ''
}
]
}
}
}
}
</script>
第一次,我填写表单并发送的数据被成功保存,但是从第二次发生错误开始。
数据库文件(C:\ Users \ myaccount \ AppData \ Roaming \ Electron \ data.db)仅具有以下内容:
"[{\"shelfNum\":\"12345\",\"books\":[{\"title\":\"Winnie-the-Poo\",\"author\":\"A. A. Milne\"}]}]"
和_id字段不会生成。
请帮助我。