1 字符串连接
 
SQL> select 'abc' || 'def' from dual;
'ABC'|
------
abcdef
2 小写
SQL>select lower('ABC012');
lower
--------
abc012

3 大写
select upper('abc012');

upper
--------
ABC012

4  左补全

 
select lpad('abc', 5, '0');

lpad
-------
00abc

select lpad('abc', 5, '012');

lpad
-------
01abc

 
第3个参数为空时,缺省为space
 
select lpad('abc', 5);

lpad
-------
   abc

select lpad('abc', 5, ' ');

lpad
-------
   abc

 
5  右补全
 
select rpad('abc', 5, '0');

rpad
-------
abc00

select rpad('abc', 5, '012');

rpad
-------
abc01

 
6 左空白删除
select ltrim('          abc');

ltrim
-------
abc
7 右空白删除

 
select ltrim('abc          ');

ltrim
---------------
abc

 
 8 左右空白删除
select trim('          abc          ');

btrim
-------
abc

9 字符串替换
 
SQL> SELECT TRANSLATE('ababab' , 'a' , '1') FROM DUAL;
TRANSL
------
1b1b1b
 
10 取子字符串
 
SQL> select substr('abc012', 3, 2) from dual;
SU
--
c0
 
11 字符串长度
 
SQL> select length('abc012') from dual;
LENGTH('ABC012')
----------------
               6
12  数字转化成字符串
 
