网络编程
位置:首页>> 网络编程>> 数据库>> OraclePL/SQL单行函数和组函数详解

OraclePL/SQL单行函数和组函数详解

 来源:asp之家 发布时间:2010-07-28 13:02:00 

标签:oracle,pl,sql,函数

1  函数是一种有零个或多个参数并且有一个返回值的程序。在SQL中Oracle内建了一系列函数,这些函数都可被称为SQL或PL/SQL语句,函数主要分为两大类:
2
3   单行函数
4
5   组函数
6
7  本文将讨论如何利用单行函数以及使用规则。
8
9  SQL中的单行函数
10
11  SQL和PL/SQL中自带很多类型的函数,有字符、数字、日期、转换、和混合型等多种函数用于处理单行数据,因此这些都可被统称为单行函数。这些函数均可用于SELECT,WHERE、ORDER BY等子句中,例如下面的例子中就包含了TO_CHAR,UPPER,SOUNDEX等单行函数。
12
13SELECT ename,TO_CHAR(hiredate,'day,DD-Mon-YYYY')
14FROM emp
15Where UPPER(ename) Like 'AL%'
16ORDER BY SOUNDEX(ename)
17
18  单行函数也可以在其他语句中使用,如update的SET子句,INSERT的VALUES子句,DELET的WHERE子句,认证考试特别注意在SELECT语句中使用这些函数,所以我们的注意力也集中在SELECT语句中。
19
20  NULL和单行函数
21
22  在如何理解NULL上开始是很困难的,就算是一个很有经验的人依然对此感到困惑。NULL值表示一个未知数据或者一个空值,算术操作符的任何一个操作数为NULL值,结果均为提个NULL值,这个规则也适合很多函数,只有CONCAT,DECODE,DUMP,NVL,REPLACE在调用了NULL参数时能够返回非NULL值。在这些中NVL函数时最重要的,因为他能直接处理NULL值,NVL有两个参数:NVL(x1,x2),x1和x2都式表达式,当x1为null时返回X2,否则返回x1。
23
24  下面我们看看emp数据表它包含了薪水、奖金两项,需要计算总的补偿
25
26column name emp_id salary bonus
27
28key type pk
29nulls/unique nn,u nn
30fk table
31datatype number number number
32length 11.2 11.2
33
34  不是简单的将薪水和奖金加起来就可以了,如果某一行是null值那么结果就将是null,比如下面的例子:
35
36update emp
37set salary=(salary+bonus)*1.1
38
39  这个语句中,雇员的工资和奖金都将更新为一个新的值,但是如果没有奖金,即 salary + null,那么就会得出错误的结论,这个时候就要使用nvl函数来排除null值的影响。
40所以正确的语句是:
41
42update emp
43set salary=(salary+nvl(bonus,0)*1.1
44
45  单行字符串函数
46
47  单行字符串函数用于操作字符串数据,他们大多数有一个或多个参数,其中绝大多数返回字符串
48
49  ASCII()
50  c1是一字符串,返回c1第一个字母的ASCII码,他的逆函数是CHR()
51
52SELECT ASCII('A') BIG_A,ASCII('z') BIG_z FROM emp
53
54BIG_A BIG_z
5565 122
56
57  CHR(<i>)[NCHAR_CS]
58  i是一个数字,函数返回十进制表示的字符
59
60select CHR(65),CHR(122),CHR(223) FROM emp
61
62CHR65 CHR122 CHR223
63A z B
64
65  CONCAT(,)
66  c1,c2均为字符串,函数将c2连接到c1的后面,如果c1为null,将返回c2.如果c2为null,则返回c1,如果c1、c2都为null,则返回null。他和操作符||返回的结果相同
67
68select concat('slobo ','Svoboda') username from dual
69
70username
71
72slobo Syoboda
73
74
75  INITCAP()
76  c1为一字符串。函数将每个单词的第一个字母大写其它字母小写返回。单词由空格,控制字符,标点符号限制。
77
78select INITCAP('veni,vedi,vici') Ceasar from dual
79
80Ceasar
81
82Veni,Vedi,Vici
83
84
85  INSTR(,[,<i>[,]])
86  c1,c2均为字符串,i,j为整数。函数返回c2在c1中第j次出现的位置,搜索从c1的第i个字符开始。当没有发现需要的字符时返回0,如果i为负数,那么搜索将从右到左进行,但是位置的计算还是从左到右,i和j的缺省值为1.
87
88select INSTR('Mississippi','i',3,3) from dual
89
90INSTR('MISSISSIPPI','I',3,3)
91
9211
93
94select INSTR('Mississippi','i',-2,3) from dual
95
96INSTR('MISSISSIPPI','I',3,3)
97
982
99
100

0
投稿

猜你喜欢

  • bcp是SQL Server中负责导入导出数据的一个命令行工具,它是基于DB-Library的,并且能以并行的方式高效地导入导出大批量的数据
  • 什么是Firebug从事了数年的Web开发工作,越来越觉得现在对WEB开发有了更高的要求。要写出漂亮的HTML代码;要编写精致的CSS样式表
  • 使用图层可以像素为单位精确定位页面元素,并且可以将层放置在页面的任意位置。当把页面元素放入图层之中时,还可以控制哪个显示在前面、哪个显示在后
  • 前段时间在论坛上有人问到一个淘宝网上的hover伪类实现的效果如果兼容ie6。其实,问题很简单,就是hover伪类在IE6中得不到很好的支持
  • 我们的每期话题,团队在内部都会通过邮件进行一番讨论,随着讨论的激烈,往往能碰撞出很多有意义的观点,因此,将讨论内容分享出来,有兴趣的朋友可以
  • 在web开发中经常遇到多关键词对对单个字段查询,我一般是通过动态数组来实现的。当然多个关键词的一般是用空格或,隔开,我这几假设多个关键词用空
  • LoadRunner监控MySQLhttp://www.docin.com/p-92272846.htmlAdvanced MySQL Pe
  • 代码如下: EXEC sp_rename '表名.[原列名]', '新列名', 'column
  • Web开发中,我们经常会遇到分页显示和排序数据记录集的情况,这在服务器端使用服务器端的代码和数据库技术是件很轻松的事情,比如:ASP、PHP
  • 不是炒冷饭,我添加了很多新的功能哦演示地址: xwinhtcdemo.htmCSS: global.cssHTC: xwin.htc特点:1
  • 你已经在上面取出w打头记录的例子中看到了LIKE的用法。LIKE判定词是一个非常有用的符号。不过,在很多情况下用了它可能会带给你太多的数据,
  • 支付宝lab的意思是支付宝实验室,也就是概念产品聚集地,可以让用户快速试用这些新产品。本次支付宝lab logo设计历时一个星期,视觉设计组
  • 返回首页的链接地址,有三种方法:1、一般方法是,直接写对应的域名地址,<a href="http://www.zfnn.co
  • 根据Nicholas的说法,有四种代码会拖慢脚本的运行,并最终导致脚本失控。分别是次数过多的同步循环、庞大的函数体、不恰当的递归和不合理的D
  • detectres.asp<HTML><head><TITLE>asp教程之全能屏幕分辨率侦测</
  • TMD这年头做前端真命苦,IE出了N个版本就算了,还跳出个马桶出来。你说你这个马桶,用人家内核就好好用拉。还改人家的东西干啥,那你改就改拉,
  • 和数据库打交道要频繁地用到SQL语句,除非你是全部用控件绑定的方式,但采用控件绑定的方式存在着灵活性差、效率低、功能弱等等缺点。因此,大多数
  • 今早打开 腾讯ISD的博客 ,看到一篇新的文章,《迷你屋视觉规范简介》,赶紧看了来学习。不过给我抓到问题咯,臭鱼不介意我在这说下吧:这套规范
  • 开放源代码社区为了扩展MySQL的使用范围,开发出了.Net框架(.NET Framework)中可以使用的数据库连接器。我们就来学习一下如
  • 代码如下:arr = array(12,52,14,43,24,58,15,64,24,57,17,56,45)&nbs
手机版 网络编程 asp之家 www.aspxhome.com