Oracle函数详解:字符串、数学、日期及逻辑函数

需积分: 7 0 下载量 13 浏览量 更新于2024-09-12 收藏 32KB PDF 举报
"Oracle函数大全包含了各种类型的函数,如字符串函数、数学函数、日期函数、逻辑运算函数等,用于在数据库操作中进行数据处理和分析。以下是对这些函数的详细介绍: 1. ASCII 函数: 返回指定字符的ASCII码,即对应的十进制数值。例如,ASCII('A')返回65,ASCII('a')返回97,ASCII('0')返回48,ASCII(' ')返回32。 2. CHR 函数: 根据给定的ASCII码返回相应的字符。例如,CHR(54740)返回'赵',CHR(65)返回'A'。 3. CONCAT 函数: 连接两个或多个字符串。例如,CONCAT('010-', '88888888') || '转23' 返回'010-88888888转23'。 4. INITCAP 函数: 将字符串的第一个字母转换为大写,其余字母保持原样。例如,INITCAP('smith') 返回'Smith'。 5. INSTR 函数: 在一个字符串中查找指定子串的位置。参数包括C1(被搜索的字符串),C2(要查找的子串),I(搜索起始位置,默认1),J(出现的位置,默认1)。例如,INSTR('oracletraining', 'ra', 1, 2) 返回9,表示'ra'在字符串中的第二个位置是9。 6. LENGTH 函数: 计算字符串的长度。例如,LENGTH('name') 返回5,LENGTH('address') 返回7,如果字符串包含非ASCII字符,如中文,长度也会正确反映字符数。 这只是Oracle函数大全中的一部分,还有更多的函数如数学函数(如TAN、TANH、TRUNC等)用于进行三角运算和数值截断,日期函数(如DATE、SYSDATE、ADD_MONTHS等)用于处理日期和时间,以及逻辑运算函数(如IFNULL、NVL、DECODE等)用于条件判断和数据填充。掌握这些函数能极大地提升你在Oracle数据库中的数据处理能力,使得SQL查询更为灵活和高效。"
2009-09-16 上传
ORACLE函数大全 ________________________________________ 作者:[本站编辑] 来源:[CSDN] 浏览:[ ] SQL中的单记录函数 1.ASCII 返回与指定的字符对应的十进制数; SQL> select ascii('A') A,ascii('a') a,ascii('0') zero,ascii(' ') space from dual; A A ZERO SPACE --------- --------- --------- --------- 65 97 48 32 2.CHR 给出整数,返回对应的字符; SQL> select chr(54740) zhao,chr(65) chr65 from dual; ZH C -- - 赵 A 3.CONCAT 连接两个字符串; SQL> select concat('010-','88888888')||'转23' 高乾竞电话 from dual; 高乾竞电话 ---------------- 010-88888888转23 4.INITCAP 返回字符串并将字符串的第一个字母变为大写; SQL> select initcap('smith') upp from dual; UPP ----- Smith 5.INSTR(C1,C2,I,J) 在一个字符串中搜索指定的字符,返回发现指定的字符的位置; C1 被搜索的字符串 C2 希望搜索的字符串 I 搜索的开始位置,默认为1 J 出现的位置,默认为1 SQL> select instr('oracle traning','ra',1,2) instring from dual; INSTRING --------- 9 6.LENGTH 返回字符串的长度; SQL> select name,length(name),addr,length(addr),sal,length(to_char(sal)) from gao.nchar_tst; NAME LENGTH(NAME) ADDR LENGTH(ADDR) SAL LENGTH(TO_CHAR(SAL)) ------ ------------ ---------------- ------------ --------- -------------------- 高乾竞 3 北京市海锭区 6 9999.99 7 7.LOWER 返回字符串,并将所有的字符小写 SQL> select lower('AaBbCcDd')AaBbCcDd from dual; AABBCCDD -------- aabbccdd 8.UPPER 返回字符串,并将所有的字符大写 SQL> select upper('AaBbCcDd') upper from dual; UPPER -------- AABBCCDD 9.RPAD和LPAD(粘贴字符) RPAD 在列的右边粘贴字符 LPAD 在列的左边粘贴字符 SQL> select lpad(rpad('gao',10,'*'),17,'*')from dual; LPAD(RPAD('GAO',1 ----------------- *******gao******* 不够字符则用*来填满 10.LTRIM和RTRIM LTRIM 删除左边出现的字符串 RTRIM 删除右边出现的字符串 SQL> select ltrim(rtrim(' gao qian jing ',' '),' ') from dual; LTRIM(RTRIM(' ------------- gao qian jing 11.SUBSTR(string,start,count) 取子字符串,从start开始,取count个 SQL> select substr('13088888888',3,8) from dual; SUBSTR(' -------- 08888888 12.REPLACE('string','s1','s2') string 希望被替换的字符或变量 s1 被替换的字符串 s2 要替换的字符串 SQL> select replace('he love you','he','i') from dual; REPLACE('H ---------- i love you 13.SOUNDEX 返回一个与给定的字符串读音相同的字符串 SQL> create table table1(xm varchar(8)); SQL> insert into table1 values('weather'); SQL> insert into table1 values('wether'); SQL>