所以我在使用sqliteporter插件创建特定表时遇到了问题。
我的assets文件夹中有一个名为initdb.sql的文件,其中有一行sql:
CREATE TABLE IF NOT EXISTS `localListItems` (
`id` INTEGER NOT NULL ,
`quantity` TINYINT(2) NOT NULL ,
`checked` TINYINT(1) NOT NULL DEFAULT 0 ,
`listId` INTEGER NOT NULL ,
`itemId` INTEGER NOT NULL ,
PRIMARY KEY (`id`),
KEY `fkIdx_26` (`listId`),
CONSTRAINT `FK_26`
FOREIGN KEY `fkIdx_26` (`listId`)
REFERENCES `localLists` (`id`)
ON DELETE CASCADE,
KEY `fkIdx_30` (`itemId`),
CONSTRAINT `FK_30`
FOREIGN KEY `fkIdx_30` (`itemId`)
REFERENCES `localItems` (`id`)
ON DELETE CASCADE
);
缩小版本:
CREATE TABLE IF NOT EXISTS `localListItems` ( `id` INTEGER NOT NULL , `quantity` TINYINT(2) NOT NULL , `checked` TINYINT(1) NOT NULL DEFAULT 0 , `listId` INTEGER NOT NULL , `itemId` INTEGER NOT NULL , PRIMARY KEY (`id`), KEY `fkIdx_26` (`listId`), CONSTRAINT `FK_26` FOREIGN KEY `fkIdx_26` (`listId`) REFERENCES `localLists` (`id`) ON DELETE CASCADE, KEY `fkIdx_30` (`itemId`), CONSTRAINT `FK_30` FOREIGN KEY `fkIdx_30` (`itemId`) REFERENCES `localItems` (`id`) ON DELETE CASCADE);
它在文档中被缩小,因此占用一行以防止转义错误'\n'
我正在使用以下类型脚本代码调用此文件:
this.httpClient.get('assets/initDB.sql', { responseType: 'text' })
.subscribe((sql:any) => {
this.sqlitePorter.importSqlToDb(this.database, sql)
.then(data => {
this.databaseReady.next(true);
this.storage.set('database_filled', this.databaseVersionControl);
})
.catch(e => console.log(e));
});
所有其他表都按要求插入(上面没有显示),但是上面的sql在phpmyadmin中运行良好,但在尝试使用sqlite创建它时不起作用。
控制台中出现的错误是以下json。
{
"code":5,
"message":"Failed to import SQL; message=near \"KEY\": syntax error",
"statement":"CREATE TABLE IF NOT EXISTS `localListItems` ( `id` INTEGER NOT NULL , `quantity` TINYINT(2) NOT NULL , `checked` TINYINT(1) NOT NULL DEFAULT 0 , `listId` INTEGER NOT NULL , `itemId` INTEGER NOT NULL , PRIMARY KEY (`id`), KEY `fkIdx_26` (`listId`), CONSTRAINT `FK_26` FOREIGN KEY `fkIdx_26` (`listId`) REFERENCES `localLists` (`id`) ON DELETE CASCADE, KEY `fkIdx_30` (`itemId`), CONSTRAINT `FK_30` FOREIGN KEY `fkIdx_30` (`itemId`) REFERENCES `localItems` (`id`) ON DELETE CASCADE)"
}
任何关于为什么这不起作用的帮助都会被告知。因为我不太明白错误代码。
谢谢您。