仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 1142|回复: 8
打印 上一主题 下一主题

[学习教程] MSSQL编程:PL/SQL单行函数和组函数详解

[复制链接]
跳转到指定楼层
楼主
发表于 2015-1-16 22:37:15 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
这能找出所有错误的99.99%。它不能找出的是仅仅涉及数据文件的损坏(这很不常见)。如果你想要检查一张表,你通常应该没有选项地运行myisamchk或用-s或--silent选项的任何一个。函数|详解  函数是一种有零个或多个参数而且有一个前往值的程序。在SQL中Oracle内建了一系列函数,这些函数都可被称为SQL或PL/SQL语句,函数次要分为两年夜类:

  单行函数

  组函数

  本文将会商怎样使用单行函数和利用划定规矩。

  SQL中的单行函数

  SQL和PL/SQL中自带良多范例的函数,有字符、数字、日期、转换、和夹杂型等多种函数用于处置单行数据,因而这些都可被统称为单行函数。这些函数都可用于SELECT,WHERE、ORDERBY等子句中,比方上面的例子中就包括了TO_CHAR,UPPER,SOUNDEX等单行函数。

SELECTename,TO_CHAR(hiredate,day,DD-Mon-YYYY)
FROMemp
WhereUPPER(ename)LikeAL%
ORDERBYSOUNDEX(ename)
  单行函数也能够在其他语句中利用,如update的SET子句,INSERT的VALUES子句,DELET的WHERE子句,认证测验出格注重在SELECT语句中利用这些函数,以是我们的注重力也会合在SELECT语句中。

  NULL和单行函数

  在怎样了解NULL上入手下手是很坚苦的,就算是一个很有履历的人仍然对此感应狐疑。NULL值暗示一个未知数据大概一个空值,算术操纵符的任何一个操纵数为NULL值,了局均为提个NULL值,这个划定规矩也合适良多函数,只要CONCAT,DECODE,DUMP,NVL,REPLACE在挪用了NULL参数时可以前往非NULL值。在这些中NVL函数时最主要的,由于他能间接处置NULL值,NVL有两个参数:NVL(x1,x2),x1和x2都式表达式,当x1为null时前往X2,不然前往x1。

  上面我们看看emp数据表它包括了薪水、奖金两项,必要盘算总的抵偿

columnnameemp_idsalarybonus

keytypepk
nulls/uniquenn,unn
fktable
datatypenumbernumbernumber
length11.211.2
  不是复杂的将薪水和奖金加起来就能够了,假如某一行是null值那末了局就将是null,好比上面的例子:

updateemp
setsalary=(salary+bonus)*1.1
  这个语句中,雇员的人为和奖金都将更新为一个新的值,可是假如没有奖金,即salary+null,那末就会得堕落误的结论,这个时分就要利用nvl函数来扫除null值的影响。
以是准确的语句是:


updateemp
setsalary=(salary+nvl(bonus,0)*1.1

  单行字符串函数

  单行字符串函数用于操纵字符串数据,他们年夜多半有一个或多个参数,个中尽年夜多半前往字符串

  ASCII()
  c1是一字符串,前往c1第一个字母的ASCII码,他的逆函数是CHR()

SELECTASCII(A)BIG_A,ASCII(z)BIG_zFROMemp

BIG_ABIG_z
65122
  CHR(<i>)[NCHAR_CS]
  i是一个数字,函数前往十进制暗示的字符

selectCHR(65),CHR(122),CHR(223)FROMemp

CHR65CHR122CHR223
AzB
  CONCAT(,)
  c1,c2均为字符串,函数将c2毗连到c1的前面,假如c1为null,将前往c2.假如c2为null,则前往c1,假如c1、c2都为null,则前往null。他和操纵符||前往的了局不异

selectconcat(slobo,Svoboda)usernamefromdual

username

sloboSyoboda

  INITCAP()
  c1为一字符串。函数将每一个单词的第一个字母年夜写别的字母小写前往。单词由空格,把持字符,标点标记限定。

selectINITCAP(veni,vedi,vici)Ceasarfromdual

Ceasar

Veni,Vedi,Vici

  INSTR(,[,<i>[,]])
  c1,c2均为字符串,i,j为整数。函数前往c2在c1中第j次呈现的地位,搜刮从c1的第i个字符入手下手。当没有发明必要的字符时前往0,假如i为正数,那末搜刮将从右到左举行,可是地位的盘算仍是从左到右,i和j的缺省值为1.

selectINSTR(Mississippi,i,3,3)fromdual

INSTR(MISSISSIPPI,I,3,3)

11

selectINSTR(Mississippi,i,-2,3)fromdual

INSTR(MISSISSIPPI,I,3,3)

2

  INSTRB(,[,i[,j])
  与INSTR()函数一样,只是他前往的是字节,关于单字节INSTRB()即是INSTR()

  LENGTH()
  c1为字符串,前往c1的长度,假如c1为null,那末将前往null值。

selectLENGTH(IpsoFacto)ergofromdual

ergo

10
  LENGTHb()
  与LENGTH()一样,前往字节。

  lower()
  前往c的小写字符,常常呈现在where子串中

selectLOWER(colorname)fromitemdetailWHERELOWER(colorname)LIKE%white%

COLORNAME

Winterwhite

  LPAD(,<i>[,])
  c1,c2均为字符串,i为整数。在c1的左边用c2字符串补足致长度i,可屡次反复,假如i小于c1的长度,那末只前往i那末长的c1字符,其他的将被截往。c2的缺省值为单空格,拜见RPAD。

selectLPAD(answer,7,)padded,answerunpaddedfromquestion;

PADDEDUNPADDED

YesYes
NONO
Maybemaybe

  LTRIM(,)
  把c1中最右边的字符往失落,使其第一个字符不在c2中,假如没有c2,那末c1就不会改动。

selectLTRIM(Mississippi,Mis)fromdual

LTR

ppi
  RPAD(,<i>[,])
  在c1的右边用c2字符串补足致长度i,可屡次反复,假如i小于c1的长度,那末只前往i那末长的c1字符,其他的将被截往。c2的缺省值为单空格,其他与LPAD类似

  RTRIM(,)
  把c1中最右侧的字符往失落,使其第后一个字符不在c2中,假如没有c2,那末c1就不会改动。

  REPLACE(,[,])
  c1,c2,c3都是字符串,函数用c3取代呈现在c1中的c2后前往。

selectREPLACE(uptown,up,down)fromdual

REPLACE

downtown
  STBSTR(,<i>[,])
  c1为一字符串,i,j为整数,从c1的第i位入手下手前往长度为j的子字符串,假如j为空,则直到串的尾部。

selectSUBSTR(Message,1,4)fromdual

SUBS

Mess

  SUBSTRB(,<i>[,])
  与SUBSTR大抵不异,只是I,J是以字节盘算。

  SOUNDEX()
  前往与c1发音类似的词

selectSOUNDEX(dawes)DawesSOUNDEX(daws)Daws,SOUNDEX(dawson)fromdual

DawesDawsDawson

D200D200D250
  TRANSLATE(,,)
  将c1中与c2不异的字符以c3取代

selectTRANSLATE(fumble,uf,ar)testfromdual

TEXT

ramble
  TRIM([[]]fromc3)
  将c3串中的第一个,最初一个,大概都删除。

selectTRIM(spacepadded)trimfromdual

TRIM

spacepadded
  UPPER()
  前往c1的年夜写,常呈现where子串中


selectnamefromdualwhereUPPER(name)LIKEKI%

NAME

KING

  单行数字函数

  单行数字函数操纵数字数据,实行数学和算术运算。一切函数都无数字参数并前往数字值。一切三角函数的操纵数和值都是弧度而不是角度,oracle没有供应内建的弧度和角度的转换函数。

  ABS()
  前往n的相对值

  ACOS()
  反余玄函数,前往-1到1之间的数。n暗示弧度



selectACOS(-1)pi,ACOS(1)ZEROFROMdual

PIZERO

3.141592650


  ASIN()
  归正玄函数,前往-1到1,n暗示弧度

  ATAN()
  归正切函数,前往n的归正切值,n暗示弧度。

  CEIL()
  前往年夜于或即是n的最小整数。

  COS()
  前往n的余玄值,n为弧度

  COSH()
  前往n的双曲余玄值,n为数字。



selectCOSH(<1.4>)FROMdual

COSH(1.4)

2.15089847


  EXP()
  前往e的n次幂,e=2.71828183.

  FLOOR()
  前往小于即是N的最年夜整数。

  LN()
  前往N的天然对数,N必需年夜于0

  LOG(,)
  前往以n1为底n2的对数

  MOD()
  前往n1除以n2的余数,

  POWER(,)
  前往n1的n2次方

  ROUND(,)
  前往舍进小数点右侧n2位的n1的值,n2的缺省值为0,这回将小数点最靠近的整数,假如n2为正数就舍进到小数点右边响应的位上,n2必需是整数。



selectROUND(12345,-2),ROUND(12345.54321,2)FROMdual

ROUND(12345,-2)ROUND(12345.54321,2)

1230012345.54


  SIGN()
  假如n为正数,前往-1,假如n为负数,前往1,假如n=0前往0.

  SIN()
  前往n的正玄值,n为弧度。

  SINH()
  前往n的双曲正玄值,n为弧度。

  SQRT()
  前往n的平方根,n为弧度

  TAN()
  前往n的正切值,n为弧度

  TANH()
  前往n的双曲正切值,n为弧度

  TRUNC(,)
  前往截尾到n2位小数的n1的值,n2缺省设置为0,当n2为缺省设置时会将n1截尾为整数,假如n2为负值,就截尾在小数点右边响应的位上。

  单行日期函数

  单行日期函数操纵DATA数据范例,尽年夜多半都有DATA数据范例的参数,尽年夜多半前往的也是DATA数据范例的值。

  ADD_MONTHS(,<i>)
  前往日期d加上i个月后的了局。i可使恣意整数。假如i是一个小数,那末数据库将隐式的他转换成整数,将会截往小数点前面的部分。

  LAST_DAY()
  函数前往包括日期d的月份的最初一天

  MONTHS_BETWEEN(,)
  前往d1和d2之间月的数量,假如d1和d2的日的日期都不异,大概都使该月的最初一天,那末将前往一个整数,不然会前往的了局将包括一个分数。

  NEW_TIME(,,)
  d1是一个日期数据范例,事先区tz1中的日期和工夫是d时,前往时区tz2中的日期和工夫。tz1和tz2时字符串。

  NEXT_DAY(,)
  前往日期d后由dow给出的前提的第一天,dow利用以后会话中给出的言语指定了一周中的某一天,前往的工夫份量与d的工夫份量不异。



selectNEXT_DAY(01-Jan-2000,Monday)"1stMonday",NEXT_DAY(01-Nov-2004,Tuesday)+7"2ndTuesday")fromdual;

1stMonday2ndTuesday

03-Jan-200009-Nov-2004


  ROUND([,])
  将日期d依照fmt指定的格局舍进,fmt为字符串。

  SYADATE
  函数没有参数,前往以后日期和工夫。

  TRUNC([,])
  前往由fmt指定的单元的日期d.

  单行转换函数

  单行转换函数用于操纵多半据范例,在数据范例之间举行转换。

  CHARTORWID()
  c使一个字符串,函数将c转换为RWID数据范例。

SELECTtest_idfromtest_casewhererowid=CHARTORWID(AAAA0SAACAAAALiAAA)
  CONVERT(,[,])
  c尾字符串,dset、sset是两个字符集,函数将字符串c由sset字符集转换为dset字符集,sset的缺省设置为数据库的字符集。

  HEXTORAW()
  x为16进制的字符串,函数将16进制的x转换为RAW数据范例。

  RAWTOHEX()
  x是RAW数据范例字符串,函数将RAW数据类转换为16进制的数据范例。

  ROWIDTOCHAR()
  函数将ROWID数据范例转换为CHAR数据范例。

  TO_CHAR([[,)
  x是一个data或number数据范例,函数将x转换成fmt指定格局的char数据范例,假如x为日期nlsparm=NLS_DATE_LANGUAGE把持前往的月份和日份所利用的言语。假如x为数字nlsparm=NLS_NUMERIC_CHARACTERS用来指定小数位和千分位的分开符,和泉币标记。

NLS_NUMERIC_CHARACTERS="dg",NLS_CURRENCY="string"
  TO_DATE([,[,)
  c暗示字符串,fmt暗示一种特别格局的字符串。前往依照fmt格局显现的c,nlsparm暗示利用的言语。函数将字符串c转换成date数据范例。

  TO_MULTI_BYTE()
  c暗示一个字符串,函数将c的担子截字符转换成多字节字符。

  TO_NUMBER([,[,)
  c暗示字符串,fmt暗示一个特别格局的字符串,函数前往值依照fmt指定的格局显现。nlsparm暗示言语,函数将前往c代表的数字。

  TO_SINGLE_BYTE()
  将字符串c中很多字节字符转化成等价的单字节字符。该函数仅当数据库字符集同时包括单字节和多字节字符时才利用

  别的单行函数

  BFILENAME(
,)
  dir是一个directory范例的工具,file为一文件名。函数前往一个空的BFILE地位值唆使符,函数用于初始化BFILE变量大概是BFILE列。

  DECODE(,,[,,,[])
  x是一个表达式,m1是一个婚配表达式,x与m1对照,假如m1即是x,那末前往r1,不然,x与m2对照,顺次类推m3,m4,m5....直到有前往了局。

  DUMP(,[,[,[,]]])
  x是一个表达式或字符,fmt暗示8进制、10进制、16进制、或则单字符。函数前往包括了有关x的外部暗示信息的VARCHAR2范例的值。假如指定了n1,n2那末从n1入手下手的长度为n2的字节将被前往。

  EMPTY_BLOB()
  该函数没有参数,函数前往一个空的BLOB地位唆使符。函数用于初始化一个BLOB变量或BLOB列。

  EMPTY_CLOB()
  该函数没有参数,函数前往一个空的CLOB地位唆使符。函数用于初始化一个CLOB变量或CLOB列。

  GREATEST()
  exp_list是一列表达式,前往个中最年夜的表达式,每一个表达式都被隐含的转换第一个表达式的数据范例,假如第一个表达式是字符串数据范例中的任何一个,那末前往的了局是varchar2数据范例,同时利用的对照长短添补空格范例的对照。

  LEAST()
  exp_list是一列表达式,前往个中最小的表达式,每一个表达式都被隐含的转换第一个表达式的数据范例,假如第一个表达式是字符串数据范例中的任何一个,将前往的了局是varchar2数据范例,同时利用的对照长短添补空格范例的对照。

  UID
  该函数没有参数,前往独一标示以后数据库用户的整数。

  USER
  前往以后用户的用户名

  USERENV()
  基于opt前往包括以后会话信息。opt的可选值为:

  ISDBA   会话中SYSDBA角色呼应,前往TRUE
  SESSIONID 前往审计会话标示符
  ENTRYID  前往可用的审计项标示符
  INSTANCE  在会话毗连后,前往实例标示符。该值只用于运转Parallel服务器而且有多个实例的情形下利用。
  LANGUAGE  前往言语、地区、数据库设置的字符集。
  LANG    前往言语称号的ISO缩写。
  TERMINAL  为以后会话利用的终端或盘算机前往操纵体系的标示符。

  VSIZE()
  x是一个表达式。前往x外部暗示的字节数。
 SQL中的组函数

  组函数也叫汇合函数,前往基于多个行的单一了局,行的正确数目没法断定,除非查询被实行而且一切的了局都被包括在内。与单行函数分歧的是,在剖析时一切的行都是已知的。因为这类不同使组函数与单行函数有在请求和举动上有巨大的差别.

  组(多行)函数

  与单行函数比拟,oracle供应了丰厚的基于组的,多行的函数。这些函数能够在select或select的having子句中利用,当用于select子串经常常都和GROUPBY一同利用。

  AVG([{DISYINCT|ALL}])
  前往数值的均匀值。缺省设置为ALL.

SELECTAVG(sal),AVG(ALLsal),AVG(DISTINCTsal)FROMscott.emp

AVG(SAL)AVG(ALLSAL)AVG(DISTINCTSAL)

1877.941181877.941181916.071413

  COUNT({*|DISTINCT|ALL})
  前往查询中行的数量,缺省设置是ALL,*暗示前往一切的行。

  MAX([{DISTINCT|ALL}])
  前往选择列表项目标最年夜值,假如x是字符串数据范例,他前往一个VARCHAR2数据范例,假如X是一个DATA数据范例,前往一个日期,假如X是numeric数据范例,前往一个数字。注重distinct和all不起感化,应为最年夜值与这两种设置是不异的。

  MIN([{DISTINCT|ALL}])
  前往选择列表项目标最小值。

  STDDEV([{DISTINCT|ALL}])
  前往选者的列表项目标尺度差,所谓尺度差是方差的平方根。

  SUM([{DISTINCT|ALL}])
  前往选择列表项目标数值的总和。

  VARIANCE([{DISTINCT|ALL}])
  前往选择列表项目标统计方差。

  用GROUPBY给数据分组

  正如标题表示的那样组函数就是操纵那些已分好组的数据,我们告知数据库用GROUPBY如何给数据分组大概分类,当我们在SELECT语句的SELECT子句中利用组函数时,我们必需把为分组或十分数列安排在GROUPBY子句中,假如没有效groupby举行专门处置,那末缺省的分类是将全部了局设为一类。

selectstat,counter(*)zip_countfromzip_codesGROUPBYstate;

STZIP_COUNT
-----------
AK360
AL1212
AR1309
AZ768
CA3982
  在这个例子中,我们用state字段分类;假如我们要将了局依照zip_codes排序,能够用ORDERBY语句,ORDERBY子句可使用列或组函数。

selectstat,counter(*)zip_countfromzip_codesGROUPBYstateORDERBYCOUNT(*)DESC;

STCOUNT(*)
----------
NY4312
PA4297
TX4123
CA3982
  用HAVING子句限定分组数据

  如今你已晓得了在查询的SELECT语句和ORDERBY子句中利用主函数,组函数只能用于两个子串中,组函数不克不及用于WHERE子串中,比方上面的查询是毛病的:


毛病
SELECTsales_clerk,SUN(sale_amount)FROMgross_salesWHEREsales_dept=OUTSIDEANDSUM(sale_amount)>10000GROUPBYsales_clerk

  这个语句中数据库不晓得SUM()是甚么,当我们必要唆使数据库对行分组,然后限定分组后的行的输入时,准确的办法是利用HAVING语句:

SELECTsales_clerk,SUN(sale_amount)
FROMgross_sales
WHEREsales_dept=OUTSIDE
GROUPBYsales_clerk
HAVINGSUM(sale_amount)>10000;
  嵌套函数

  函数能够嵌套。一个函数的输入能够是另外一个函数的输出。操纵数有一个可承继的实行历程。但函数的优先权只是基于地位,函数遵守由内到外,由左到右的准绳。嵌套手艺一样平常用于象DECODE如许的能被用于逻辑判别语句IF....THEN...ELSE的函数。

  嵌套函数能够包含在组函数中嵌套单行函数,大概组函数嵌套进单行函数或组函数中。好比上面的例子:

SELECTdeptno,GREATEST(COUNT(DISTINCTjob),COUNT(DISTINCTmgr)cnt,
COUNT(DISTINCTjob)jobs,
COUNT(DISTINCTmgr)mgrs
FROMemp
GROUPBYdeptno;

DEPTNOCNTJOBSMGRS
-----------------
10442
20434
30332




这章描述如何检查和处理在MySQL数据库中的数据损坏。如果你的表损坏很多,你应该尝试找出其原因!见G.1调试一个MySQL服务器。
蒙在股里 该用户已被删除
沙发
发表于 2015-1-19 18:58:18 来自手机 | 只看该作者
其实可以做一下类比,Oracle等数据库产品老早就支持了java编程,而且提供了java池参数作为用户配置接口。但是现在有哪些系统大批使用了java存储过程?!连Oracle自己的应用都不用为什么?!
柔情似水 该用户已被删除
板凳
发表于 2015-1-28 09:07:23 | 只看该作者
SP4包括用于以下SQLServer2000组件的程序包:Database组件(下载文件:SQL2000-KB884525-SP4-x86.EXE)更新SQLServer2000的32位Database组件,包括数据库引擎、复制、客户端连接组件及工具。有关其他信息,请参阅ReadmeSql2k32Sp4.htm。AnalysisServices组件(下载文件:SQL2000.AS-KB884525-SP4-x86.EXE)更新SQLServer2000的32位AnalysisServices。
深爱那片海 该用户已被删除
地板
发表于 2015-2-5 15:19:40 | 只看该作者
对于数据库来说,查询是数据库的灵魂,那么SQL查询效率究竟效率如何呢?下文将带对SQL查询的相关问题进行讨论,供您参考。
分手快乐 该用户已被删除
5#
发表于 2015-2-12 12:29:33 | 只看该作者
再开发调试阶段和OLAP环境中,外键是可以建立的。新版本中加入了SETNULL和SETDEFAULT属性,能够提供能好的级联设置。
6#
 楼主| 发表于 2015-3-3 03:23:15 | 只看该作者
以前的DTS轻盈简单。但是现在的SSIS虽然功能强大了很多,但是总是让人感觉太麻烦。看看论坛中询问SSIS的贴子就知道。做的功能太强大了,往往会有很多用户不会用了
因胸联盟 该用户已被删除
7#
发表于 2015-3-11 09:12:28 | 只看该作者
如果你是从“学习某一种数据库应用软件,从而获得应聘的资本和工作机会”的角度来问的话。
不帅 该用户已被删除
8#
发表于 2015-3-18 02:52:35 | 只看该作者
然后最好有实践机会,能够把实践到的和实践结合起来,其实理论思考是个非常困扰和痛苦的事情
精灵巫婆 该用户已被删除
9#
发表于 2015-3-25 10:10:10 | 只看该作者
原来公司用过MYSQL自己也只是建个表写个SQL
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2025-1-8 12:50

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表