首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQLDelight多表创建

SQLDelight多表创建
EN

Stack Overflow用户
提问于 2022-11-14 18:16:25
回答 1查看 40关注 0票数 1

我正在用KMM做实验,但是我对SQLDelight有一个问题。下面是AppDatabase.sq文件的代码示例。

代码语言:javascript
复制
CREATE TABLE Data (
id INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
content TEXT NOT NULL
);

-- ====>> Add this new table <<==== (QUESTION 1)
CREATE TABLE Settings (
version TEXT NOT NULL
);

insertItem:
INSERT INTO Data(id, content) VALUES(?,?);

removeAll:
DELETE FROM Data;

selectById:
SELECT * FROM Data WHERE id = ?;

updateById:
UPDATE Data SET content = ? WHERE id = ?;

-- ====>> I want this to be run on DB creation <<==== (QUESTION 2)
INSERT INTO Settings(version) VALUES ('1.0.0');

getVersion:
SELECT version FROM Settings;

当我运行应用程序时,我接收到:android.database.sqlite.SQLiteException: no such table: Settings (code 1 SQLITE_ERROR): , while compiling: SELECT version FROM Settings

如果我使用应用程序检查 of Android 打开应用程序创建的数据库,似乎只有Data表和其他与我的表无关的自动生成表。

我的两个问题(请参阅SQL代码中的注释以获得编号参考)是:

  1. 如何从Settings文件创建此表( .sq )?
  2. 如何在不调用实际代码中的任何函数的情况下将新值插入到我的表中?

如果您需要,整个项目是这里,但是在以前的版本中,因为我想实现的更改不起作用!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-11-14 21:43:34

我已经克隆了您的Github项目,添加了您在这里提供的代码,它运行得很好。两个表都被创建,Settings表有"1.0.0“版本行。

您是否已在电话上卸载应用程序并再次安装?您可能还在使用旧版本的数据库,因为您还没有为SQLDelight提供任何迁移。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/74436136

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档