SQL> select to_char(123456, '999,999,999,999') from dual;
TO_CHAR(123456,'
----------------
         123,456
 
13 字符串转化为数字
 
SQL> select to_number('123' || '456', '999999999999') from dual;
TO_NUMBER('123'||'456','999999999999')
--------------------------------------
                                123456
SQL> select to_number('123,456', '999,999,999,999') from dual;
TO_NUMBER('123,456','999,999,999,999')
--------------------------------------
                                123456
 
 

#####################################
# 常用的字符和字符串处理类函数
#####################################

# LOWER函数
作用:将字符串转换成为小写字母
示例:
    select firstname,lastname from customers
    where LOWER(lastname) = 'nelson';
# UPPER函数
作用:将字符串转换成为大写字母
示例:
    select firstname,lastname from customers
    where UPPER(lastname) = 'nelson';

# INITCAP函数
作用:将字符串转换成为混合大小写,每一个单词的开始都是一个大写字母,
         其余字符转换成为小写字母。
示例:
    select firstname,lastname from customers
    where UPPER(lastname) = 'nelson';

select initcap(firstname),initcap(lastname) from customers;

# SUBSTR函数
作用:取子串函数
格式:SUBSTR(C,P,L)      其中:C表示字符串,P表示要提取的起始的字符串的位置,
           L表示提取的长度。如果P为负值,表示从字符串的
           最后一位倒着向前取。
示例:
    select distinct substr(zip,1,3)
    from customers;
  
    select distinct substr(zip,1,3),substr(zip,-3,2)
    from customers;

# LENGTH函数
作用:确定要分析的字符串的长度
示例:
    select destinct length(address)
    from customers;

# LPAD函数
作用:用于字符串填充。填充的是字符串左侧的区域。
格式:LPAD(C,L,S)         其中:C表示将要填充的字符串,L表示填充“之后”字符串
            的长度,S表示用于填充的符号或者字符
示例:
    select firstname,LPAD(firstname,12,' ')
    from customers
    where firstname like '%E%';

# RPAD函数
作用:用于字符串填充。填充的是字符串右侧的区域。
格式:RPAD(C,L,S)         其中:C表示将要填充的字符串,L表示填充“之后”字符串
            的长度,S表示用于填充的符号或者字符
示例:
    select firstname,RPAD(firstname,12,' ')
    from customers
    where firstname like '%E%';

# LTRIM函数

# RTRIM函数

# REPLACE函数
作用:用于字符串的替换
格式:REPLACE(C,S,R) 其中:C表示将处理的字符串,S表示想要查找的字符串,R表示
            将要替换的字符串。类似于“查找与替换”功能。
示例:

# CONCAT函数
作用:字符串连接函数    ||

####################################################################
# 数字函数
####################################################################

# ROUND函数
作用:用来将数字字段舍入的指定的精度。
格式:ROUND(N,P)
示例:
    select title,retail,ROUND(RETAIL,1),TRUNC(RETAIL,1)
    from books;

# TRUNC函数
作用:用来将数字字段截断的指定的精度。
格式:ROUND(N,P)
示例:
    select title,retail,ROUND(RETAIL,1),TRUNC(RETAIL,1)
    from books;

####################################################################
# 日期函数
####################################################################

# Oracle的日期函数以DD-MON-YY格式显示日期值,这种格式表示两位的天数,三位的月份简写
    以及两位的年份。
    例如:20-MAR-02
  
# MONTHS_BETWEEN函数
作用:表示两个月之间相差的天数
示例:
    select title,MONTHS_BETWEEN(orderdate,pubdate)
    from books NATURAL JOIN orders NATURAL JOIN orderitems
    where order# = 1009;

# ADD_MONTHS函数
     作用:表示在某个日期之后的时间
示例:
    select title,pubdate,ADD_MONTHS(pubdate,60) "Drop Date"
    from books 
    order by "Drop Date";

# NEXT_DAY函数
作用:
格式:    NEXT_DAY(d,DAY)    其中:d表示开始日期,DAY表示将要确定的一周中的某一天
示例:
    select order#,orderdate,NEXT_DAY(orderdate,7)
    from orders
    where order# = 1010;

# TO_DATE函数
作用:
示例:
    select order#,orderdate,shipdate
    from orders
    where orderdate = to_date('3-31-2003','MM-DD-YYYY');

##### 日期格式元素的值

MONTH    全部写出的月份名称,添加空格,达到9个字符的总宽度 APRIL
    MON    月份名称的三个字母简写       APR
    MM    月份的两位数字值       04
    RM    罗马数字的月份        IV
    D               一周中某一天的数值
    DD     一月中某一天的数值
    DDD             一年中某一天的数值
    DAY             一周中某一天的名称,添加空格,达到9个字符的宽度    Wednesday
    DY    一周中某一天的三个字母简写      WED
    YYYY    显示4位的年份
    YYY、YY、Y      显示年份的最后三位、最后两位或者最后一位
    YEAR            全部写出年份
    B.C. 或者 A.D.

####################################################################
# NVL函数
####################################################################
作用: 可以使用NVL函数来解决对可能包含NULL值的字段执行数学运算时导致的问题。
    在Oracle9i中,NULL值不等于空格或者0。在计算中使用NULL值时,结果是NULL值。
    NVL函数使用一个值来代替现有的NULL值。

select order#,orderdate,shipdate,shipdate-orderdate "Delay"
    from orders;
    在执行上述查询时,有一些列是空白的。请注意!

select order#,orderdate,NVL(shipdate,to_date('07-4-03','DD-MM-YY')),
    NVL(shipdate,to_date('07-4-03','DD-MM-YY'))-orderdate "Delay"
    from orders
    where order# = 1018;

如果shipdate列的值为NULL,就用'07-04-03'替换shipdate的值。

####################################################################
# NVL2函数
####################################################################

作用: NVL2函数是NVL函数的一个变化形式,他允许不同的选项,这取决于是否存在NULL值。
格式: NVL2(x,y,z),其中y表示当x不是NULL时所替换的数据,z表示当x是NULL时所替换的数
    据。这使用户在处理NULL值时更加灵活。

例如:NVL2(commission,salary,salary+commission) 
    表示:如果佣金是NULL,那么工资总额就是工资;如果佣金不是NULL,那么就将工资总额计算为工资加佣金。

select order#,orderdate,NVL2(shipdate,'Shipped','NOT SHIPPED') "Status"
    from orders;

####################################################################
# TO_CHAR函数
####################################################################
作用: 用于将日期和数字转换为格式化的字符串。
格式:

select title,to_char(pubdate,'MONTH    DD ,YYYY') "Publication Date",
    to_char(retail,'$9999.99') "Retail Price"
    from books
    where isbn = 0401140733;

####################################################################
# DECODE函数
####################################################################
作用:
格式:

DECODE是Oracle公司独家提供的功能,它是一个功能很强的函数。它虽然不是SQL的标准,
但对于性能非常有用。到目前,其他的数据库供应商还不能提供类似DECODE的功能,甚至有的
数据库的供应商批评Oracle的SQL不标准。实际上,这种批评有些片面或不够水平。就象有些马    车制造商抱怨亨利。福特的“马车”不标准一样。
在逻辑编程中,经常用到If – Then –Else 进行逻辑判断。在DECODE的语法中,实际上就是这 样的逻辑处理过程。它的语法如下:

DECODE(value, if1, then1,    if2,then2, if3,then3,    . . .    else )

Value 代表某个表的任何类型的任意列或一个通过计算所得的任何结果。当每个value值被测试    ,如果value的值为if1,Decode 函数的结果是then1;如果value等于if2,Decode函数结果是    then2;等等。事实上,可以给出多个if/then 配对。如果value结果不等于给出的任何配对时,    Decode 结果就返回else 。
需要注意的是,这里的if、then及else 都可以是函数或计算表达式。

DECODE实现表的转置

例子:希望将下面的列结果按照列的方式来显示JOB内容:

SQL> select empno,ename,job,sal,deptno from emp
    2    order by deptno,job;

EMPNO ENAME        JOB                SAL       DEPTNO
---------- ---------- --------- ---------- ----------
        7934 MILLER       CLERK             1300           10
        7782 CLARK        MANAGER           2450           10
        7839 KING         PRESIDENT         5000           10
        7788 SCOTT        ANALYST           3000           20
        7369 SMITH        CLERK              800           20
        7876 ADAMS        CLERK             1100           20
        7566 JONES        MANAGER           2975           20
        7938 赵元杰       软件             12345           20
        7698 BLAKE        MANAGER           2850           30
        7499 ALLEN        SALESMAN          1600           30
        7654 MARTIN       SALESMAN          1250           30
        7844 TURNER       SALESMAN          1500           30
        7521 WARD         SALESMAN          1250           30

18 rows selected.

再看下面的查询结果:

SQL> select deptno,job,sum(sal) from emp group by deptno,job;

DEPTNO JOB           SUM(SAL)
---------- --------- ----------
          10 CLERK             1300
          10 MANAGER           2450
          10 PRESIDENT         5000
          20 ANALYST           3000
          20 CLERK             1900
          20 MANAGER           2975
          20 软件             74070
          30 MANAGER           2850
          30 SALESMAN          5600

9 rows selected.

从上面的结果看,如果希望将JOB置换成列的方式,则只要用DECODE将JOB列进行描述即可。创建的视图如下:

create or replace view empv as
select deptno,
sum( decode(job,'ANALYST', sal,0)) ANALYST,
sum( decode(job,'CLERK', sal,0)) CLERK,
sum( decode(job,'MANAGER', sal,0)) MANAGER,
sum( decode(job,'PRESIDENT', sal,0)) PRESIDENT,
sum( decode(job,'SALESMAN', sal,0)) SALESMAN,
sum( decode(job,'软件', sal,0)) 软件
from emp    group by deptno;

具体运行的显示样本如下:
SQL> create or replace view empv as
    2    select deptno,
    3    sum( decode(job,'ANALYST', sal,0)) ANALYST,
    4    sum( decode(job,'CLERK', sal,0)) CLERK,
    5    sum( decode(job,'MANAGER', sal,0)) MANAGER,
    6    sum( decode(job,'PRESIDENT', sal,0)) PRESIDENT,
    7    sum( decode(job,'SALESMAN', sal,0)) SALESMAN,
    8    sum( decode(job,'软件', sal,0)) 软件
    9    from emp    group by deptno;

View created.

SQL> select * from empv;

DEPTNO      ANALYST        CLERK      MANAGER    PRESIDENT     SALESMAN         软件
---------- ---------- ---------- ---------- ---------- ---------- ----------
          10            0         1300         2450         5000            0            0
          20         3000         1900         2975            0            0        74070
          30            0            0         2850            0         5600            0

####################################################################
# SOUNDEX函数
####################################################################

####################################################################
# NESTING函数
####################################################################

####################################################################
# DUAL表
####################################################################

####################################################################
# SUM函数
####################################################################

select sum(retail-cost) "Total Profit"
from orderitems NATURAL JOIN books
where order# = 1007;

####################################################################
# AVG函数
####################################################################

select avg(retail-cost) "Average Profit"
from books
where category = 'COMPUTER';

select to_char(avg(retail-cost),'999.99') "Average Profit"
from books
where category = 'COMPUTER';

####################################################################
# COUNT函数
####################################################################

select count(distinct category) from books;

select distinct count(category) from books;

select count(*) from orders
where shipdate is null;

select count(shipdate) from orders
where shipdate is null;

在COUNT函数中提供的参数是一个*时,存在的所有记录都会计算在内,通过计算整个记录, Count函数不会丢掉NULL值。

####################################################################
# MAX函数
####################################################################

####################################################################
# MIN函数
####################################################################

####################################################################
# GROUP BY子句
####################################################################

select category,to_char(avg(retail-cost),'999.99') Profit
from books
group by category

select customer#,order#,sum(quantity*retail) "Order Total"
from orders NATURAL JOIN orderitems NATURAL JOIN books
group by customer#,order#

####################################################################
# HAVING子句
####################################################################

select category,to_char(avg(retail-cost),'999.99') Profit
from books
group by category
having avg(retail-cost)>15;

select category,to_char(avg(retail-cost),'999.99') Profit
from books
where pubdate>to_date('01-01-02','DD-MM-YY')
group by category
having avg(retail-cost)>15;

按照订单进行分组统计,但是只显示总金额超过100美元的订单。

select customer#,order#,sum(quantity*retail) "Order Total"
from orders NATURAL JOIN orderitems NATURAL JOIN books
group by customer#,order#
having sum(quantity*retail)>100;

####################################################################
# STDDEV函数
####################################################################
作用:
    计算指定字段的标准差。“标准差”计算用来确定一组数字中的单个值与平均值的接近    程度。
示例:
    select category,avg(retail-cost),stddev(retail-cost)
    from books
    group by category;

要想解释标准差计算的数值,必须将它与每一个种类的“平均利润”作比较。例如:查     看上述结果中Cooking种类,图书的平均利润是8.60美元。但是大多数图书都接近这个    平均值,还是大多数图书都之产生1美元的利润,而一本书产生了20美元的利润?
    标准差就是有多少本书位于平均值附近的某个范围之内的统计近似值。

####################################################################
# VARIANCE函数
####################################################################

作用: 用来确定数据在一个组中的分散程度。一组记录的方差是根据指定字段的最大值
    和最小值计算的。
    如果数据值很密集,那么方差就很小;但是如果数据包含极端的值(很大或者很小)
    那么方差就很大。
示例:
    select category,variance(retail-cost),min(retail-cost),max(retail-cost)
    from books
    group by category;

对结果的解释:
    上述查询结果列出了BOOKS表中所有图书的种类、每一个种类的利润方差以及每个种类
    中的最小利润和最大利润(为了进行比较)。与标准差一样,如果一组数据只包含一个      值,那么计算得到的方差是0。但是与标准差不同,方差不是用与源数据相同的单位计    算的。

要想解释VARRANCE函数的结果,必须查看这个值有多大或者多小。例如:Cooking种类    具有比其他种类更小的方差。这意味着Cooking种类中的图书利润更密集(也就是说,    利润没有覆盖更大的范围)。
                  看一下Cooking种类中的图书的最小利润和最大利润,注意,利润范围是2.30美元,
    (9.75.7.45)。另一方面,我们看看Family Life种类。这个种类具有最高方差,如果    比较最小利润和最大利润,那么他的利润范围很大。
    这就警告管理人员,一些书可能产生很小的利润。而其他一些可以产生很大的利润,可    以知道企业的经营数据。

 
 

ORACLE 字符串操作的更多相关文章

  1. Oracle字符串操作[转:http://www.cnblogs.com/xd502djj/archive/2010/08/11/1797577.html]

    ORACLE 字符串操作 1 字符串连接   SQL> select 'abc' || 'def' from dual; 'ABC'|------abcdef 2 小写SQL>select ...

  2. JAVA-Unit02: Oracle字符串操作 、 Oracle数值操作 、 Oracle日期操作 、 空值操作

    Unit02: Oracle字符串操作 . Oracle数值操作 . Oracle日期操作 . 空值操作 DQL数据查询语言 查询语句基本由SELECT子句由FROM子句构成. SELECT子句指定要 ...

  3. Oracle中有关字符串操作的语法

    Oracle中有关字符串操作的语法 Oracle提供了丰富的字符串函数 lpad()函数 lpad()函数用于左补全字符串.在某些情况下,预期的字符串为固定长度,而且格式统一,此时可以考虑使用lpad ...

  4. Oracle 字符串函数

    平常我们用Oracle主要有两种字符串类型1.char始终为固定的长度,如果设置了长度小于char列的值,则Oracle会自动用空格填充的.当比较char时,Oracle用空格将其填充为等长,再进行比 ...

  5. [转]Oracle 树操作(select…start with…connect by…prior)

    转自http://www.cnblogs.com/linjiqin/archive/2013/06/24/3152674.html Oracle 树操作(select-start with-conne ...

  6. oracle 字符串切割成结果集方法

    oracle字符串切割几种方式 方法一: SELECT COLUMN_VALUE FROM TABLE(SYS.ODCIVARCHAR2LIST('1','2','3','4','5')); 方法二: ...

  7. Oracle 树操作

    Oracle 树操作(select…start with…connect by…prior) oracle树查询的最重要的就是select…start with…connect by…prior语法了 ...

  8. C# Oracle数据库操作类实例详解

    本文所述为C#实现的Oracle数据库操作类,可执行超多常用的Oracle数据库操作,包含了基础数据库连接.关闭连接.输出记录集.执行Sql语句,返回带分页功能的dataset .取表里字段的类型和长 ...

  9. Windows7上完全卸载Oracle 12c操作步骤

    注:本文来源于:< Windows7上完全卸载Oracle  12c操作步骤 > 1.关闭Oracle所有的服务,按[win+R]运行[services.msc]找到所有Oracle开头的 ...

随机推荐

  1. Android-打反编译工具的一种方法

    转载请注明出处:http://blog.csdn.net/goldenfish1919/article/details/41010261 首先我们来看下dex文件的格式: class_defs的结构: ...

  2. Android注解支持(Support Annotations)

    注解支持(Support Annotations) Android support library从19.1版本开始引入了一个新的注解库,它包含很多有用的元注解,你能用它们修饰你的代码,帮助你发现bu ...

  3. [置顶] String StringBuffer StringBuilder的区别剖析

    这是一道很常见的面试题目,至少我遇到过String/StringBuffer/StringBuilder的区别:String是不可变的对象(final)类型,每一次对String对象的更改均是生成一个 ...

  4. (转载)SVN 提交操作缩写(A D M R) .

    前言: 今天使用SVN提交代码,发现提交后的代码找不到之前的版本. 操作的字母缩写为R.一般我们常见的操作为 A D M R   A:add,新增 C:conflict,冲突 D:delete,删除 ...

  5. MKServerBuilder.psm1

    MKServerBuilder.psm1 function Test-ElevatedShell { $user = [Security.Principal.WindowsIdentity]::Get ...

  6. 百度知道的php爬虫

    原文地址:百度知道的php爬虫作者:好宏杰软件 <?php class spider  {    private $content ;    private $contentlen ;    p ...

  7. PHP数组函数相关

    php的数组函数是一个重点,因为在PHP中是一个主要的复合数据类型, 首先是,寻找一个值是否存在一个数组中的函数: array_search — 在数组中搜索给定的值,如果成功则返回相应的键名 mix ...

  8. [FTP] FTPClient--FTP操作帮助类,上传下载,文件,目录操作 (转载)

    点击下载 FTPClient.zip 这个类是关于FTP客户端的操作1.构造函数 2.字段 服务器账户密码3.属性4.链接5.传输模式6.文件操作7.上传和下载8.目录操作9.内容函数看下面代码吧 / ...

  9. Socket 错误一览表

    出现网络联机错误Socket error #11001 表示您的计算机无法连上服务器,请检查您的Proxy设定以及Proxy相关账号,或暂时取消您防毒软件的「个人防火墙」. · 出现网络联机错误Soc ...

  10. IIS本地部署项目出错

    今天,打开部署在本地IIS的项目发现出错了.报的错,跟没有连接网络一样的.我当时有点懵,过一会儿再静下心来,想想这是什么原因. 第一步,把所有部署的项目,都打开看了一下,方便找出对比. 发现,绑定了I ...