`
fyd222
  • 浏览: 103967 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

SQL 基础-->常用函数

 
阅读更多

--==================================

--SQL 基础-->常用函数

--==================================

/*

一、函数的分类

SQL函数一般分为两种

单行函数 基于单行的处理,一行产生一个结果

多行函数 基于多行的处理,对多行进行汇总,多行产生结果

二、函数形式

function_name [(arg1, arg2,...)]

三、常用的单行函数:

1. 字符函数:

lower(x) 转小写

upper(x) 转大写

initcap(x) 单词首字母转大写

concat(x,y) 字符连接与| | 功能类似

substr(x,start [,length]) 取子串

格式: substr('asdfasdfasdfasddf',1,3)

length(x) 取字符串长度

lpad | rpad(x,width [,pad_string]) 字符定长,(不够长度时,左|右填充)

trim([trim_charFROM] x) 删除首部、尾部字符

格式:trim('h' from 'hello hello')

trim 默认删除方式是both

leading 只删首部 trim(leading 'h' from 'hello helloh')

trailing 只删尾部 trim(trailing 'h' from 'hello helloh')

ltrim(x[,trim_string]) x右边删除字符 等价于使用trailing

rtrim(x[,trim_string]) x左边删除字符 等价于使用leading

instr 返回子字符串在字符串中的位置

格式:instr(string,substring,position,occurence)

replace(x,search_string,replace_string) 字符替换

格式:replace('字符', '字符' ,'字符')

将字符中的字符,替换成字符

2. 数值函数:

round(x [,y]) 四舍五入

trunc(x,[,y]) 截断

mod(m,n) 求余

ceil(x) 返回特定的最小数(大于等于x的最小整数)

floor(x) 返回特定的最大数(小于等于x的最大整数)

3. 日期函数:

sysdate 返回系统当前日期

实际上ORACLE内部存储日期的格式是:世纪,年,月,日,小,分钟,秒。

不管如何输入都这样

9i开始,默认的日期格式是:DD-MON-RR,之前是DD-MON-YY

RR YY 都是世纪后的两位,但有区别

ORACLE的有效日期范围是:公元前年月日-年月日

RR日期格式:

1、如果当前年份最后两位是:-,并且指定年份的最后两位也为-,

则返回本世纪

例:当前年:, 01--,表示2008

2、如果当前年份最后两位是:-,指定年份最后两位为50

则返回上世纪。

例:当前年:,01--,表示1998

3、如果当前年最后两位为:-,指定年份最后两位为0-,

则返回下世纪。

例:当前年:,--表示的是年

4、如果当前年最后两位是:-,指定年份最后两位为:-

则返回本世纪。

例:当前年:,--表示的是年

months_between(xy 两个日期之间相差的月数

例:查询最近个月入职的员工

add_months(x,y) 返回x上加上y个月后的结果

last_day(x) 返回指定日期所在月最后一天的日期

next_day(xday) 返回指定日期的下一day的时间值,day是一个文本串,比如SATURDAY

extract 提取日期

select extract(day from sysdate) from dual

select extract(month from sysdate) from dual;

select extract(year from sysdate) from dual;

4. 转换函数:

TO_DATE(char[, 'format_model']) TO_DATE函数将一个字符串转换成日期格式

函数有个fx 修饰语。这个修饰语为TO_DATE函数的字符函

数中的独立变量和日期格式指定精确匹配.

TO_CHAR(date, 'format_model') 转换为CHAR类型,

必须与单引号一起嵌入,区分大小写,

用逗号把日期数值分开,有一个fm 移除填补空白或者阻止零开头

TO_CHAR(number, 'format_model')

TO_NUMBER(char[, 'format_model']) TO_NUMBER 函数将一个字符串转换成一个数字格式:

select to_date('1999-09-23','yyyy-mm-dd') from dual;

数据类型的转换分为隐式数据类型转换和显式数据类型转换

在表达式中, Oracle服务器能自动地转换下列各项,即隐式转换:

VARCHAR2 or CHAR =====NUMBER

VARCHAR2 or CHAR =====DATE

对表达式赋值, Oracle服务器能自动地转换下列各项,即隐式转换:

NUMBER =======VARCHAR2 or CHAR

DATE =======VARCHAR2 or CHAR

日期格式元素:

YYYY 数字年份

YEAR 英文年份

MM 数字月

MONTH 英文月

MON 英文缩写

DD 数字日

DY 英文缩写

DAY 英文

5. 通用函数

decode 条件判断

格式:decode (col|expression,search1,result1 [,search2,result2,...] [,default])

判断col|exporession的值,当search1匹配时,则返回,result1,

search2匹配时,返回result2 ... 如果都不匹配,返回default

select EMPNO,ENAME,JOB,SAL,

decode(job,'CLERK',SAL*1.15,'SALESMAN',SAL*1.1,SAL*1.12) NEW_SAL

FROM SCOTT.EMP;

if then else 条件判断

case 表达式

CASE expr WHEN comparison_expr1 THEN return_expr1

[WHEN comparison_expr2 THEN return_expr2

WHEN comparison_exprn THEN return_exprn

ELSE else_expr]

END

四、演示*/

--lower函数

SQL> select lower('SQL') from dual;

LOW

---

sql

SQL> select EMPNO,ENAME,JOB from scott.emp where lower(ename) like 'a%';

EMPNO ENAME JOB

---------- ---------- ---------

7499 ALLEN SALESMAN

7876 ADAMS CLERK

SQL> insert into scott.emp(empno,ename) values(9999,'albert');

1 row created.

SQL> select * from scott.emp where lower(ename) like 'a%';

EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO

---------- ---------- --------- ---------- ---------- ---------- ---------- ----------

9999 albert

7499 ALLEN SALESMAN 7698 1981-02-20 1600 300 30

7876 ADAMS CLERK 7788 1987-05-23 1100 20

SQL> select * from scott.emp where ename like 'A%';

EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO

---------- ---------- --------- ---------- ---------- ---------- ---------- ----------

7499 ALLEN SALESMAN 7698 1981-02-20 1600 300 30

7876 ADAMS CLERK 7788 1987-05-23 1100 20

--upper函数

SQL> select upper('SQL Course') as Upper_Char from dual;

UPPER_CHAR

----------

SQL COURSE

--单词首子母转大写

SQL> select initcap(ename) as initcap_name scott.emp where ename = 'albert';

INITCAP_NAME

----------

Albert

--字符的拼接,||concat等效

SQL> select ename || ' is an ' || job from scott.emp where ename = 'SCOTT';

ENAME||'ISAN'||JOB

---------------------------

SCOTT is an ANALYST

SQL> select concat(concat(ename,' is an '),job) as concat_str from scott.emp where ename = 'SCOTT';

CONCAT_STR

--------------------------

SCOTT is an ANALYST

--SUBSTR,截取子串,下面的例子从第个位置开始连续截取个字符

SQL> select substr('HelloWorld',2,3) from dual;

SUB

---

ell

--LENGTH 取字符串长度

SQL> select length('HelloWord') as String_length from dual;

STRING_LENGTH

-------------

9

-- lpad | rpad 字符串的填充

-- lpad,左填充,直到达到指定长度为止

SQL> select lpad('salary',10,'*') as String_Lpad from dual;

STRING_LPA

----------

****salary

--指定长度为,多出的部分被截断

SQL> select lpad('salary',4,'*') as String_Lpad from dual;

STRI

----

sala

--rpad,右填充,直到达到指定长度为止

SQL> select rpad('salary',10,'|') as String_Rpad from dual;

STRING_RPA

----------

salary||||

--指定长度为,多出的部分被截断

SQL> select rpad('salary',5,'|') as String_Rpad from dual;

STRIN

-----

salar

-- trim 删除首尾字符,格式:trim('h' from 'hello hello'),默认的方式为both

SQL> select trim('h' from 'hello helloh') as String_Trim from dual;

STRING_TRI

----------

ello hello

-- trim 删除首尾字符,指定leading只删首部

SQL> select trim(leading 'h' from 'hello helloh') as Trim_Leading from dual;

TRIM_LEADIN

-----------

ello helloh

-- trim 删除首尾字符,指定trailing只删尾部

SQL> select trim(trailing 'h' from 'hello helloh') as Trim_Trailling from dual;

TRIM_TRAILL

-----------

hello hello

--rtrim ,ltrim

SQL> select rtrim('hello helloh','h') as Rtrim_String ,

2 ltrim('hello helloh','h') as Ltrim_String

3 from dual;

RTRIM_STRIN LTRIM_STRIN

----------- -----------

hello hello ello helloh

--replace 字符替换

SQL> select replace('Jack and Johnson','J','Bl') as String_Replace from dual;

STRING_REPLACE

------------------

Black and Blohnson

--instr 下面的示例从第个字符开始,返回第二个OR的位置

SQL> select instr('CORPORATE FOLLOR','OR',3,2) as Instring from dual;

INSTRING

----------

15

--round 四舍五入函数

SQL> select round(102.253,2) as round_func from dual;

ROUND_FUNC

----------

102.25

SQL> select round(102.253,0) as round_func from dual;

ROUND_FUNC

----------

102

SQL> select round(102.253,-1) as round_func from dual;

ROUND_FUNC

----------

100

--trunc 截断函数

SQL> select trunc(2010.328) as trunc_func_1,

2 trunc(2010.328,1) as trunc_func_2,

3 trunc(2010.328,-1) as trunc_func_3

4 from dual;

TRUNC_FUNC_1 TRUNC_FUNC_2 TRUNC_FUNC_3

------------ ------------ ------------

2010 2010.3 2010

--#MOD(m,n) 取余函数

SQL> select mod(2010,3) as mod_func from dual;

MOD_FUNC

----------

0

SQL> select mod(5,3) as mod_func from dual;

MOD_FUNC

----------

2

--ceil(x) 返回特定的最小数(大于等于x的最小整数)

SQL> select ceil(593.3) as ceil_func from dual;

CEIL_FUNC

----------

594

--floor(x) 返回特定的最大数(小于等于x的最大整数)

SQL> select floor(593.4) as floor_func from dual;

FLOOR_FUNC

----------

593

--month_between(日期,日期)两个日期相差的月数

SQL> select empno,ename,job,months_between(sysdate,hiredate) as diff_month from scott.emp;

EMPNO ENAME JOB DIFF_MONTH

---------- ---------- --------- ----------

9999 albert

7369 SMITH CLERK 351.370601

7499 ALLEN SALESMAN 349.273827

7521 WARD SALESMAN 349.209311

7566 JONES MANAGER 347.854472

7654 MARTIN SALESMAN 342

7698 BLAKE MANAGER 346.88673

7782 CLARK MANAGER 345.628666

7788 SCOTT ANALYST 275.306085

7839 KING PRESIDENT 340.370601

7844 TURNER SALESMAN 342.660924

SQL> select * from scott.emp where months_between(sysdate,hiredate) <= 300;

EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO

---------- ---------- --------- ---------- ---------- ---------- ---------- ----------

7788 SCOTT ANALYST 7566 1987-04-19 3000 20

7876 ADAMS CLERK 7788 1987-05-23 1100 20

--add_months(日期,n) 返回在指定的日期后,加上n个月后的日期

SQL> select add_months(sysdate,5) from dual;

ADD_MONTHS

----------

2010-08-28

--last_day(sysdate) 返回指定日期所在月最后一天的日期

SQL> select last_day(sysdate) from dual;

LAST_DAY(S

----------

2010-03-31

--next_day 返回指定日期的下一day的时间值,day是一个文本串,比如SATURDAY

SQL> select next_day('05-FEB-2005','TUESDAY') as nextday from dual;

NEXTDAY

---------

08-FEB-05

/*EXTRACT*/

SQL> select extract(day from sysdate) from dual;

EXTRACT(DAYFROMSYSDATE)

-----------------------

28

SQL> select extract(month from sysdate) from dual;

EXTRACT(MONTHFROMSYSDATE)

-------------------------

3

SQL> select extract(year from sysdate) from dual;

EXTRACT(YEARFROMSYSDATE)

------------------------

2010

--使用ROUND TRUNC函数处理日期

--round(sysdate,'MONTH') 当月第一天

--round(sysdate,'YEAR') 当年的第一天

--trunc(sysdate,'MONTH') 当月第一天

--trunc(sysdate,'YEAR') 当年的第一天

SQL> select sysdate,round(sysdate,'MONTH'),round(sysdate,'YEAR'),

2 trunc(sysdate,'MONTH'),trunc(sysdate,'YEAR')

3 from dual;

SYSDATE ROUND(SYS ROUND(SYS TRUNC(SYS TRUNC(SYS

--------- --------- --------- --------- ---------

15-APR-10 01-APR-10 01-JAN-10 01-APR-10 01-JAN-10

--类型转换

-- to_char

SQL> select empno,ename,hiredate,to_char(hiredate,'fmDD Month YYYY') as hiredate2,

2 to_char(hiredate,'DD MM YYYY') as hiredate3

3 from scott.emp

4 where sal > 2500;

EMPNO ENAME HIREDATE HIREDATE2 HIREDATE3

---------- ---------- --------- ----------------- ----------

7566 JONES 02-APR-81 2 April 1981 02 04 1981

7698 BLAKE 01-MAY-81 1 May 1981 01 05 1981

7788 SCOTT 19-APR-87 19 April 1987 19 04 1987

7839 KING 17-NOV-81 17 November 1981 17 11 1981

7902 FORD 03-DEC-81 3 December 1981 03 12 1981

SQL> select to_char(12345.67) as char1,to_char(12345.67,'99,999.99') as char2

2 from dual;

CHAR1 CHAR2

-------- ----------

12345.67 12,345.67

--当被转换的数据位数超过格式指定位数,则出现错误。

SQL> select to_char(12345678.90,'99,999.99') as char1 from dual;

CHAR1

----------

##########

--to_number

SQL> select to_number('970.13') as number1,

2 to_number('970.13') + 35.5 as nunber2,

3 to_number('-$12,345.67','$99,999.99') as number3

4 from dual;

NUMBER1 NUNBER2 NUMBER3

---------- ---------- ----------

970.13 1005.63 -12345.67

--to_date

--注意:最终日期采用默认格式DD-MON—YY显示

SQL> select to_date('05-JUL-2008') as date1,to_date('05-JUL-08') as date2,

2 to_date('July 5,2008','MONTH DD,YYYY') as date3,

3 to_date('7.4.08','MM.DD.YY') as date4

4 from dual;

DATE1 DATE2 DATE3 DATE4

--------- --------- --------- ---------

05-JUL-08 05-JUL-08 05-JUL-08 04-JUL-08

--case when

SQL> select empno,ename,sal,deptno,case deptno when 20 then 1.10 * sal

2 when 30 then 1.20 * sal

3 else 1.30 * sal end as newsal

4 from scott.emp order by deptno;

EMPNO ENAME SAL DEPTNO NEWSAL

---------- ---------- ---------- ---------- ----------

7782 CLARK 2450 10 3185

7839 KING 5000 10 6500

7934 MILLER 1300 10 1690

7566 JONES 2975 20 3272.5

7902 FORD 3000 20 3300

7876 ADAMS 1100 20 1210

7369 SMITH 800 20 880

7788 SCOTT 3000 20 3300

7521 WARD 1250 30 1500

7844 TURNER 1500 30 1800

/*DECODE*/

SQL> select empno,ename,job,sal, decode(job,'CLERK',sal*1.5,'SALESMAN',sal*1.1,sal*1.2) as newsal from scott.emp;

EMPNO ENAME JOB SAL NEWSAL

---------- ---------- --------- ---------- ----------

9999 albert

7369 SMITH CLERK 800 1200

7499 ALLEN SALESMAN 1600 1760

7521 WARD SALESMAN 1250 1375

7566 JONES MANAGER 2975 3570

7654 MARTIN SALESMAN 1250 1375

7698 BLAKE MANAGER 2850 3420

7782 CLARK MANAGER 2450 2940

7788 SCOTT ANALYST 3000 3600

7839 KING PRESIDENT 5000 6000

7844 TURNER SALESMAN 1500 1650

五、更多

SQL基础-->过滤和排序

SQL 基础-->SELECT 查询

SQL/PLSQL 基础

Oracle相关

分享到:
评论

相关推荐

    SQL 标量函数----->日期函数 day() 、month()、year()、DATEADD()、ATEDIFF()、DATENAME()、DATEPART() GETDATE()

    ### SQL标量函数详解:日期函数day()、month()、year()、DATEADD()、DATEDIFF()、DATENAME()、...综上所述,以上这些日期函数在SQL中非常常用,通过合理运用这些函数,可以极大地提高日期时间数据处理的效率和准确性。

    ---------------SQL常用函数1

    在本文中,我们将深入探讨SQL的一些常用函数和语句,这些是任何数据库管理员或开发人员都应该熟悉的基础知识。 首先,我们关注数据操作: 1. **SELECT**:这是SQL中最基本的语句,用于从数据库表中检索数据行和列...

    SQL常用函数大全

    SQLServer2000虽然已经相对较老,但其提供的函数集仍然是现代SQL版本的基础。以下是一些SQLServer2000中常用的函数分类及其详细解释: 1. **数值函数**: - `ABS()`: 计算并返回一个数值的绝对值。 - `SQRT()`: ...

    Oracle11g SQL基础-实验手册.pdf

    Oracle11g SQL基础实验手册详细介绍了使用Oracle 11g数据库管理系统时,编写和执行基本SQL语句所需的各项技能。Oracle 11g是甲骨文公司推出的一个稳定的企业级数据库版本,支持大型事务处理和数据仓库应用。SQL是...

    17.函数整理(T-SQL 版).pdf

    文档的其余部分可能还包含有关这些函数更多细节和示例,但根据提供的内容来看,涵盖了T-SQL中常用函数的基本知识。这些函数对于进行数据操作和数据处理是十分关键的,是数据库开发者和数据库管理人员必须掌握的基础...

    SQL基础教程-Mick-示例程序&习题答案

    本教程“SQL基础教程-Mick-示例程序&习题答案”由Mick编写,旨在为初学者提供一个实用的学习资源,帮助他们快速掌握SQL的核心概念和操作。 1. SQL基础知识: - 数据类型:SQL支持多种数据类型,如整数(INT)、...

    greenplum常用函数-基础

    在数据仓库的使用过程中,掌握一些常用函数对于提升工作效率和维护数据准确性至关重要。根据给定的文件内容,我们将详细介绍Greenplum中常用的基础函数。 首先,创建表是数据库管理中的基础操作。在Greenplum中,...

    ERP源码20110803

    轻松实现报表显示、过滤、打印、导出等一体化集成功能。提供VB.net、C#丰富使用例子,报表如何调用一目了然。 工具特点: 1、可根据SQL语句自动生成报表...4,添加 基础档案-&gt;业务-&gt;常用摘要 5,添加新模块 帐务管理

    SQL基础语法讲解以及常用函数

    ### SQL基础语法与常用函数详解 #### 一、SQL基础语法概述 SQL(Structured Query Language,结构化查询语言)是一种用于管理关系数据库的标准语言。它主要用于处理存储在关系数据库管理系统中的数据,支持数据...

    SQLServer2000常用函数大全

    这个资料包"SQLServer2000常用函数大全"涵盖了日期处理、自动编号以及存储过程和函数编写的相关例程,旨在帮助用户更好地理解和运用这些功能。 1. **日期处理函数**: - `GETDATE()`:返回当前系统的日期和时间。 ...

    三层ERP源代码

    非常好非常专业的ERP源码,VB.NET编写,如果你是程序员,可以在此基础上进行二次开发 工具特点: 1、可根据SQL语句自动生成报表格式,打印格式,用户只要...4,添加 基础档案-&gt;业务-&gt;常用摘要 5,添加新模块 帐务管理

    sql--常用sql语句查询

    ### SQL基础查询语句 1. **查找含有特定关键词的数据:** - `SELECT * FROM dictionary WHERE INSTR(comments, 'index') &gt; 0;` 这条语句用于从`dictionary`表中筛选出`comments`字段中含有“index”关键字的所有...

    SQL-查询和-SQL-函数PPT课件.ppt

    本篇PPT课件主要涵盖了Oracle数据库的基础知识以及SQL查询和函数的使用。 首先,Oracle服务器由两大部分构成:Oracle数据库和Oracle实例。Oracle实例包含系统全局区(SGA)内存结构,这些内存区域用于存储数据库...

    sqlserver常用函数及个人收藏

    这些函数是SQL Server中基础但非常实用的部分,了解并熟练掌握它们对于数据库管理、数据查询和应用程序开发至关重要。通过深入理解和实践,你可以编写出更加高效和精确的SQL语句,从而提升工作效率。

    oracle SQL查询和SQL函数手册 基本涵盖了常用的

    1. **SQL基础概念** - **SQL**(Structured Query Language)是一种用于管理关系数据库的标准语言,包括数据查询、数据更新、数据插入和数据删除等操作。 - **Oracle SQL** 是Oracle公司对SQL标准的实现,包含了...

    sql数据库基础知识整理,常用函数及常用语法

    SQL数据库基础知识是数据库管理和开发的重要组成部分,其中包括了各种函数和语法。下面我们将深入探讨这些知识点。 首先,我们来看聚合函数,它们在数据处理中极为常见。`MAX()`、`MIN()`用于找出列中的最大和...

    sql标准--------------

    5. 过程化SQL(PL/SQL或类似的):在某些数据库系统中,如Oracle,支持嵌入式过程语言,允许编写存储过程、函数和触发器等。 6. 游标:允许程序逐行处理查询结果,提高了处理大量数据的灵活性。 7. 视图:虚拟表,...

    精通SQL--结构化查询语言详解

    第1章 数据库与sql基础 1 1.1 数据库的基本概念 1 1.1.1 数据库的由来 1 1.1.2 数据库系统的概念 3 1.2 数据库系统的结构、组成及工作流程 3 1.2.1 数据库的体系结构 3 1.2.2 数据库系统的组成 4 1.2.3 ...

Global site tag (gtag.js) - Google Analytics