加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

SQLite中“Text”和“String”数据类型之间的区别

发布时间:2020-12-12 19:11:31 所属栏目:百科 来源:网络整理
导读:我有一个SQLite数据库与我的Android应用程序.我注意到我不小心使用“String”数据类型而不是“Text”数据类型定义了一个表.以下是带字符串的代码: private final String LISTDATES_CREATE = "create table if not exists ListDates (_id integer primary ke
我有一个SQLite数据库与我的Android应用程序.我注意到我不小心使用“String”数据类型而不是“Text”数据类型定义了一个表.以下是带字符串的代码:
private final String LISTDATES_CREATE = "create table if not exists ListDates (_id integer primary key autoincrement,ListName string not null,UpdateDate string not null);";

这个工作.它从未抛出错误,我可以存储和检索数据.但是,我无法在文档或Internet上找到SQLite中“String”数据类型的任何引用.通常,所有字符串类型数据都用“text”定义,如下所示:

private final String LISTDATES_CREATE = "create table if not exists ListDates (_id integer primary key autoincrement,ListName text not null,UpdateDate text not null);";

所以我的问题是,使用“string”数据类型定义的字段与“text”数据类型之间有什么区别?有差别吗如果是,使用一个或另一个的后果是什么?

这里要注意的微妙之处在于SQLite不会强制执行您列入列的值的数据类型.这意味着您可以将文本放入数字字段,依此类推.

要理解两个SQL语句之间的差异,请查看第2.1 Determination Of Column Affinity节,该表将映射您提供给SQLite使用的存储类的列类型.

在这种情况下,类型字符串通过规则5映射到存储类NUMERIC.将该字段声明为代码中的文本将告诉DBMS使用TEXT存储类.再次,由于SQLite不强制列类型,因此您将注意到将字符串存储为NUMERIC列时,代码可能运行正常.

作为一个替代示例,您可以定义一个类型为INTERESTING STUFF的列,并通过规则1映射到INTEGER存储类.

总的来说,使用表格定义的文本可能是一个好主意.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读