SQL_SERVER常用函数
- 格式:doc
- 大小:633.50 KB
- 文档页数:39
sqlserve 常用函数
1. `SUM()`: 用于计算指定列的总和。
2. `AVG()`: 用于计算指定列的平均值。
3. `COUNT()`: 用于计算指定列的行数或某个值的出现次数。
4. `MAX()`: 用于找出指定列中的最大值。
5. `MIN()`: 用于找出指定列中的最小值。
6. `GROUP BY`: 用于根据一个或多个列对结果进行分组。
7. `HAVING`: 用于在分组后对结果进行筛选。
8. `JOIN`: 用于将两个或多个表中的数据连接起来。
9. `WHERE`: 用于在查询结果中筛选满足条件的数据。
10. `ORDER BY`: 用于根据一个或多个列对结果进行排序。
11. `DISTINCT`: 用于返回唯一的、不重复的结果集。
12. `SUBSTRING`: 用于从字符串中提取子字符串。
13. `DATEPART`: 用于从日期或时间值中提取部分信息,例如年、月、日等。
14. `ISNULL`: 用于检查一个表达式是否为 NULL。
15. `COALESCE`: 用于替换 NULL 值。
这只是 SQL Server 中一些常用函数的一小部分示例。
SQL Server 还提供了许多其他函数,用于处理字符串、日期、数学计算、聚合等各种操作。
具体使用哪些函数取决于你的具体需求和数据操作。
sqlserver常用函数
SQLServer是一种关系型数据库管理系统,它提供了许多有用的函数来处理数据。
以下是一些常用的SQL Server函数:
1. SUBSTRING函数:用于返回一个字符串的子字符串。
2. LEN函数:用于返回一个字符串的长度。
3. REPLACE函数:用于将字符串中的指定字符或字符串替换为新的字符或字符串。
4. CHARINDEX函数:用于查找一个字符串中的子字符串的位置。
5. UPPER和LOWER函数:用于将字符串转换为大写或小写。
6. CAST和CONVERT函数:用于将一个数据类型转换为另一个数据类型。
7. GETDATE函数:用于返回当前系统日期和时间。
8. DATEPART函数:用于从日期或时间值中提取指定的部分(例如,年、月、日、小时、分钟或秒)。
9. DATEDIFF函数:用于计算两个日期之间的差异。
10. RANK和ROW_NUMBER函数:用于对查询结果进行排名和编号。
这些函数可以极大地方便SQL Server开发人员的工作,使他们能够更轻松地处理和管理数据。
- 1 -。
SQL Server函数大全--聚合函数use pubsgoselect avg(distinct price) --算平均数from titleswhere type='business'gouse pubsgoselect max(ytd_sales) --最大数from titlesgouse pubsgoselect min(ytd_sales) --最小数from titlesgouse pubsgoselect type,sum(price),sum(advance) --求和from titlesgroup by typeorder by typegouse pubsgoselect count(distinct city) --求个数from authorsgouse pubsgoselect stdev(royalty) --返回给定表达式中所有值的统计标准偏差from titlesgouse pubsgoselect stdevp(royalty) --返回表达式中所有制的填充统计标准偏差from titlesgouse pubsgoselect var(royalty) --返回所有值的统计方差from titlesgouse pubsgoselect varp(royalty) --返回所有值的填充的统计方差from titlesgo--数学函数select sin(23.45),atan(1.234),rand(),PI(),sign(-2.34) --其中rand是获得一个随机数--配置函数SELECT @@VERSION --获取当前数据库版本SELECT @@LANGUAGE --当前语言--时间函数select getdate() as 'wawa_getdate' --当前时间select getutcdate() as 'wawa_getutcdate' --获取utc时间select day(getdate()) as 'wawa_day' --取出天select month(getdate()) as 'wawa_month' --取出月select year(getdate()) as 'wawa_year' --取出年select dateadd(d,3,getdate()) as wawa_dateadd --加三天,注意'd'表示天,'m'表示月,'yy'表示年,下面一样select datediff(d,'2004-07-01','2004-07-15') as wawa_datediff --计算两个时间的差select datename(d,'2004-07-15') as wawa_datename --取出时间的某一部分select datepart(d,getdate()) as wawa_datepart --取出时间的某一部分,和上面的那个差不多--字符串函数select ascii(123) as '123',ascii('123') as '"123"',ascii('abc') as '"abc"' --转换成ascii码select char(123),char(321),char(-123) --根据ascii转换成字符select lower('ABC'),lower('Abc'),upper('Abc'),upper('abc') --转换大小写select str(123.45,6,1), str(123.45,2,2) --把数值转换成字符串select ltrim(' "左边没有空格"') --去空格select rtrim('"右边没有空格" ') --去空格select ltrim(rtrim(' "左右都没有空格" ')) --去空格select left('sql server',3),right('sql server',6) --取左或者取右use pubsselect au_lname,substring(au_fname,1,1) --取子串from authorsorder by au_lnameselect charindex('123','abc123def',2) --返回字符串中指定表达式的起始位置select patindex('123','abc123def'),patindex('3%','abc123def') --返回表达式中某模式第一次出现的起始位置select quotename('abc','{'),quotename('abc') --返回由指定字符扩住的字符串select reverse('abc'),reverse('上海') --颠倒字符串顺序select replace('abcdefghicde','cde','xxxx') --返回呗替换了指定子串的字符串select space(5),space(-2)--系统函数select host_name() as 'host_name',host_id() as 'host_id',user_name() as 'user_name',user_id() as 'user_id',db_name() as 'db_name'--变量的定义使用--声明局部变量declare @mycounter intdeclare @last_name varchar(30),@fname varchar(20),@state varchar(2) --一下声明多个变量--给变量赋值use northwindgodeclare @firstnamevariable varchar(20),@regionvariable varchar(30)set @firstnamevariable='anne' --可以用set,也可以用select给变量赋值,微软推荐用set,但select 在选择一个值直接赋值时很有用set @regionvariable ='wa'select lastname,firstname,title --用声明并赋值过的变量构建一个Select语句并查询from employeeswhere firstname= @firstnamevariable or region=@regionvariablego--全局变量select @@version --返回数据库版本select @@error --返回最后的一次脚本错误select @@identity --返回最后的一个自动增长列的id--while,break,continue的使用--首先计算所有数的平均价格,如果低于30的话进入循环让所有的price翻倍,--里面又有个if来判断如果最大的单价还大于50的话,退出循环,否则继续循环,知道最大单价大于50就break出循环,呵呵,--我分析的应该对吧.use pubsgowhile (select avg(price) from titles) <$30beginupdate titlesset price=price*2select max(price) from titlesif(select max(price) from titles) >$50breakelsecontinueprint 'too much for the marker to bear'--事务编程经典例子--begin transaction是开始事务,commit transaction是提交事务,rollback transaction是回滚事务--这个例子是先插入一条记录,如果出现错误的话就回滚事务,也就是取消,并直接return(返回),如果没错的话就commit 提交这个事务了哦--上面的那个return返回可以返回一个整数值,如果这个值是0的话就是执行的时候没出错,如果出错了就是一个负数,--这个return也可以用在存储过程中,可用用exec @return_status= pro_name来获取这个值use pubsgobegin tran mytraninsert into stores(stor_id,stor_name)values('333','my books')goinsert into discounts(discounttype,stor_id,discount)values('清仓甩卖','9999',50.00)if @@error<>0beginrollback tran mytranprint '插入打折记录出错'returnendcommit tran mytran--事务处理的保存点示例--做了事务保存点后可以rollback(回滚)到指定的保存点,不至于所有的操作都不能用use pubsgoselect * from storesbegin transaction testsavetraninsert into stores(stor_id,stor_name)values('1234','W.Z.D Book')save transaction before_insert_data2goinsert into stores(stor_id,stor_name)values('5678','foreat Books')gorollback transaction before_insert_data2select * from stores--存储存储过程use pubsif exists(select name from sysobjects where name= 'proc_calculate_taxes' and type='P')drop procedure proc_calculate_taxescreate procedure proc_calculate_taxes (@p1 smallint=42,@p2 char(1),@p3 varchar(8)='char') asselect *from titles--执行过程EXECUTE PROC_CALCULATE_TAXES @P2='A'。
SQL--Server常用公式与函数整理一、算术运算符SQL*Server*支持基本的算术运算符,如加(+)、减(-)、乘()、除(/)和取余(%)等。
这些运算符可以直接在*SQL*查询中使用,用于数字和日期类型的数据计算。
示例:sqlSELECT*5+3AS加法结果;--输出结果为8SELECT*10-5AS减法结果;--输出结果为5SELECT*32AS乘法结果;--输出结果为6SELECT*10/2AS除法结果;--输出结果为5SELECT*11%2AS取余结果;--输出结果为1二、字符串函数字符串函数主要用于字符串的处理和操作,包括截取、连接、查找、替换、转换等。
常用的字符串函数有:*LEN(string_expression):返回字符串的长度。
*LEFT(string_expression,*number_of_chars):返回字符串最左侧的指定数量的字符。
*RIGHT(string_expression,*number_of_chars):返回字符串最右侧的指定数量的字符。
*SUBSTRING(string_expression,*start,*length):返回字符串的子字符串。
*CHARINDEX(substring,*expression*[,*start_location]):返回子字符串在表达式中的起始位置。
REPLACE(string_expression,*search_string,*replacement_string):在字符串中替换指定的子字符串。
*LOWER(string_expression):将字符串转换为小写。
*UPPER(string_expression):将字符串转换为大写。
示例:sqlSELECT*LEN('Hello*World')*AS*字符串长度;*--*输出结果为*11SELECT*LEFT('Hello*World',*5)*AS*左侧子串;*--*输出结果为*Hello三、日期函数日期函数用于日期和时间的处理和计算,常用的日期函数有:*GETDATE():返回当前日期和时间。
SQL Server 是一种关系型数据库管理系统,广泛应用于企业和个人的数据存储和管理。
在 SQL Server 中,函数是一种非常重要的功能,用于对数据进行处理和计算。
本文将介绍 SQL Server 中常用的函数,包括数学函数、字符串函数、日期时间函数等,并给出相应的示例和用法说明。
一、数学函数1. ABS():返回一个数的绝对值。
示例:SELECT ABS(-10) as Result;结果:102. ROUND():将一个数四舍五入到指定的小数位数。
示例:SELECT ROUND(3.14159, 2) as Result;结果:3.143. POWER():返回给定数的指定次幂。
示例:SELECT POWER(2, 3) as Result;结果:84. CEILING():返回大于或等于指定表达式的最小整数。
示例:SELECT CEILING(3.14) as Result;结果:45. FLOOR():返回小于或等于指定表达式的最大整数。
示例:SELECT FLOOR(3.14) as Result;结果:3二、字符串函数1. LEN():返回指定字符串的长度。
示例:SELECT LEN('Hello') as Result;结果:52. UPPER():将字符串转换为大写字母。
示例:SELECT UPPER('hello') as Result;结果:HELLO3. LOWER():将字符串转换为小写字母。
示例:SELECT LOWER('HELLO') as Result;结果:hello4. LEFT():返回字符串左边指定长度的子串。
示例:SELECT LEFT('Hello', 3) as Result;结果:Hel5. RIGHT():返回字符串右边指定长度的子串。
示例:SELECT RIGHT('Hello', 3) as Result;结果:llo三、日期时间函数1. GETDATE():返回当前的系统日期和时间。
一、.修改查询出来的字段属性①、cast 和convert都是用来将一种数据类型的表达式转换为另一种数据类型的表达式cast一般更容易使用,convert的优点是可以格式化日期和数值.⑴、cast()语句语句形式为:select cast(字段as int) as 自定义字段名from table1查询table1的字段内容并且将数据类型转换为int类型显现出来,重新附一个别名⑵、Convert() 语句⑴语句形式为:select convert(int,字段) as 自定义字段名from table2查询table1的字段内容并且将数据类型转换为int类型显现出来,重新附一个别名⑵语句形式为:select convert(char(10),getdate(),102)获取当前日期,并且格式为yy.mm.dd(最多占10个字节)第三参数如下:日期类型格式10003 19 20084:45PM10103/19/20081022008.03.1910319/03/200810419.03.200810519-03-200810619 03 200810703 19, 200810816:45:0010903 19 20084:45:00:11003-19-20081112008/03/191122008031911319 03 2008 16:45:00:11416:45:00:000②、str()函数--数值转换字符类型函数格式:str(参数1(必填),参数2(选填),参数3(选填))参数1 数值字段,参数2 指定的总长度(包括逗号,小数,整数与空,默认为10),参数3 保留的小数位数转换规则:先看整数部分是否满足转换长度,只要长度值小于整数长度就返回“*”;若长度值大于整数长度,再看小数部分。
小数部分能按要求转换后仍不足转换长度,再在左侧补空格二、对小数值进行取值①、round() 函数--遵循四舍五入保留指定的小数位函数格式:round(参数1,参数2)参数1:数值。
SQLServer常⽤函数及命令1.字符串函数--ascii函数,返回字符串最左侧字符的ascii码值SELECT ASCII('a') AS asciistr--ascii代码转换函数,返回指定ascii值对应的字符SELECT CHAR(97) AS strs--left(c1,n)左⼦串函数,返回字符串c1中从左边开始的n个字符SELECT LEFT('helloworld',4) AS lefts--len(c1)返回字符串c1的字符(⽽不是字节)数,其中不包含尾随空格SELECT LEN('helloworld') AS lens--lower(c1) ⼤写转换为⼩写SELECT LOWER('HELLOWORLD') AS lowers--LTRIM(c1)删除前导空格,返回删除了前导空格的字符串 ltrim()去左边空格(rtrim()右边空格)SELECT LTRIM(' asafas') AS lt--REPLACE(C1,C2,C3) 替换字符函数SELECT REPLACE('ZHESSDF-DFDSS','-','@') AS RE--REPLICATE(C1,N)复制函数,以指定的次数n重复字符串c1SELECT REPLICATE('这是复制函数-',3) AS rep--right(c1,n)右⼦串函数,返回字符串c1中从右边开始的n个字符串SELECT RIGHT('asdfggh',4) AS strs--space(n) 空格函数,返回由n个重复的空格字符串SELECT SPACE(7) AS spaces--str(f,n,m)返回由数值数据f转换来的字符串,字符串的长度有参数n决定,字符串中保留的⼩数位书由M决定SELECT STR(12.1234,9,6) AS strs--SUBSTRING(c1,n1,n2)求⼦串函数,返回字符串c1从n1开始,长度为n2的⼦串SELECT SUBSTRING('mylightshina',4,5)--upper(c1) 转⼤写SELECT UPPER('asdff') AS up--ISNULL('内容',''):判断字符串是否为null,是的话返回‘’2.⽇期函数--时间⽇期SELECT'today''s date is '+CONVERT(VARCHAR(12), GETDATE(),102)AS daSELECT GETDATE() 当前⽇期时间,GETUTCDATE() ut⽇期时间,DATEPART(YEAR, GETDATE()) 年,DATENAME(YEAR, GETDATE()) 年名,DATEPART(MONTH, GETDATE()) ⽉,DATENAME(MONTH, GETDATE()) ⽉份名,DATEPART(DAY, GETDATE()) ⽇,DAY(GETDATE()) ⽇,MONTH(GETDATE()) ⽉,YEAR(GETDATE()) 年,DATEADD(DAY, 5, GETDATE()) 新⽇期,DATEDIFF(DAY, GETDATE(), '2018-12-17') AS⽇期间隔;3.系统函数--转换函数 cast(),convert()SELECT CAST('2018'AS DECIMAL(10, 5)) AS deci,CONVERT(VARCHAR, GETDATE(), 101) AS'101',CONVERT(VARCHAR, GETDATE(), 102) AS'102',CONVERT(VARCHAR, GETDATE(), 103) AS'103',CONVERT(VARCHAR, GETDATE(), 104) AS'104',CONVERT(VARCHAR, GETDATE(), 105) AS'105',CONVERT(VARCHAR, GETDATE(), 106) AS'106',CONVERT(VARCHAR, GETDATE(), 107) AS'107',CONVERT(VARCHAR, GETDATE(), 108) AS'108',CONVERT(VARCHAR, GETDATE(), 109) AS'109',CONVERT(VARCHAR, GETDATE(), 100) AS'100',CONVERT(VARCHAR, GETDATE(), 120) AS'120',CONVERT(VARCHAR, GETDATE(), 121) AS'121',CONVERT(VARCHAR, GETDATE(), 126) AS'126',CONVERT(VARCHAR, GETDATE(), 130) AS'130';--创建uniqueidentifier类型的唯⼀值SELECT NEWID() AS Id--ISNULL(c1,c2)SELECT ISNULL(ParentId,'########'),*FROM dbo.Module--isdate(exp)判断exp是否为有效⽇期SELECT ISDATE('2018-12-11 12:2:1')--ISNUMERIC(c1)判断c1是否是数字,是则返回1,否返回0SELECT ISNUMERIC('1') 是,ISNUMERIC('a') 否4.流程控制语句--begin...end语句块BEGINSELECT*FROM dbo.Role;END;--if...else语句IF1>4SELECT*FROM dbo.Role;ELSESELECT*FROM dbo.FlowInstance;--简单case表达式SELECT CASE ActivityType WHEN2THEN'qqq'ELSE'www'END ss ,*FROM dbo.FlowInstance--搜索case表达式SELECT CASE WHEN ActivityType>2THEN'qqq'ELSE'www'END ss ,*FROM dbo.FlowInstance--waitfor语句WAITFOR DELAY '00:00:03';SELECT*FROM dbo.Role;--在下午⼋点查询输出WAITFOR TIME '20:00:00';SELECT*FROM dbo.Form;--while语句DECLARE@sum INT,@i INT;SET@i=0;SET@sum=0;WHILE@i<=100BEGINSET@i=@i+1;IF ((@i%2) =0)CONTINUE;SET@sum=@sum+@i;IF (@i>50)BREAK;END;PRINT'1-50中的奇数和为'+CONVERT(CHAR(6), @sum);5.sp命令1、数据库:--sp_helpdb:报告有关指定数据库或所有数据库的信息。
sqlserver查询函数用法SQL Server是一种常见的关系型数据库管理系统(RDBMS),它使用结构化查询语言(SQL)来管理和操作数据。
SQL Server提供了许多功能强大的查询函数,可以帮助数据库开发人员更轻松地从数据库中检索和处理数据。
在本文中,我们将一步一步地介绍SQL Server中的一些常见查询函数的用法和示例。
1. 聚合函数聚合函数是一种用于计算数据集合中的总数、平均值、最小值、最大值和总和等统计数据的函数。
SQL Server提供了几种常见的聚合函数,包括SUM、AVG、MIN、MAX和COUNT。
- SUM函数:用于计算某一列的总和。
例如,我们可以使用以下查询来计算销售表中所有订单的总销售额:SELECT SUM(销售额) AS 总销售额FROM 销售表;- AVG函数:用于计算某一列的平均值。
例如,我们可以使用以下查询来计算所有产品的平均价格:SELECT AVG(价格) AS 平均价格FROM 产品表;- MIN函数:用于计算某一列的最小值。
例如,我们可以使用以下查询来查找销售表中最低销售额的订单:SELECT MIN(销售额) AS 最低销售额FROM 销售表;- MAX函数:用于计算某一列的最大值。
例如,我们可以使用以下查询来查找销售表中最高销售额的订单:SELECT MAX(销售额) AS 最高销售额FROM 销售表;- COUNT函数:用于计算某一列的行数。
例如,我们可以使用以下查询来计算产品表中的产品数量:SELECT COUNT(*) AS 产品数量FROM 产品表;2. 字符串函数字符串函数用于处理和操作字符串类型的数据。
SQL Server提供了一些常用的字符串函数,包括CONCAT、SUBSTRING、LEN和UPPER/LOWER。
- CONCAT函数:用于将多个字符串连接在一起。
例如,我们可以使用以下查询来将名字和姓氏连接成一个完整的姓名:SELECT CONCAT(名字, ' ', 姓氏) AS 全名FROM 员工表;- SUBSTRING函数:用于提取字符串的子串。
SQL SERVER常用函数SQL字符串函数一、字符转换函数4、STR()把数值型数据转换为字符型数据。
STR (<float_expression>[,length[, <decimal>]])length 指定返回的字符串的长度,decimal 指定返回的小数位数。
如果没有指定长度,缺省的length 值为10, decimal 缺省值为0。
当length 或者decimal 为负值时,返回NULL;当length 小于小数点左边(包括符号位)的位数时,返回length 个*;先服从length ,再取decimal ;当返回的字符串位数小于length ,左边补足空格。
三、取子串函数3、SUBSTRING()SUBSTRING (<expression>,<starting_ position>,length)返回从字符串左边第starting_ position 个字符起length个字符的部分。
四、字符串比较函数1、CHARINDEX()返回字符串中某个指定的子串出现的开始位置。
CHARINDEX (<’substring_expression’>, <expression>) 其中substring _expression 是所要查找的字符表达式,expression 可为字符串也可为列名表达式。
如果没有发现子串,则返回0 值。
此函数不能用于TEXT 和IMAGE 数据类型。
2、PATINDEX()返回字符串中某个指定的子串出现的开始位置。
PATINDEX (<’%substring _expression%’>, <column_ name>)其中子串表达式前后必须有百分号“%”否则返回值为0。
与CHARINDEX 函数不同的是,PATINDEX函数的子串中可以使用通配符,且此函数可用于CHAR、 VARCHAR 和TEXT 数据类型。
五、字符串操作函数1、QUOTENAME()返回被特定字符括起来的字符串。
QUOTENAME (<’character_expression’>[,quote_ character]) 其中quote_ character标明括字符串所用的字符,缺省值为“[]”。
2、REPLICATE()返回一个重复character_expression 指定次数的字符串。
REPLICATE (character_expression integer_expression) 如果integer_expression 值为负值,则返回NULL 。
3、REVERSE()将指定的字符串的字符排列顺序颠倒。
REVERSE (<character_expression>) 其中character_expression 可以是字符串、常数或一个列的值。
4、REPLACE()返回被替换了指定子串的字符串。
REPLACE (<string_expression1>,<string_expression2>, <string_expression3>)用string_expression3 替换在string_expression1 中的子串string_expression2。
4、SPACE()返回一个有指定长度的空白字符串。
SPACE (<integer_expression>) 如果integer_expression 值为负值,则返回NULL 。
5、STUFF()用另一子串替换字符串指定位置、长度的子串。
STUFF (<character_expression1>, <start_ position>,<length>,<character_expression2>)如果起始位置为负或长度值为负,或者起始位置大于character_expression1 的长度,则返回NULL 值。
如果length 长度大于character_expression1 中 start_ position 以右的长度,则character_expression1 只保留首字符。
六、数据类型转换函数1、CAST()CAST (<expression> AS <data_ type>[ length ])2、CONVERT()CONVERT (<data_ type>[ length ], <expression> [,style])1)data_type为SQL Server系统定义的数据类型,用户自定义的数据类型不能在此使用。
2)length用于指定数据的长度,缺省值为30。
3)把CHAR或VARCHAR类型转换为诸如INT或SAMLLINT这样的INTEGER类型、结果必须是带正号或负号的数值。
4)TEXT类型到CHAR或VARCHAR类型转换最多为8000个字符,即CHAR或VARCHAR数据类型是最大长度。
5)IMAGE类型存储的数据转换到BINARY或VARBINARY类型,最多为8000个字符。
6)把整数值转换为MONEY或SMALLMONEY类型,按定义的国家的货币单位来处理,如人民币、美元、英镑等。
7)BIT类型的转换把非零值转换为1,并仍以BIT类型存储。
8)试图转换到不同长度的数据类型,会截短转换值并在转换值后显示“+”,以标识发生了这种截断。
9)用CONVERT()函数的style 选项能以不同的格式显示日期和时间。
style 是将DATATIME 和SMALLDATETIME 数据转换为字符串时所选用的由SQL Server 系统提供的转换样式编号,不同的样式编号有不同的输出格式。
七、日期函数1、day(date_expression)返回date_expression中的日期值2、month(date_expression)返回date_expression中的月份值3、year(date_expression)返回date_expression中的年份值4、DATEADD()DATEADD (<datepart>, <number>, <date>)返回指定日期date 加上指定的额外日期间隔number 产生的新日期。
5、DATEDIFF()DATEDIFF (<datepart>, <date1>, <date2>)返回两个指定日期在datepart 方面的不同之处,即date2 超过date1的差距值,其结果值是一个带有正负号的整数值。
6、DATENAME()DATENAME (<datepart>, <date>)以字符串的形式返回日期的指定部分此部分。
由datepart 来指定。
7、DATEPART()DATEPART (<datepart>, <date>)以整数值的形式返回日期的指定部分。
此部分由datepart 来指定。
DATEPART (dd, date) 等同于DAY (date)DATEPART (mm, date) 等同于MONTH (date)DATEPART (yy, date) 等同于YEAR (date)8、GETDATE()以DATETIME 的缺省格式返回系统当前的日期和时间1.当前系统日期、时间select getdate()2. dateadd 在向指定日期加上一段时间的基础上,返回新的 datetime 值例如:向日期加上2天select dateadd(day,2,'2004-10-15') --返回:2004-10-17 00:00:00.0003. datediff 返回跨两个指定日期的日期和时间边界数。
select datediff(day,'2004-09-01','2004-09-18') --返回:174. datepart 返回代表指定日期的指定日期部分的整数。
SELECT DATEPART(month, '2004-10-15') --返回 105. datename 返回代表指定日期的指定日期部分的字符串SELECT datename(weekday, '2004-10-15') --返回:星期五6. day(), month(),year() --可以与datepart对照一下select 当前日期=convert(varchar(10),getdate(),120),当前时间=convert(varchar(8),getdate(),114)select datename(dw,'2004-10-15')select 本年第多少周=datename(week,'2004-10-15'),今天是周几=datename(weekday,'2004-10-15')GetDate( ) 返回系统目前的日期与时间- 1 -DateDiff (interval,date1,date2) 以interval 指定的方式,返回date2 与date1两个日期之间的差值date2-date1DateAdd (interval,number,date) 以interval指定的方式,加上number之后的日期DatePart (interval,date) 返回日期date中,interval 指定部分所对应的整数值DateName (interval,date) 返回日期date中,interval 指定部分所对应的字符串名称举例:1.GetDate() 用于sql server :select GetDate()2.DateDiff('s','2005-07-20','2005-7-25 22:56:32')返回值为 514592 秒DateDiff('d','2005-07-20','2005-7-25 22:56:32')返回值为 5 天3.DatePart('w','2005-7-25 22:56:32')返回值为 2 即星期一(周日为1,周六为7)DatePart('d','2005-7-25 22:56:32')返回值为 25即25号DatePart('y','2005-7-25 22:56:32')返回值为 206即这一年中第206天DatePart('yyyy','2005-7-25 22:56:32')返回值为 2005即2005年2. 查询某个日期之间的记录数据:select * from t_business_product where hit_count>1000 and last_date>'2005-02-01'and last_date<='2005-06-05'order by id descgo查询最近一个月内的点击率大于100的记录数据:select * from t_business_product where hit_count>100 anddatediff(Dd,last_date,getdate())<=30 order by id descgo查询最近一周内的点击率大于100的记录数据:select * from t_business_product where hit_count>100 anddatediff(Dw,last_date,getdate())<=7 order by id desc go查询某一年(如2006年)点击率大于300的记录数据:select * from t_business_product where hit_count>300 andDatePart(Yy,last_date)=2006 order by id descgo或select * from t_business_product where hit_count>300 andDatePart(Year,last_date)=2006 order by id descgo3. SQL Server中文版的默认的日期字段datetime格式是yyyy-mm-dd Thh:mm:ss.mmm4. CAST 和 CONVERT将某种数据类型的表达式显式转换为另一种数据类型。