本文目录
sql创建数据表时列属性有哪些?
使用check约束: CREATE?TABLE? (... ... maxdiscount?tinyint?CHECK?(maxdiscount?between?75?and?100)) ;
sqlsum用在什么数据类型?
sqlsum用在求和的数据类型。
SUM函数用于返回表达式中所有值的和。其语法:
SUM([ALL | DISTINCT] expression)
ALL:对所有的值进行聚合函数运算。ALL是默认设置。
DISTINCT:指定SUM返回惟一值的和。
expression:常量、列或函数,或者是算术、按位与字符串等运算符的任意组合。
在使用SUM函数时,SQL Server把结果集中的smallint或tinyint这些数据类型当做int处理。
在使用SUM函数时,SQL Server将忽略空值(NULL),即计算时不计算这些空值。
tinyint类型数据存储范围?
Tinyint占用1字节的存储空间,即8位(bit)。那么Tinyint的取值范围怎么来的呢?我们先看无符号的情况。无符号的最小值即全部8位(bit)都为0,换算成十进制就是0,所以无符号的Tinyint的最小值为0.无符号的最大值即全部8bit都为1,11111111,换算成十进制就是255.这很好理解。
有符号的Tinyint的取值范围是怎么来的呢?在计算机中,用最高位表示符号。0表示正,1表示负,剩下的表示数值。那么有符号的8bit的最小值就是
1 1 1 1 1 1 1 1=-127
表示负值
最大值:
0 1 1 1 1 1 1 1=+127
表示正值
怎么有符号的最小值是-127,而不是-128呢?这就是本文要说的关键地方了,在计算机中,表示负值是用补码
为什么有符号的TINYINT的最小值是-128?虽然“-0”也是“0”,但根据正、反、补码体系,“-0”的补码和“+0”是不同的,这样就出现两个补码代表一个数值的情况。为了将补码与数字一一对应,所以人为规定“0”一律用“+0”代表。同时为了充分利用资源,就将原来本应该表示“-0”的补码规定为代表-128。
tinyint是浮点类型么?
tinyint属于16位整型,不是浮点类型
什么是整型字段?
整型分类:
TINYINT
超出范围只存最大可接受值, 或报错
SMALLINT
MEDIUMINT
INT
BIGINT
注意:
整型都是默认带符号
针对整型,宽度作用: 只有整型括号里面的数字不是限制存储,表示限制位数
id int(8)
如果数字没有超过8位,那么默认用空格填充至8位
如果数字超过了8位,那么有几位就存几位(但是要遵守最大范围)
zerofill 用0填充至8位
总结:
针对整型字段 括号内无需指定宽度 因为默认的宽度足够显示所有数据