PLSQL经常使用函数(ORACLE)(2)

---------------------------------------------------------------------------------------------------------- 一、Dateadd   在向指定日期加上一段时间的基础上,返回新的   datetime   值。      语法 :DATEADD(datepart,number,date)        参数   datepart      是规定应向日期的哪一部分返回新值的参数。下表列出了识别的日期部分和缩写。      日期部分   缩写        Year   yy,   yyyy        quarter   qq,   q        Month   mm,   m        dayofyear   dy,   y        Day   dd,   d        Week   wk,   ww        Hour   hh        minute   mi,  n         second   ss,   s        millisecond   ms                  number        是用来增长datepart的值。若是指定一个不是整数的值,则将废弃此值的小数部分。   例如,若是为datepart指定day,为number指定1.75,则date将增长1。           date       是返回datetime或smalldatetime值或日期格式字符串的表达式。有关指定日期的更多信息,请参见datetime和smalldatetime。      若是您只指定nian份的最后两位数字,则小于或等于"两位数nian份截止期"配置选项的值的最后两位数字的数字所在世纪与截止nian所   在世纪相同。大于该选项的值的最后两位数字的数字所在世纪为截止nian所在世纪的前一个世纪。   例如,若是two  digit year cutoff 为 2049(默认),则 49 被解释为 2049,2050 被解释为 1950。   为避免模糊,请使用四位数的nian份。           返回类型      返回   datetime,但若是   date   参数是   smalldatetime,返回   smalldatetime。     二、DATEDIFF     返回跨两个指定日期的日期和时间边界数。     1、 语法     DATEDIFF ( datepart , startdate , enddate )     2、参数     datepart     是规定了应在日期的哪一部分计算差额的参数。下表列出了 Microsoft? SQL Server? 识别的日期部分和缩写。     日期部分 缩写     year yy, yyyy     quarter qq, q     Month mm, m     dayofyear dy, y     Day dd, d     Week wk, ww     Hour hh     minute mi, n     second ss, s     millisecond ms         startdate     是计算的开始日期。startdate 是返回 datetime 或 smalldatetime 值或日期格式字符串的表达式。     由于 smalldatetime 只精确到分钟,因此当用 smalldatetime 值时,秒和毫秒老是 0。     若是您只指定nian份的最后两位数字,则小于或等于"两位数nian份截止期"配置选项的值的最后两位数字的数字所在世纪与截止nian所在世纪相同。大于该选项的值的最后两位数字的数字所在世纪为截止nian所在世纪的前一个世纪。例如,若是 two digit year cutoff 为 2049(默认),则 49 被解释为 2049,2050 被解释为 1950。为避免模糊,请使用四位数的nian份。          enddate     是计算的终止日期。enddate 是返回 datetime 或 smalldatetime 值或日期格式字符串的表达式。          3、返回类型     integer     4、用法     此函数计算两个指定日期之间日期部分的数目。结果为日期部分中等于(date2 - date1)的有符号的整数值。     当结果不是日期部分的偶数倍时,DATEDIFF 将被截断而不是被舍入。     当使用 day 做为日期部分时,DATEDIFF 返回两个指定的时间之间(包括第二个日期但不包括第一个日期)的午夜数。     当使用 month 做为日期部分时,DATEDIFF 返回两个日期之间(包括第二个日期但不包括第一个日期)出现的月的第一天的数目。     当使用 week 做为日期部分时,DATEDIFF 返回两个日期(包括第二个日期但不包括第一个日期)之间星期日的数目。     对于更小的时间单位存在溢出值: milliseconds    24 天  seconds    68 nian  minutes    4083 nian  others    没有溢出限制  若是超出这些限制,此函数将返回溢出错误。     5、标准和兼容性 SQL/92    Transact-SQL 扩展。 SQL/99    Transact-SQL 扩展。 Sybase    与 Adaptive Server Enterprise 兼容。    6、示例     下面的语句返回 1:      select datediff( hour, ''4:00am'', ''5:50am'' )     下面的语句返回 102:     select datediff( month, ''1987/05/02'', ''1995/11/15'' )     下面的语句返回 0:     select datediff( day, ''00:00'', ''23:59'' )     下面的语句返回 4:      select datediff( day, ''1999/07/19 00:00'',''1999/07/23 23:59'' )     下面的语句返回 0:     select datediff( month, ''1999/07/19'', ''1999/07/23'' )     下面的语句返回 1:     select datediff( month, ''1999/07/19'', ''1999/08/23'' )   三、decode函数   decode(条件,值1,翻译值1,值2,翻译值2,...值n,翻译值n,缺省值)      该函数的含义以下:      IF 条件=值1 THEN   RETURN(翻译值1)   ELSIF 条件=值2 THEN   RETURN(翻译值2)   ......   ELSIF 条件=值n THEN   RETURN(翻译值n)      ELSE   RETURN(缺省值)   END IF      ·使用方法:      一、比较大小      select decode(sign(变量1-变量2),-1,变量1,变量2) from dual; --取较小值   sign()函数根据某个值是0、正数仍是负数,分别返回0、一、-1      例如:   变量1=10,变量2=20   则sign(变量1-变量2)返回-1,decode解码结果为“变量1”,达到了取较小值的目的。      二、表、视图结构转化      现有一个商品销售表sale,表结构为:      month    char(6)      --月份   sell    number(10,2)   --月销售金额      现有数据为:      200001  1000   200002  1100   200003  1200   200004  1300   200005  1400   200006  1500   200007  1600   200101  1100   200202  1200   200301  1300      想要转化为如下结构的数据:      year   char(4)      --nian份   month1  number(10,2)   --1月销售金额   month2  number(10,2)   --2月销售金额   month3  number(10,2)   --3月销售金额   month4  number(10,2)   --4月销售金额   month5  number(10,2)   --5月销售金额   month6  number(10,2)   --6月销售金额   month7  number(10,2)   --7月销售金额   month8  number(10,2)   --8月销售金额   month9  number(10,2)   --9月销售金额   month10  number(10,2)   --10月销售金额   month11  number(10,2)   --11月销售金额   month12  number(10,2)   --12月销售金额      结构转化的SQL语句为:      create or replace view   v_sale(year,month1,month2,month3,month4,month5,month6,      month7,month8,month9,month10,month11,month12)   as   select   substrb(month,1,4),   sum(decode(substrb(month,5,2),'01',sell,0)),   sum(decode(substrb(month,5,2),'02',sell,0)),   sum(decode(substrb(month,5,2),'03',sell,0)),   sum(decode(substrb(month,5,2),'04',sell,0)),   sum(decode(substrb(month,5,2),'05',sell,0)),   sum(decode(substrb(month,5,2),'06',sell,0)),   sum(decode(substrb(month,5,2),'07',sell,0)),   sum(decode(substrb(month,5,2),'08',sell,0)),   sum(decode(substrb(month,5,2),'09',sell,0)),   sum(decode(substrb(month,5,2),'10',sell,0)),   sum(decode(substrb(month,5,2),'11',sell,0)),   sum(decode(substrb(month,5,2),'12',sell,0))   from sale   group by substrb(month,1,4); 四、CAST和CONVERT  将某种数据类型的表达式显式转换为另外一种数据类型。CAST 和 CONVERT 提供类似的功能。  语法  使用 CAST:  CAST ( expression AS data_type )  使用 CONVERT:  CONVERT (data_type[(length)], expression [, style])  参数  expression  是任何有效的 Microsoft? SQL Server? 表达式。有关更多信息,请参见表达式。  data_type  目标系统所提供的数据类型,包括 bigint 和 sql_variant。不能使用用户定义的数据类型。有关可用的数据类型的更多信息,请参见数据类型。  length  nchar、nvarchar、char、varchar、binary 或 varbinary 数据类型的可选参数。    style  日期格式样式,借以将 datetime 或 smalldatetime 数据转换为字符数据(nchar、nvarchar、char、varchar、nchar 或 nvarchar 数据类型);或者字符串格式样式,借以将 float、real、money 或 smallmoney 数据转换为字符数据(nchar、nvarchar、char、varchar、nchar 或 nvarchar 数据类型)。    SQL Server 支持使用科威特算法的阿拉伯样式中的数据格式。    在表中,左侧的两列表示将 datetime 或 smalldatetime 转换为字符数据的 style 值。给 style 值加 100,可得到包括世纪数位的四位nian份 (yyyy)。    不带世纪数位 (yy) 带世纪数位 (yyyy)   标准   输入/输出**   - 0 或 100 (*) 默认值 mon dd yyyy hh:miAM(或 PM)   1 101 美国 mm/dd/yyyy   2 102 ANSI yy.mm.dd   3 103 英国/法国 dd/mm/yy   4 104 德国 dd.mm.yy   5 105 意大利 dd-mm-yy   6 106 - dd mon yy   7 107 - mon dd, yy   8 108 - hh:mm:ss   - 9 或 109 (*) 默认值 + 毫秒 mon dd yyyy hh:mi:ss:mmmAM(或 PM)   10 110 美国 mm-dd-yy   11 111 日本 yy/mm/dd   12 112 ISO yymmdd   - 13 或 113 (*) 欧洲默认值 + 毫秒 dd mon yyyy hh:mm:ss:mmm(24h)   14 114 - hh:mi:ss:mmm(24h)   - 20 或 120 (*) ODBC 规范 yyyy-mm-dd hh:mm:ss[.fff]   - 21 或 121 (*) ODBC 规范(带毫秒) yyyy-mm-dd hh:mm:ss[.fff]   - 126(***) ISO8601 yyyy-mm-dd Thh:mm:ss:mmm(不含空格)   - 130* 科威特 dd mon yyyy hh:mi:ss:mmmAM   - 131* 科威特 dd/mm/yy hh:mi:ss:mmmAM      *    默认值(style 0 或 100、9 或 10九、13 或 11三、20 或 120、21 或 121)始终返回世纪数位 (yyyy)。  ** 当转换为 datetime 时输入;当转换为字符数据时输出。  *** 专门用于 XML。对于从 datetime 或 smalldatetime 到 character 数据的转换,输出格式如表中所示。对于从 float、money 或 smallmoney 到 character 数据的转换,输出等同于 style 2。对于从 real 到 character 数据的转换,输出等同于 style 1。        重要 默认状况下,SQL Server 根据截止nian份 2049 解释两位数字的nian份。即,两位数字的nian份 49 被解释为 2049,而两位数字的nian份 50 被解释为 1950。许多客户端应用程序(例如那些基于 OLE 自动化对象的客户端应用程序)都使用 2030 做为截止nian份。SQL Server 提供一个配置选项("两位数字的截止nian份"),借以更改 SQL Server 所使用的截止nian份并对日期进行一致性处理。然而最安全的办法是指定四位数字nian份。      当从 smalldatetime 转换为字符数据时,包含秒或毫秒的样式将在这些位置上显示零。当从 datetime 或 smalldatetime 值进行转换时,能够经过使用适当的 char 或 varchar 数据类型长度来截断不须要的日期部分。    下表显示了从 float 或 real 转换为字符数据时的 style 值。    值 输出   0(默认值) 最大为 6 位数。根据须要使用科学记数法。   1 始终为 8 位值。始终使用科学记数法。   2 始终为 16 位值。始终使用科学记数法。      在下表中,左列表示从 money 或 smallmoney 转换为字符数据时的 style 值。    值 输出   0(默认值) 小数点左侧每三位数字之间不以逗号分隔,小数点右侧取两位数,例如 4235.98。   1 小数点左侧每三位数字之间以逗号分隔,小数点右侧取两位数,例如 3,510.92。   2 小数点左侧每三位数字之间不以逗号分隔,小数点右侧取四位数,例如 4235.9819。       返回类型  返回与 data type 0 相同的值。       五、CHARINDEX函数     返回字符或者字符串在另外一个字符串中的起始位置。CHARINDEX函数调用方法以下:         CHARINDEX ( expression1 , expression2 [ , start_location ] )        Expression1是要到expression2中寻找的字符中,start_location是CHARINDEX函数开始在expression2中找expression1的位置。        CHARINDEX函数返回一个整数,返回的整数是要找的字符串在被找的字符串中的位置。假如CHARINDEX没有找到要找的字符串,那么函数整数“0”。让咱们看看下面的函数命令执行的结果:       CHARINDEX('SQL', 'Microsoft SQL Server')       这个函数命令将返回在“Microsoft SQL Server”中“SQL”的起始位置,在这个例子中,CHARINDEX函数将返回“S”在“Microsoft SQL Server”中的位置11。      接下来,咱们看这个CHARINDEX命令:       CHARINDEX('7.0', 'Microsoft SQL Server 2000')       在这个例子中,CHARINDEX返回零,由于字符串“7.0” 不能在“Microsoft SQL Server”中被找到。接下来经过两个例子来看看如何使用CHARINDEX函数来解决实际的T-SQL问题。 六、DATEPART  返回表明指定日期的指定日期部分的整数。    语法  DATEPART ( datepart ,date )     参数  datepart    是指定应返回的日期部分的参数。下表列出了 Microsoft? SQL Server? 识别的日期部分和缩写。    日期部分 缩写   year yy, yyyy   quarter qq, q   month mm, m   dayofyear dy, y   day dd, d   week wk, ww   weekday dw   Hour hh   minute mi, n   second ss, s   millisecond ms        week (wk, ww) 日期部分反映对 SET DATEFIRST 做的更改。任何一      的 1 月 1 日定义了 week 日期部分的开始数字,例如:DATEPART(wk, 'Jan 1, xxxx') = 1,此处 xxxx 表明任一nian。    weekday (dw) 日期部分返回对应于星期中的某天的数,例如:Sunday = 一、Saturday = 7。weekday 日期部分产生的数取决于 SET DATEFIRST 设定的值,此命令设定星期中的第一天。    date    是返回 datetime 或 smalldatetime 值或日期格式字符串的表达式。对 1753 nian 1 月 1 日以后的日期用datetime 数据类型。更早的日期存储为字符数据。当输入 datetime 值时,始终将其放入引号中。由于 smalldatetime 只精确到分钟,因此当用 smalldatetime 值时,秒和毫秒老是 0。    若是只指定nian份的最后两位数字,则小于或等于"两位数nian份截止期"配置选项的值的最后两位数字的数字所在世纪与截止nian所在世纪相同。大于该选项的值的最后两位数字的数字所在世纪为截止nian所在世纪的前一个世纪。例如,若是 two digit year cutoff 为 2049 (默认),则 49 被解释为 2049,2050 被解释为 1950。为避免模糊,请使用四位数的nian份。    有关时间值指定的更多信息,请参见时间格式。有关日期指定的更多信息,请参见 datetime 和 smalldatetime。    返回类型  int    注释  DAY、MONTH、和 YEAR 函数分别是 DATEPART(dd, date)、DATEPART(mm, date)、和 DATEPART(yy, date) 的同义词。    示例  GETDATE 函数返回当前日期;然而,比较时并不老是须要完整的日期信息(一般只是对日期的一部分进行比较)。此示例显示 GETDATE 及 DATEPART 的输出。    SELECT GETDATE() AS 'Current Date'  GO    下面是结果集:    Current Date  ---------------------------  Feb 18 1998 11:46PM  SELECT DATEPART(month, GETDATE()) AS 'Month Number'  GO    下面是结果集:    Month Number  ------------  2    此示例假设日期是 5 月 29 日。    SELECT DATEPART(month, GETDATE())  GO    下面是结果集:    -----------  5  (1 row(s) affected)    在此示例中,以数字表示日期。注意:SQL Server 将 0 解释为 01/01/1900。    SELECT DATEPART(m, 0), DATEPART(d, 0), DATEPART(yy, 0)    下面是结果集:    ----- ------ ------  1     1      1900 七、SUBSTRING  功能:返回字符、二进制、文本或图像表达式的一部分  语法:SUBSTRING ( expression, start, length )   SUBSTR(str,pos): 由<str>中,选出全部从第<pos>位置开始的字元。请注意,这个语法不适用于SQL Server上。          SUBSTR(str,pos,len): 由<str>中的第<pos>位置开始,选出接下去的<len>个字元。         SQL 中的 substring 函数是用来抓出一个栏位资料中的其中一部分。这个函数的名称在不一样的资料库中不彻底同样:   MySQL: SUBSTR(), SUBSTRING()   Oracle: SUBSTR()   SQL Server: SUBSTRING()   参数:  expression 字符串、二进制字符串、文本、图像、列或包含列的表达式。请勿使用包含聚合函数的表达式。  start 整数或能够隐式转换为 int 的表达式,指定子字符串的开始位置。  length 整数或能够隐式转换为 int 的表达式,指定子字符串的长度。   返回值:   若是 expression 是一种支持的字符数据类型,则返回字符数据。若是 expression 是一种支持的二进制数据类型,则返回二进制数据。若是 start = 1,则子字符串从表达式的第一个字符开始。   返回字符串的类型与给定表达式的类型相同(下表所示内容除外)。  给定表达式  返回类型    image  varbinary   ntext   nvarchar    八、stuff  stuff的功能:删除指定长度的字符串并在指定的起始点插入另外一组字符  STUFF ( character_expression , start , length , character_expression )   character_expression :操做的字符,  start:删除和插入的起始点,  length:删除的长度,  character_expression :要插入的字符  注:sql的stuff()函数和编程中数组的下标起始位置不同,数组是以0开始的,而 stuff()函数是以 1 开始的。  若是 stuff() 函数以 0 开始的话,它是从expression1_Str 字符串的最后一个字符开始截取。例子以下所示:     例1:stuff('00000000',0,3,'123') --> 对应的结果是: (没有值输出)     例2:stuff('00000000',1,3,'123') --> 对应的结果是:12300000 九、ceiling函数   floor函数      ceiling函数返回大于或等于所给数字表达式的最小整数。  floor函数返回小于或等于所给数字表达式的最大整数。  好比  celling(12.1) 结果为 13  floor(12.1)结果为 12   在介绍这个以前你必须明白什么是oracle中的空值null
相关文章
相关标签/搜索