SQLite的数据类型总结

news/2024/7/7 19:11:36

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

一般数据采用的固定的静态数据类型,而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。


转载于:https://my.oschina.net/carbenson/blog/510582


http://lihuaxi.xjx100.cn/news/286919.html

相关文章

关于NameError: name ‘sns‘ is not defined->ModuleNotFoundError: No module named ‘seaborn‘错误提示

添加:import seaborn as sns 添加这句之后又出现这个错误: 2.ModuleNotFoundError: No module named seaborn 下载seaborn: 方法一:Anaconda Prompt->activate tensorflow (创建tensorflow环境)->输入: pip inst…

Codeforces Round #672 (Div. 2)D. Rescue Nibel![扫描线解决区间问题]

题目链接 题目大意:就是给你n个区间,从中选出k个区间,这k个区间共同覆盖了同一个点,问有多少种选法?结果mod 998244353 解题思路:1.首先我们可以这么想:我们把区间左端点赋值为1,右端…

解读算法「时间」与「空间」复杂度——冰与火之歌

作者 | 程序员小吴来源 | 五分钟学算法算法(Algorithm)是指用来操作数据、解决程序问题的一组方法。对于同一个问题,使用不同的算法,也许最终得到的结果是一样的,比如排序就有前面的十大经典排序和几种奇葩排序&#x…

关于NameError: name ‘train_test_split‘ is not defined错误提示

添加:from sklearn.model_selection import train_test_split

用Python偷偷告诉你国庆8亿人都去哪儿浪?

2019 年国庆到来啦!今年想着来点新花样吧那去哪里玩人少 big 还高呢?一、目标使用 Python 分析出国庆哪些旅游景点:好玩、便宜、人还少的地方,不然拍照都要抢着拍!二、获取数据既然做数据分析肯定要先搞到数据&#xf…

android ORM框架LitePal 封装SQLite

LitePal的基本用法 虽说LitePal宣称是近乎零配置,但也只是“近乎”而已,它还是需要进行一些简单配置才可以使用的,那么我们第一步就先快速学习一下LitePal的配置方法。 快速配置 1. 引入Jar包或源码 首先我们需要将LitePal的jar包引入到项目当…

python 测试linux dev文件,Linux测试开发人员要掌握的Linux命令有哪些?

今天小编要跟大家分享的文章是关于Linux测试开发人员要掌握的学习Linux和一、文件和目录相关文件和目录相关1、进入目录——cd cd /usr/local //进入/usr/local这个目录2、查看当前目录下所有的文件和目录——lsls -al //显示当前目录下所有的文件和目录,包含隐藏文…

HDU1301(最小生成树)

题意:将所有的村庄链接在一起,并且要求总的公路系统成本最低,所以很容易想到构造最小生成树: 输入的意思是:给出n代表村庄的数量,然后下面给出n-1行;每一行在行首给出一个村庄的和一个数字&…