SQLite3 数据类型
转自 http://blog.chinaunix.net/uid-25523295-id-3082716.html 大部分SQL数据库引擎使用静态数据类型,数据的类型取决于它的存储单元(即所在的列)的类型。 SQLite3具有以下5种存储类别(在这里,存储类别和数据类型有所区别): NULL 空值
INTEGER 带符号整数,根据存入的数值的大小占据1,2,3,4,6或者8个字节
REAL 浮点数,采用8byte(即双精度)的IEEE格式表示
TEXT 字符串文本,采用数据库的编码 UTF-8、UTF-16BE或者UTF-16LE
BLOB 无类型,可用于保存二进制文件
存储类别可能比数据类型更加普遍一点,比如 INTEGER存储类别,它包含了6种长度不同的整形数,它们在磁盘上的存储方式有一点差别,但当它们被读入内存进行处理的时候,将会被转换为更加普遍的数据类型(8字节有符号数)。所以,大多数时候,“存储类别”和“数据类型”有一些不易觉察的差别,而且他们也能够被交换使用。 SQLite3数据库(SQLite version 3 database)中除了被声明为主键的INTEGER类型的列外,任何列都能够存储属于任一存储类型的数值。 SQL语句中的任何数值,无论它们是被嵌入到SQL语句中的字面值,还是被绑定到预编译过的SQL语句中的参数 1.1 布尔值 TEXT 遵循ISO8601 字符串("YYYY-MM-DD HH:MMSS:SSS")
REAL 按照公历,从现在到格林威治时间的 November 24 B.C
INTEGER 按照Unix系统时间,从1970-01-01 00:00:00 UTC 到现在的秒数
应用程序能够在这中间选择任意格式来表示时间日期,并且使用内置的时间日期函数在这几种格式之间自由的转换。 2.0 类型亲和性 TEXT
NUMERIC
INTEGER
REAL
NONE
具有 TEXT 亲和性的列使用 NULL,TEXT 或者 BLOB存储类别来存储数据,如果数字值(Numeric data)被插入到具有 TEXT 亲和性的列中, 在存储前,它会被转换成文本 2.1 列的类型亲和性的决定 列的亲和性由这一列被声明的类型来决定,它遵从以下顺序规则: 1. 如果声明的类型中含有字符串“INT”,它将具有 INTEGER 亲和性 2. 如果列的类型声明中含有“CHAR”,“CLOB”或者“TEXT”中的任意一个,这一列将具有 TEXT 亲和性。比如 VARCHAR 类型 含有字符串“CHAR”,因此被指定 TEXT 亲和性。 3. 如果列的类型声明中含有字符串“BLOB”或者没有声明类型,它将具有 NULL 亲和性 4. 如果列的类型声明中含有“REAL”,“FLOA”,“DOUB”中的任意一个,它将具有 REAL 亲和性 5. 其他的将具有 NUMERIC 亲和性 记住这些规则的优先级从上到下,如果一个列的类型被声明为“CHARINT”,它将满足规则1和2,但是按照优先级,它将具有 INTEGER 亲和性。 总结: create table scr( name,age );
insert into scr values( "duwei",20 );
insert into scr values( 20,"youhongtao");
select * from scr;
duwei | 20
20 | youhongtao
但是为了代码的可阅读性以及兼容其他数据库引擎,不建议缺省列的类型声明。 因为列声明的类型不决定存储在其中的数据的类型,它主要用于兼容其它的数据库引擎以及决定列的 类型亲和性,便于程序阅读。 列的类型亲和性主要决定了存储数据时的转换动作。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |