当前位置:首页 » 编程语言 » sql表达数字取值范围
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

sql表达数字取值范围

发布时间: 2022-06-07 05:14:54

sql Server限制输入值的取值范围的是什么

SQL Server限制输入值的取值范围的是用户自己定义的。

CHECK 约束用于限制列中的值的范围。

如果对单个列定义 CHECK 约束,那么该列只允许特定的值。

如果对一个表定义 CHECK 约束,那么此约束会在特定的列中对值进行限制。

撤销 CHECK 约束

如需撤销 CHECK 约束,请使用下面的 SQL:

SQL Server / Oracle / MS Access:

ALTER TABLE Persons

DROP CONSTRAINT chk_Person

MySQL:

ALTER TABLE Persons

DROP CHECK chk_Person

(1)sql表达数字取值范围扩展阅读

check主要用于限定字段值的范围

常见用法举例:

1、重量需大于0,并且小于等于100

WEIGHT NUMERIC(9,2) CHECK(WEIGHT>0 AND WEIGHT<=100

2、性别取‘男’或者‘女’

SSEX CHAR(2) CHECK(SSEX='male' OR SSEX='female')

3、年龄取15-45

SAGE SMALLINT CHECK(SAGE>=15 AND SAGE<=45)

4、学分大于0

SEMSTER SMALLINT CHECK(SEMSTER>0)

❷ MSSQL中Date类型的取值范围

datetime
从 1753 年 1 月 1 日到 9999 年 12 月 31 日的日期和时间数据,精确到百分之三秒(或 3.33 毫秒)。
smalldatetime
从 1900 年 1 月 1 日到 2079 年 6 月 6 日的日期和时间数据,精确到分钟。
楼主要的是不是这个?

❸ SQL Server 里的int型取值范围是多少

SQLServer中int的默认长度是4,即4个32位字节,数据范围从-2^31(-2,147,483,648)到2^31-1(2,147,483,647)用于int的sql-92单词是integer。

在支持整数值的地方支持Int数据类型。但是,在某些特殊情况下不能使用int,当整数值超过int数据类型支持的范围时可以使用bigint。在SQLServer中,int数据类型是主要的整数数据类型。

(3)sql表达数字取值范围扩展阅读:

当转换成int,短整型,非常小的整数或bigint恒定值浮动,真实,小数,或数值数据类型隐式或显式地使用算术运算符(+,-,*,/或%,规则应用在评估精度的数据类型和表达式的结果取决于不同自动参数化查询。

因此,查询中相似的表达式有时会产生不同的结果。如果查询没有自动参数化,则在将常量值转换为指定的数据类型之前,首先将其转换为数值,该数据类型足够精确,可以保存常量的值。例如,常数值1被转换为数值(1,0),而常数值250被转换为数值(3,0)。

❹ SQL语句怎样查询一个范围

SQL方法完成数值区间查询
要求:根据奖金等级表的数值区间,返回奖金对应的等级。

1、链接外部数据:数据--现有链接--浏览更多,在路径中选择数据Excel文件和目标工作表,建立数据链接。

详细步骤参考前面所发的SQL相关文章。

2、编写sql语句。
2.1、使用switch函数,SQL语句为:
select 姓名,奖金,switch(奖金<200,"D级",奖金<300,"C级",奖金<500,"B级",奖金>=500,"A级") as 奖金等级 from [奖金$a1:b11]

switch函数直接判断数值,若数值小于200,返回D级;数值小于300返回C级;数值小于500,返回B级;余下的数值条件要变化为>=500返回A级而不是<=700。

2.2、使用iif函数,SQL语句为:
select 姓名,奖金,iif(奖金<200,"D级",iif(奖金<300,"C级",iif(奖金<500,"B级","A级"))) as 奖金等级 from [奖金$a1:b11]

其基本思路和switch函数相同,类似工作表函数if的嵌套。

2.3、使用betweent...and,SQ语句为:
select a.姓名,a.奖金,b.等级 from [奖金$a1:b11] a,[奖金等级$] b where a.奖金 between b.最小值 and b.最大值

以戴苏明同学为例子,在SQL代码运行的时候,将戴苏明同学的奖金一一和奖金等级表中的数值进行对比,符合区间的就返回区间等级。其他同学亦然。

但是,当奖金超出最大值700的时候就会取不到该条数据。

如刘平的奖金701并不在betweent...and的区间内,返回的结果中没有刘平的数据。

2.4、使用Where比较大小,sql语句为:
select a.姓名,a.奖金,b.等级 from [奖金$a1:b11] a,[奖金等级$] b where a.奖金 >=b.最小值 and a.奖金<=b.最大值

此方法原理和betweent...and一样,当奖金超过最大值700时,数据将有遗漏(刘平)。

当奖金的最大值为700的时候,以上四种方法都得出同样的结果。

当奖金最大值超过700的时候,3、4两个方法将遗漏奖金大于700的数据。

因此,可在设计奖金等级表的时候,可以将最大值700改为一个比较大的数值,使奖金再高也不会超过,则四种方位皆可。

如更改奖金等级表的最大值700为70000,这么大的一个范围,则四种方法都适用。

❺ 怎么计算sql中数据类型的范围

SQL数据类型详解

bit 整型
其值只能是0、1或空值。
这种数据类型用于存储只有两种可能值的数据,如Yes 或No、True 或False 、On
或Off.

int 整型 4个字节
从- 2^31(-2147483648)到2^31 (2147483
647)之间的整数。
存储到数据库的几乎所有数值型的数据都可以用这种数据类型。

smallint 整型 2个字节
smallint 数据类型可以存储从- 2^15(-32768)到2^15(32767)之间的整数。

tinyint 整型 1个字节
tinyint 数据类型能存储从0到255 之间的整数。

numeric 、 decimal 精确数值型

从-1038-1到1038-1的固定精度和范围的数值型数据。
使用这种数据类型时,必须指定范围和精度。
范围是小数点左右所能存储的数字的总位数,精度是小数点右边存储的数字的位数。

money 货币型
这种数据类型能存储从-9220亿到9220 亿之间的数据,精确到货币单位的万分之一。

smallmoney 货币型
这种数据类型能存储从-214748.3648 到214748.3647
之间的数据,精确到货币单位的万分之一。

float 浮点数值型
从-1.79E+308到1.79E+308 之间的任意数。

real 实型
在-3.40E+38到3.40E+38之间的浮点数。

datetime 日期时间型

从1753年1月1日到9999年12月31日间所有的日期和时间数据,精确到三百分之一秒或3.33毫秒。

Smalldatetime 日期时间型
从1900年1月1日到2079年6月6日间的日期和时间,精确到一分钟。

cursor 特殊数据型
它包含一个对游标的引用。这种数据类型用在存储过程中,而且创建表时不能用。

timestamp 特殊数据型

用来创建一个数据库范围内的唯一数码。
一个表中只能有一个timestamp列。每次插入或修改一行时,timestamp列的值都会改变。

Uniqueidentifier 特殊数据型
全局唯一标识符,即GUID。可以使用NEWID
函数或转换一个字符串为唯一标识符来初始化具有唯一标识符的列 .

char 字符型

存储指定长度的定长非统一编码型的数据。当定义一列为此类型时,你必须指定列长。
当你总能知道要存储的数据的长度时,此数据类型很有用。
此数据类型的列宽最大为8000
个字符.

varchar 字符型
用来存储非统一编码型字符数据。与char
型不一样,此数据类型为变长。
当定义一列为该数据类型时,你要指定该列的最大长度。

它与char数据类型最大的区别是,存储的长度不是列长,而是数据的长度.

text 字符型

用来存储大量的非统一编码型字符数据。
这种数据类型最多可以有2^31-1或20亿个双字节字符.

nchar 统一编码字符型

用来存储定长统一编码字符型数据。统一编码用双字节结构来存储每个字符,而不是用单字节(普通文本中的情况)。它允许大量的扩展字符。此数据类型能存储4000种字符,使用的字节空间上增加了一倍.

nvarchar 统一编码字符型
nvarchar
数据类型用作变长的统一编码字符型数据。此数据类型能存储4000种字符,使用的字节空间增加了一倍.

ntext 统一编码字符型
ntext 数据类型用来存储大量的统一编码字符型数据。
这种数据类型能存储2^30
-1或将近10亿个字符,且使用的字节空间增加了一倍

binary 二进制数据类型
binary数据类型用来存储可达8000
字节长的定长的二进制数据。当输入表的内容接近相同的长度时,你应该使用这种数据类型.

varbinary 二进制数据类型
varbinary 数据类型用来存储可达8000
字节长的变长的二进制数据。当输入表的内容大小可变时,你应该使用这种数据类型

image 二进制数据类型
image 数据类型用来存储变长的二进制数据,最大可达2^31-1或大约20亿字节

---------------------------------------------------
(1)二进制数据类型

二进制数据包括 Binary、Varbinary 和 Image
Binary
数据类型既可以是固定长度的(Binary),也可以是变长度的。
Binary[(n)] 是 n 位固定的二进制数据。其中,n 的取值范围是从 1 到
8000。其存储窨的大小是 n + 4 个字节。
Varbinary[(n)] 是 n 位变长度的二进制数据。其中,n 的取值范围是从 1 到
8000。其存储窨的大小是 n + 4个字节,不是n 个字节。
在 Image 数据类型中存储的数据是以位字符串存储的,不是由 SQL Server
解释的,必须由应用程序来解释。例如,应用程序可以使用BMP、TIEF、GIF 和 JPEG 格式把数据存储在 Image 数据类型中。

(2)字符数据类型

字符数据的类型包括 Char,Varchar 和 Text
字符数据是由任何字母、符号和数字任意组合而成的数据。
Varchar
是变长字符数据,其长度不超过 8KB。Char 是定长字符数据,其长度最多为 8KB。超过 8KB 的ASCII 数据可以使用Text数据类型存储。例如,因为
Html 文档全部都是 ASCII 字符,并且在一般情况下长度超过 8KB,所以这些文档可以 Text 数据类型存储在SQL Server 中。

(3)Unicode 数据类型

Unicode 数据类型包括 Nchar,Nvarchar 和Ntext
在 Microsoft SQL Server 中,传统的非
Unicode 数据类型允许使用由特定字符集定义的字符。在 SQL Server安装过程中,允许选择一种字符集。使用 Unicode
数据类型,列中可以存储任何由Unicode 标准定义的字符。在 Unicode
标准中,包括了以各种字符集定义的全部字符。使用Unicode数据类型,所战胜的窨是使用非 Unicode 数据类型所占用的窨大小的两倍。
在 SQL
Server 中,Unicode 数据以 Nchar、Nvarchar 和 Ntext
数据类型存储。使用这种字符类型存储的列可以存储多个字符集中的字符。当列的长度变化时,应该使用Nvarchar 字符类型,这时最多可以存储 4000
个字符。当列的长度固定不变时,应该使用 Nchar 字符类型,同样,这时最多可以存储4000 个字符。当使用 Ntext 数据类型时,该列可以存储多于 4000
个字符。

(4)日期和时间数据类型

日期和时间数据类型包括 Datetime 和
Smalldatetime两种类型
日期和时间数据类型由有效的日期和时间组成。例如,有效的日期和时间数据包括“4/01/98
12:15:00:00:00 PM”和“1:28:29:15:01AM
8/17/98”。前一个数据类型是日期在前,时间在后一个数据类型是霎时间在前,日期在后。在 Microsoft SQL
Server中,日期和时间数据类型包括Datetime 和 Smalldatetime 两种类型时,所存储的日期范围是从 1753 年 1 月 1
日开始,到9999 年12 月 31 日结束(每一个值要求 8 个存储字节)。使用 Smalldatetime 数据类型时,所存储的日期范围是 1900年 1
月 1日 开始,到 2079 年 12 月 31 日结束(每一个值要求 4
个存储字节)。
日期的格式可以设定。设置日期格式的命令如下:
Set DateFormat {format | @format
_var|
其中,format | @format_var 是日期的顺序。有效的参数包括 MDY、DMY、YMD、YDM、MYD 和
DYM。在默认情况下,日期格式为MDY。
例如,当执行 Set DateFormat YMD 之后,日期的格式为年 月 日 形式;当执行 Set
DateFormat DMY 之后,日期的格式为日 月有年 形式

(5)数字数据类型

数字数据只包含数字。数字数据类型包括正数和负数、小数(浮点数)和整数
整数由正整数和负整数组成,例如 39、25、0-2 和 33967。在
Micrsoft SQL Server 中,整数存储的数据类型是 Int,Smallint和 Tinyint。

Int 数据类型存储数据的范围大于 Smallint 数据类型存储数据的范围,而 Smallint 据类型存储数据的范围大于Tinyint
数据类型存储数据的范围。

使用 Int 数据狗昔存储数据的范围是从 -2 147 483 648 到 2 147 483 647(每一个值要求4个字节存储空间)。

使用 Smallint 数据类型时,存储数据的范围从 -32 768 到 32 767(每一个值要求2个字节存储空间)。

使用Tinyint 数据类型时,存储数据的范围是从0 到255(每一个值要求1个字节存储空间)。
精确小娄数据在 SQL Server
中的数据类型是 Decimal 和 Numeric。这种数据所占的存储空间根据该数据的位数后的位数来确定。
在SQL Server
中,近似小数数据的数据类型是 Float 和
Real。例如,三分之一这个分数记作。3333333,当使用近似数据类型时能准确表示。因此,从系统中检索到的数据可能与存储在该列中数据不完全一样。

(6)货币数据表示正的或者负的货币数量 。

在 Microsoft SQL Server 中,货币数据的数据类型是Money 和 Smallmoney
Money数据类型要求 8
个存储字节,Smallmoney 数据类型要求 4 个存储字节。

(7)特殊数据类型

特殊数据类型包括前面没有提过的数据类型。特殊的数据类型有3种,即 Timestamp、Bit 和
Uniqueidentifier。
Timestamp 用于表示SQL Server 活动的先后顺序,以二进投影的格式表示。Timestamp
数据与插入数据或者日期和时间没有关系。
Bit 由 1 或者 0 组成。当表示真或者假、ON 或者 OFF 时,使用 Bit
数据类型。例如,询问是否是每一次访问的客户机请求可以存储在这种数据类型的列中。
Uniqueidentifier 由 16
字节的十六进制数字组成,表示一个全局唯一的。当表的记录行要求唯一时,GUID是非常有用。例如,在客户标识号列使用这种数据类型可以区别不同的客户。

2.用户定义的数据类型

用户定义的数据类型基于在 Microsoft SQL Server
中提供的数据类型。当几个表中必须存储同一种数据类型时,并且为保证这些列有相同的数据类型、长度和可空性时,可以使用用户定义的数据类型。例如,可定义一种称为
postal_code 的数据类型,它基于 Char
数据类型。
当创建用户定义的数据类型时,必须提供三个数:数据类型的名称、所基于的系统数据类型和数据类型的可空性。

(1)创建用户定义的数据类型

创建用户定义的数据类型可以使用 Transact-SQL 语句。系统存储过程 sp_addtype
可以来创建用户定义的数据类型。其语法形式如下:
sp_addtype
{type},[,system_data_bype][,'null_type']
其中,type
是用户定义的数据类型的名称。system_data_type 是系统提供的数据类型,例如 Decimal、Int、Char 等等。 null_type
表示该数据类型是如何处理空值的,必须使用单引号引起来,例如'NULL'、'NOT NULL'或者'NONULL'。
例子:
Use
cust
Exec sp_addtype ssn,'Varchar(11)',"Not Null'
创建一个用户定义的数据类型
ssn,其基于的系统数据类型是变长为11 的字符,不允许空。
例子:
Use cust
Exec sp_addtype
birthday,datetime,'Null'
创建一个用户定义的数据类型 birthday,其基于的系统数据类型是
DateTime,允许空。
例子:
Use master
Exec sp_addtype
telephone,'varchar(24),'Not Null'
Eexc sp_addtype
fax,'varchar(24)','Null'
创建两个数据类型,即 telephone 和 fax

(2)删除用户定义的数据类型

当用户定义的数据类型不需要时,可删除。删除用户定义的数据类型的命令是 sp_droptype {'type'}。
例子:
Use
master
Exec sp_droptype
'ssn'
注意:当表中的列还正在使用用户定义的数据类型时,或者在其上面还绑定有默认或者规则时,这种用户定义的数据类型不能删除。

SQL SERVER的字段类型说明

以下为SQL SERVER7.0以上版本的字段类型说明。SQL SERVER6.5的字段类型说明请参考SQL SERVER提供的说明。

字段类型 描述
bit 0或1的整型数字
int
从-2^31(-2,147,483,648)到2^31(2,147,483,647)的整型数字
smallint
从-2^15(-32,768)到2^15(32,767)的整型数字
tinyint 从0到255的整型数字

decimal 从-10^38到10^38-1的定精度与有效位数的数字
numeric decimal的同义词

money
从-2^63(-922,337,203,685,477.5808)到2^63-1(922,337,203,685,477.5807)的货币数据,最小货币单位千分之十

smallmoney 从-214,748.3648到214,748.3647的货币数据,最小货币单位千分之十

float
从-1.79E+308到1.79E+308可变精度的数字
real 从-3.04E+38到3.04E+38可变精度的数字

datetime 从1753年1月1日到9999年12日31的日期和时间数据,最小时间单位为百分之三秒或3.33毫秒

smalldatetime 从1900年1月1日到2079年6月6日的日期和时间数据,最小时间单位为分钟

timestamp 时间戳,一个数据库宽度的唯一数字
uniqueidentifier 全球唯一标识符GUID

char 定长非Unicode的字符型数据,最大长度为8000
varchar 变长非Unicode的字符型数据,最大长度为8000

text 变长非Unicode的字符型数据,最大长度为2^31-1(2G)

nchar
定长Unicode的字符型数据,最大长度为8000
nvarchar 变长Unicode的字符型数据,最大长度为8000
ntext
变长Unicode的字符型数据,最大长度为2^31-1(2G)

binary 定长二进制数据,最大长度为8000

varbinary 变长二进制数据,最大长度为8000
image 变长二进制数据,最大长度为2^31-1(2G)

-------------------------------------
Bit
1位,值为0或1

Int
Integer
4字节,值为-2^31~2^31-1
Smallint

2字节,值为-2^15~2^15-1
Tinyint
1字节,值为0~255
Decimal (p,s)

数字数据,固定精度为P,宽度为S
Numeric
Money

8字节,存放货币类型,值为-2^63~2^63-1
Small money

4字节,存放货币类型,值为-214748.3648~+214748.3647近似数值数据类型
Float (n)

N在1~24之间,4字节,7位精度
N=1~7为real
N在25~53之间,8字节,15位精度

=8~15为float
Datetime
8字节,描述某天的日期和时刻,值的精确度为1/300秒

Smalldatetime
4字节,描述某天的日期和时刻,精度为分钟
Cursor
对游标的引用

Timestamp
8字节,存放在数据库内唯一的数据
Uniqueidentifier

16字节,存放全局唯一标识(GUID)
Char (n)
非unicode字符串的固定长度,n=1~8000

Character (n)
Varchar (n)
可变长度,非unicode字符串n=1~8000

Char varying(n)
Text
服务器代码页中可变长度非unicode数据。最大长度为2^31-1个字符

Nchar
固定长度unicode字符串n=1~4000
National character (n),

National char(n)
Nvarchar
固定长度unicode字符串n=1~4000
National
character varying(n)
Ntext
可变长度unicode数据,最大长度为2^30-1个字符

National text
Binary (n)
固定长度二进制数据,n在1~8000之间,存储空间为n+4字节

Varbinary (n)
可变长度二进制数据,n=1~8000
Binary varying (n)
Tmage

可变长度二进制数据,大小为0~2^31-1
注意:
1)
对于数值型数据类型,宽度(scale)是指存储在小数点后的数字位数,而精度(precision)是指能存储的包含小数点在内的所有数字位数。

2) money和small money的存储宽度为4。
3) 时间戳列值在每一行更新时系统自动更新,时间戳列不能是关键字或关键字的一部分。

