sqlite数据类型

转载 2012年03月21日 11:21:48

一般数据采用的固定的静态数据类型,而SQLite采用的是动态数据类型,会根据存入值自动判断。SQLite具有以下五种数据类型:

1.NULL:空值。
2.INTEGER:带符号的整型,具体取决有存入数字的范围大小。
3.REAL:浮点数字,存储为8-byte IEEE浮点数。
4.TEXT:字符串文本。
5.BLOB:二进制对象。


但实际上,sqlite3也接受如下的数据类型:
 smallint 16 位元的整数。
 interger 32 位元的整数。
 decimal(p,s) p 精确值和 s 大小的十进位整数,精确值p是指全部有几个数(digits)大小值,s是指小数点後有几位数。如果没有特别指定,则系统会设为 p=5; s=0 。
 float  32位元的实数。
 double  64位元的实数。
 char(n)  n 长度的字串,n不能超过 254。
 varchar(n) 长度不固定且其最大长度为 n 的字串,n不能超过 4000。
 graphic(n) 和 char(n) 一样,不过其单位是两个字元 double-bytes, n不能超过127。这个形态是为了支援两个字元长度的字体,例如中文字。
 vargraphic(n) 可变长度且其最大长度为 n 的双字元字串,n不能超过 2000
 date  包含了 年份、月份、日期。
 time  包含了 小时、分钟、秒。
 timestamp 包含了 年、月、日、时、分、秒、千分之一秒。

datetime 包含日期时间格式,必须写成'2010-08-05'不能写为'2010-8-5',否则在读取时会产生错误!

Sqlite常用数据类型,

这句话本身就有问题,因为:SQLite是无类型的. 这意味着你可以保存任何类型的数据到你所想要保存的任何表的任何列中, 无论这列声明的数据类型是什么(只有自动递增Integer Primary Key才有用). 对于SQLite来说对字段不指定类型是完全有效的. 如:

Create Table ex3(a, b, c);

即使SQLite允许忽略数据类型, 但是仍然建议在你的Create Table语句中指定数据类型. 因为数据类型对于你和其他的程序员交流, 或者你准备换掉你的数据库引擎是非常有用的. SQLite支持常见的数据类型, 如: 

SQL代码
  1. CREATE TABLE ex2(    
  2. a VARCHAR(10),    
  3. b NVARCHAR(15),   
  4. c TEXT,    
  5. d INTEGER,   
  6. e FLOAT,   
  7. f BOOLEAN,    
  8. g CLOB,    
  9. h BLOB,    
  10. i TIMESTAMP,   
  11. j NUMERIC(10,5),    
  12. k VARYING CHARACTER (24),    
  13. l NATIONAL VARYING CHARACTER(16)   
  14. );

char、varchar、text和nchar、nvarchar、ntext的区别

1、CHAR。CHAR存储定长数据很方便,CHAR字段上的索引效率级高,比如定义char(10),那么不论你存储的数据是否达到了10个字节,都要占去10个字节的空间,不足的自动用空格填充。

2、VARCHAR。存储变长数据,但存储效率没有CHAR高。如果一个字段可能的值是不固定长度的,我们只知道它不可能超过10个字符,把它定义为 VARCHAR(10)是最合算的。VARCHAR类型的实际长度是它的值的实际长度+1。为什么“+1”呢?这一个字节用于保存实际使用了多大的长度。从空间上考虑,用varchar合适;从效率上考虑,用char合适,关键是根据实际情况找到权衡点。

3、TEXT。text存储可变长度的非Unicode数据,最大长度为2^31-1(2,147,483,647)个字符。

