
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存储类.
总的来说,使用表格定义的文本可能是一个好主意.
总结以上是内存溢出为你收集整理的SQLite中“Text”和“String”数据类型之间的区别全部内容,希望文章能够帮你解决SQLite中“Text”和“String”数据类型之间的区别所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)