int、bigint、smallint 和 tinyint
来源:互联网 发布:安卓系统软件 知乎 编辑:程序博客网 时间:2024/05/20 11:51
int、bigint、smallint 和 tinyint
使用整数数据的精确数字数据类型。
bigint
从 -2^63 (-9223372036854775808) 到 2^63-1 (9223372036854775807) 的整型数据(所有数字)。存储大小为 8 个字节。
int
从 -2^31 (-2,147,483,648) 到 2^31 - 1 (2,147,483,647) 的整型数据(所有数字)。存储大小为 4 个字节。int 的 SQL-92 同义字为 integer。
smallint
从 -2^15 (-32,768) 到 2^15 - 1 (32,767) 的整型数据。存储大小为 2 个字节。
tinyint
从 0 到 255 的整型数据。存储大小为 1 字节。
注释
在支持整数值的地方支持 bigint 数据类型。但是,bigint 用于某些特殊的情况,当整数值超过 int 数据类型支持的范围时,就可以采用 bigint。在 SQL Server 中,int 数据类型是主要的整数数据类型。
在数据类型优先次序表中,bigint 位于 smallmoney 和 int 之间。
只有当参数表达式是 bigint 数据类型时,函数才返回 bigint。SQL Server 不会自动将其它整数数据类型(tinyint、smallint 和 int)提升为 bigint。
总结----------------------------
所以手机号码11位大概是2的34次方,所以用int不合适了,
所以要用bigint,
int类型最多也就是10位数字
但是一般手机号码都是用varchart
关于char 和varchart
区别:
1.CHAR的长度是固定的,而VARCHAR2的长度是可以变化的, 比如,存储字符串“abc",对于CHAR (10),表示你存储的字符将占10个字节(包括7个空字符),而同样的VARCHAR2 (10)则只占用3个字节的长度,10只是最大值,当你存储的字符小于10时,按实际长度存储。
2.CHAR的效率比VARCHAR2的效率稍高。
3.目前VARCHAR是VARCHAR2的同义词。工业标准的VARCHAR类型可以存储空字符串,但是oracle不这样做,尽管它保留以后这样做的权利。Oracle自己开发了一个数据类型VARCHAR2,这个类型不是一个标准的VARCHAR,它将在数据库中varchar列可以存储空字符串的特性改为存储NULL值。如果你想有向后兼容的能力,Oracle建议使用VARCHAR2而不是VARCHAR。
何时该用CHAR,何时该用varchar2?
CHAR与VARCHAR2是一对矛盾的统一体,两者是互补的关系.
VARCHAR2比CHAR节省空间,在效率上比CHAR会稍微差一些,即要想获得效率,就必须牺牲一定的空间,这也就是我们在数据库设计上常说的‘以空间换效率’。
VARCHAR2虽然比CHAR节省空间,但是如果一个VARCHAR2列经常被修改,而且每次被修改的数据的长度不同,这会引起‘行迁移’(Row Migration)现象,而这造成多余的I/O,是数据库设计和调整中要尽力避免的,在这种情况下用CHAR代替VARCHAR2会更好一些。
VARCHAR2与VARCHAR的区别
二者的区别如下:
1,varchar2把所有字符都占两字节处理(一般情况下),varchar只对汉字和全角等字符占两字节,数字,英文字符等都是一个字节;
2,VARCHAR2把空串等同于null处理,而varchar仍按照空串处理;
3,VARCHAR2字符要用几个字节存储,要看数据库使用的字符集。
总结:用Unicode编码的字符串,结果是字符的整数值
- int、bigint、smallint 和 tinyint
- int、bigint、smallint 和 tinyint
- int、bigint、smallint 和 tinyint
- int、bigint、smallint 和 tinyint
- int、bigint、smallint 和 tinyint
- int、bigint、smallint 和 tinyint
- bigint,int,smallint,tinyint
- bigint ,int ,smallint,tinyint
- int、bigint、smallint 和 tinyint 区别
- int、bigint、smallint 和 tinyint范围
- int、bigint、smallint 和 tinyint (Transact-SQL)
- int、bigint、smallint 和 tinyint范围
- mysql int,bigint,smallint和tinyint理解
- int、bigint、smallint 和 tinyint范围
- int、bigint、smallint和tinyint范围
- int,bigint,smallint、tinyint、varchar
- MySQL tinyint/smallint/int/bigint
- 数据类型int、bigint、smallint 和 tinyint范围(sqlserver)
- asp.net 前后台之间数据的绑定
- 【CodeForces】557A - Ilya and Diplomas(水)
- easyui中datagrid 部分参数说明
- footer元素
- 解决Microsoft Visual Studio F6不能重新生成解决方案问题,附图文。
- int、bigint、smallint 和 tinyint
- PHP安全
- Java hashcode函数作用
- ios开发中动画那点事
- 64位Ubuntu配置sdk
- iOS开发 -- 用QLPreviewController查看文档
- OC-RunTime运行时技术的总结具体代码实现
- 弄懂java中”==“、”equals“、”hashcode“
- 每天一个linux命令(2):cd命令