繁体   English   中英

如何在Sqlite中为TEXT列设置默认值?

[英]How to set a default value to a TEXT column in Sqlite?

我有一张简单的桌子。 我正在尝试将默认值放入TEXT列。 这是表查询:

"CREATE TABLE book(_id INTEGER PRIMARY KEY AUTOINCREMENT, book_id TEXT NOT NULL DEFAULT '0', book_name TEXT NOT NULL);"   

它创建表但我尝试插入数据时出现问题。 我只是尝试给book_name一个书名,因为我预计book_id的列默认值为0。 但它没有,它添加了空值,因此行不会插入。 我也试过这个查询:

"CREATE TABLE book(_id INTEGER PRIMARY KEY AUTOINCREMENT, book_id TEXT NOT NULL DEFAULT \'0\', book_name TEXT NOT NULL);"     

但问题仍然存在。 我已经搜索了堆栈溢出,得到了一些答案,但它们已经老了,现在还不适合我。 因此,如何在sqlite中将默认值设置为TEXT列有所改变。 提前致谢 :)

编辑
这是insert语句:

database.insert("book", null, cv);    

这里cvContentValues的对象,它只包含列book_name的值。

您可以在创建表时为列指定默认值。 (看起来好像你不能使用ALTER语句添加默认值,所以你必须重新创建你的表。)

CREATE TABLE your_table_name
(MainContactName TEXT NOT NULL DEFAULT '')

对于实施例

CREATE TABLE book(_id INTEGER PRIMARY KEY AUTOINCREMENT,book TEXT DEFAULT "abc");

现在看到, 默认值设置为“abc”

检查sqllite 文档

改变桌子,

sqlitedbInstance.execSQL("alter table myTable add column Address TEXT DEFAULT 'ABC' ");

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM