oracle学习笔记三

函数
  字符函数
     字符串大小写转换
 LOWER (strexp)  返回字符串,并将所有的字符小写
 UPPER (strexp)  返回字符串,并将所有的字符大写 
 INITCAP(strexp) 将字符串的(每个单词的)第一个字母变为大写,后面的小写
     字符处理函数
1、CONCAT(strexp, strexp):  连接两个字符串 
2、Substr(str,start_index,length) :从指定的位置截取指定长度的字符串 
3、LENGTH(strexp):返回字符串的长度 
4、LPAD( string1, padded_length, [ pad_string ] )   在列的左边粘贴字符
     其中string1    是需要粘贴字符的字符串       
     padded_length  是返回的字符串的数量,如果这个数量比原字符串的长度要短,
                    lpad函数将会把字符串截取成padded_length;  
     pad_string     是个可选参数,这个字符串是要粘贴到string1的左边,如果这个参数未写,
                    lpad函数将会在string1的左边粘贴空格。 
5、RPAD(粘贴字符)    RPAD  在列的右边粘贴字符


Trim():截取字符串两端特殊字符
replace(str,search_str[,replace_str]):将每次在str中出现的search_str用replace_str替换 
*  数字函数
     Round:传回一个数值,该数值是按照指定的小数位数进行四舍五入运算的结果。
        ROUND( number, decimal_places )
               number : 需四舍五入处理的数值,
               decimal_places : 四舍五入 , 小数取几位 ( 预设为 0 )




    TRUNC:  函数返回处理后的数值,其工作机制与ROUND函数极为类似,
            只是该函数不对指定小数前或后的部分做相应舍入选择处理,而统统截去。
            
mod(number1,number2) 两个数值相除并返回其余数。运算符执行 number1 除以 number2 操作 


* 日期函数


MONTHS_BETWEEN(date2,date1)    两日期相差多少月
Add_months(date1,number)       加月份到日期得到新的日期
NEXT_DAY(date,'day')           给出日期date和星期x之后计算下一个星期的日期 

Last_day(date1)                计算指定日期所在月份的最后一天的日期



转换函数


TO_CHAR(date, ‘fmt’) :  是字符类型的函数,转化日期为字符
TO_CHAR(number, ‘fmt’): 是字符类型的函数,转化数字为字符
TO_NUMBER(char [, 'fmt'])) 使用TO_NUMBER函数将字符转换为数字
TO_DATE(char[, 'fmt'])     使用TO_DATE函数将字符转换为日期


其它函数
NVL (expr1, expr2)          将空值转换为替换的值
NVL2 (expr1, expr2, expr3)  如果expr0不为Null,返回expr1,
                            为Null,返回expr2.  
NULLIF (expr1, expr2)       比较两个表达式,如果相等返回空值,
                            如果不等返回第一个表达式。
COALESCE (expr1, expr2, ..., exprn)返回表达式列表里的第一个非空表达式的值,表达式列表可以包含很多表达式,当第一个满足值非空时,返回这个表达式的值


分组函数
AVG ([DISTINCT|ALL]n)计算平均值
COUNT({ *|[DISTINCT|ALL]expr})返回所有符合条件并且字段值非空的记录
MAX ([DISTINCT|ALL]expr)计算最大值
MIN ([DISTINCT|ALL]expr)计算最小值
SUM ([DISTINCT|ALL]n)计算总和



posted @ 2012-09-06 18:48  retacn_yue  阅读(115)  评论(0编辑  收藏  举报