4、NCHAR、NVARCHAR、NTEXT。这三种从名字上看比前面三种多了个“N”。它表示存储的是Unicode数据类型的字符。我们知道字符中,英文字符只需要一个字节存储就足够了,但汉字众多,需要两个字节存储,英文与汉字同时存在时容易造成混乱,Unicode字符集就是为了解决字符集这种不兼容的问题而产生的,它所有的字符都用两个字节表示,即英文字符也是用两个字节表示。nchar、nvarchar的长度是在1到4000之间。和char、varchar比较起来,nchar、nvarchar则最多存储4000个字符,不论是英文还是汉字;而char、varchar最多能存储8000个英文,4000个汉字。可以看出使用nchar、nvarchar数据类型时不用担心输入的字符是英文还是汉字,较为方便,但在存储英文时数量上有些损失。  

    所以一般来说,如果含有中文字符,用nchar/nvarchar,如果纯英文和数字,用char/varchar。


Sqlite 数据类型 总结

sqlite 数据类型 总结 一般数据采用的固定的静态数据类型,而SQLite采用的是动态数据类型,会根据存入值自动判断。SQLite具有以下五种数据类型: 1.NULL:空值。 2.INT...
  • candyguy242
  • candyguy242
  • 2012年11月29日 10:58
  • 939

SQLite 3 中的数据类型

SQLite使用动态类型系统,在SQLite中,值的数据类型和值本身,而不是和它的容器,关联在一起的。SQLite的动态类型系统和其他数据库引擎的静态类型系统是兼容的,这样在静态类型的数据库上执行的S...
  • u012917700
  • u012917700
  • 2017年03月03日 09:19
  • 236

SQLite支持那些数据类型

http://forlong401.com/?p=1317 http://androidren.com/index.php?qa=300&qa_1=sqlite%E6%94%AF%E6%8C%81%...
  • forlong401
  • forlong401
  • 2015年02月12日 11:52
  • 6552

利用Sqlite数据库的blob类型存储自定义的数据类型(小寿转载)

sqlite数据库的其他作用在这里就不阐述了,直接进入正题吧! 如何利用sqlite数据库的blob类型存取自定义的数据类型,本人苦苦挣扎了一天,在网上搜了个遍也没找着看起来似乎有用的介绍,所以本人...
  • u011676589
  • u011676589
  • 2014年06月30日 11:48
  • 2303

Android学习笔记七:sqlite3中的数据类型

出处:http://www.cnblogs.com/kfqcome/archive/2011/06/27/2137000.html 大多数的数据库引擎(到现在据我们所知的除了sqlite...
  • wuhenyouyuyouyu
  • wuhenyouyuyouyu
  • 2016年05月13日 10:30
  • 1521

【数据库】 sqlite3数据类型和函数

sqlite3支持的数据类型: NULL、INTEGER、REAL、TEXT、BLOB 但是,sqlite3也支持如下的数据类型 smallint           16位整数 intege...
  • XiaoMT_Rush
  • XiaoMT_Rush
  • 2011年09月10日 21:42
  • 8692

sqlite 的数据类型 与 python 的数据类型

sqlite 数据类型 转载自:http://blog.csdn.net/zanfeng/article/details/17436381 一般数据采用的固定的静态数据类型,而SQLi...
  • lengyff
  • lengyff
  • 2015年04月16日 16:22
  • 2527

android sqlite 数据库存贮类型 long double floate 等 数据类型

INTEGER –整数,对应Java 的byte、short、int 和long。REAL – 小数,对应Java 的float 和double。TEXT – 字串,对应Java 的String。...
  • a2241076850
  • a2241076850
  • 2017年04月07日 13:09
  • 2035

Sqlite3中存储类型和数据类型结合文档解析。

sqlite3是个很小的数据库,运行在手机,机顶盒上....那它就不可能像musql,sqlserver那么规范,有很多的数据类型,之前我也以为它定义了很多数据类型,其实不是他就5个存储类,那么多数据...
  • jycboy
  • jycboy
  • 2015年08月05日 16:08
  • 1916

修改sqlite字段类型

在单机版部署的环境中,在软件升级时,对数据库的修改一般是用 SQL 语句来实现(不可能叫客户用 SQLite Expert 自己修改吧),本来用 SQL 语句修改字段不是啥复杂的事,举例如下: --...
  • guofuyou
  • guofuyou
  • 2013年11月24日 13:17
  • 1228
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:sqlite数据类型
举报原因:
原因补充:

(最多只允许输入30个字)