4)
唯一标识数据类型不能使用算术操作符(如+、-等),这种数据类型只能使用相等比较操作。Unicode是所有字符集的一致存储数据的标准。它要使用两倍于非Unicode数据存储的存储空间。

❻ 怎么用sql语句设定取值范围【0-6】

select * from table where 字段 between 0 and 6

❼ sql 取值范围

也就是说下边界不一定是0,可能出现-1000,或者-100000,那么就写一个很小的数,比如 -999999999999,我就不信有比这个还小的。
或者分开写用or连接
select * from wap_shiwu_point_info p where p.isvalid=1 and (p.shiwu_discount_points between 0 and #{userablePoints} or p.shiwu_discount_points <=0)
p.shiwu_discount_points <=0应该是没有问题的吧。
或者把<=分开,分成<和等于,这样可能也能解决问题,无非就是换种写法而已。

❽ SQL如何实现按数据范围查询

SQL里面 像这种字符串存储的数字 可以直接比较大小
select * from table where CPLSH>='000100' and CPLSH<='000300'
多个范围的话就用or,比如
select * from table where (CPLSH>='000100' and CPLSH<='000300') or (CPLSH>='000305' and CPLSH<='000400')
有几个范围加几个范围

❾ 取值:1~6怎么用SQL语言表达

问题表述得不是很清楚,我暂时理解成要取某个字段的值在1~6范围内:
select *
from 表名
where 字段名 between 1 and 6