- 浏览: 55534 次
- 性别:
- 来自: 武汉
文章分类
最新评论
-
dvd_rom:
如此说来,美国人整夜整夜都不睡觉,也没出什么事啊?
太晚睡觉等于自杀 -
生于菇乡:
嗯,讲的很是 精辟
java中常用集合类,接口 -
fish2007:
对现有的应用实例进行分析是学习模式的一个很好的途径,应当注意学 ...
如何掌握并在实践中自如运用设计模式 -
cobrano1:
数据缓冲区那里应该是A=C+D
Oracle体系结构之-内存结构 -
cobrano1:
博主编辑有问题, 有重复的地方
Oracle体系结构之-内存结构
在SQLPLUS下,实现中-英字符集转换
alter session set nls_language='AMERICAN';
alter session set nls_language='SIMPLIFIED CHINESE';
主要知识点:
一、有关表的操作
1)建表
create table test as select * from dept; --从已知表复制数据和结构
create table test as select * from dept where 1=2; --从已知表复制结构但不包括数据
2)插入数据:
insert into test select * from dept;
二、运算符
算术运算符:+ - * / 可以在select 语句中使用
连接运算符:|| select deptno|| dname from dept;
比较运算符:> >= = != < <= like between is null in
逻辑运算符:not and or
集合运算符: intersect ,union, union all, minus
要求:对应集合的列数和数据类型相同
查询中不能包含long 列
列的标签是第一个集合的标签
使用order by时,必须使用位置序号,不能使用列名
例:集合运算符的使用:
intersect ,union, union all, minus
select * from emp intersect select * from emp where deptno=10 ;
select * from emp minus select * from emp where deptno=10;
select * from emp where deptno=10 union select * from emp where deptno in (10,20); --不包括重复行
select * from emp where deptno=10 union all select * from emp where deptno in (10,20); --包括重复行
三,常用 ORACLE 函数
sysdate为系统日期 dual为虚表
一)日期函数[重点掌握前四个日期函数]
1,add_months[返回日期加(减)指定月份后(前)的日期]
select sysdate S1,add_months(sysdate,10) S2,
add_months(sysdate,5) S3 from dual;
2,last_day [返回该月最后一天的日期]
select last_day(sysdate) from dual;
3,months_between[返回日期之间的月份数]
select sysdate S1, months_between('1-4月-04',sysdate) S2,
months_between('1-4月-04','1-2月-04') S3 from dual
4,next_day(d,day): 返回下个星期的日期,day为1-7或星期日-星期六,1表示星期日
select sysdate S1,next_day(sysdate,1) S2,
next_day(sysdate,'星期日') S3 FROM DUAL
5,round[舍入到最接近的日期](day:舍入到最接近的星期日)
select sysdate S1,
round(sysdate) S2 ,
round(sysdate,'year') YEAR,
round(sysdate,'month') MONTH ,
round(sysdate,'day') DAY from dual
6,trunc[截断到最接近的日期]
select sysdate S1,
trunc(sysdate) S2,
trunc(sysdate,'year') YEAR,
trunc(sysdate,'month') MONTH ,
trunc(sysdate,'day') DAY from dual
7,返回日期列表中最晚日期
select greatest('01-1月-04','04-1月-04','10-2月-04') from dual
二)字符函数(可用于字面字符或数据库列)
1,字符串截取
select substr('abcdef',1,3) from dual
2,查找子串位置
select instr('abcfdgfdhd','fd') from dual
3,字符串连接
select 'HELLO'||'hello world' from dual;
4, 1)去掉字符串中的空格
select ltrim(' abc') s1,
rtrim('zhang ') s2,
trim(' zhang ') s3 from dual
2)去掉前导和后缀
select trim(leading 9 from 9998767999) s1,
trim(trailing 9 from 9998767999) s2,
trim(9 from 9998767999) s3 from dual;
5,返回字符串首字母的Ascii值
select ascii('a') from dual
6,返回ascii值对应的字母
select chr(97) from dual
7,计算字符串长度
select length('abcdef') from dual
8,initcap(首字母变大写) ,lower(变小写),upper(变大写)
select lower('ABC') s1,
upper('def') s2,
initcap('efg') s3 from dual;
9,Replace
select replace('abc','b','xy') from dual;
10,translate
select translate('abc','b','xx') from dual; -- x是1位
11,lpad [左添充] rpad [右填充](用于控制输出格式)
select lpad('func',15,'=') s1, rpad('func',15,'-') s2 from dual;
select lpad(dname,14,'=') from dept;
12, decode[实现if ..then 逻辑]
select deptno,decode(deptno,10,'1',20,'2',30,'3','其他') from dept;
三)数字函数
1,取整函数(ceil 向上取整,floor 向下取整)
select ceil(66.6) N1,floor(66.6) N2 from dual;
2, 取幂(power) 和 求平方根(sqrt)
select power(3,2) N1,sqrt(9) N2 from dual;
3,求余
select mod(9,5) from dual;
4,返回固定小数位数 (round:四舍五入,trunc:直接截断)
select round(66.667,2) N1,trunc(66.667,2) N2 from dual;
5,返回值的符号(正数返回为1,负数为-1)
select sign(-32),sign(293) from dual;
四)转换函数
1,to_char()[将日期和数字类型转换成字符类型]
1) select to_char(sysdate) s1,
to_char(sysdate,'yyyy-mm-dd') s2,
to_char(sysdate,'yyyy') s3,
to_char(sysdate,'yyyy-mm-dd hh12:mi:ss') s4,
to_char(sysdate, 'hh24:mi:ss') s5,
to_char(sysdate,'DAY') s6 from dual;
2) select sal,to_char(sal,'$99999') n1,to_char(sal,'$99,999') n2 from emp
2, to_date()[将字符类型转换为日期类型]
insert into emp(empno,hiredate) values(8000,to_date('2004-10-10','yyyy-mm-dd'));
3, to_number() 转换为数字类型
select to_number(to_char(sysdate,'hh12')) from dual; //以数字显示的小时数
五)其他函数
user:
返回登录的用户名称
select user from dual;
vsize:
返回表达式所需的字节数
select vsize('HELLO') from dual;
nvl(ex1,ex2):
ex1值为空则返回ex2,否则返回该值本身ex1(常用)
例:如果雇员没有佣金,将显示0,否则显示佣金
select comm,nvl(comm,0) from emp;
nullif(ex1,ex2):
值相等返空,否则返回第一个值
例:如果工资和佣金相等,则显示空,否则显示工资
select nullif(sal,comm),sal,comm from emp;
coalesce:
返回列表中第一个非空表达式
select comm,sal,coalesce(comm,sal,sal*10) from emp;
nvl2(ex1,ex2,ex3) :
如果ex1不为空,显示ex2,否则显示ex3
如:查看有佣金的雇员姓名以及他们的佣金
select nvl2(comm,ename,') as HaveCommName,comm from emp;
六)分组函数
max min avg count sum
1,整个结果集是一个组
1) 求部门30 的最高工资,最低工资,平均工资,总人数,有工作的人数,工种数量及工资总和
select max(ename),max(sal),
min(ename),min(sal),
avg(sal),
count(*) ,count(job),count(distinct(job)) ,
sum(sal) from emp where deptno=30;
2, 带group by 和 having 的分组
1)按部门分组求最高工资,最低工资,总人数,有工作的人数,工种数量及工资总和
select deptno, max(ename),max(sal),
min(ename),min(sal),
avg(sal),
count(*) ,count(job),count(distinct(job)) ,
sum(sal) from emp group by deptno;
2)部门30的最高工资,最低工资,总人数,有工作的人数,工种数量及工资总和
select deptno, max(ename),max(sal),
min(ename),min(sal),
avg(sal),
count(*) ,count(job),count(distinct(job)) ,
sum(sal) from emp group by deptno having deptno=30;
3, stddev 返回一组值的标准偏差
select deptno,stddev(sal) from emp group by deptno;
variance 返回一组值的方差差
select deptno,variance(sal) from emp group by deptno;
4, 带有rollup和cube操作符的Group By
rollup 按分组的第一个列进行统计和最后的小计
cube 按分组的所有列的进行统计和最后的小计
select deptno,job ,sum(sal) from emp group by deptno,job;
select deptno,job ,sum(sal) from emp group by rollup(deptno,job);
cube 产生组内所有列的统计和最后的小计
select deptno,job ,sum(sal) from emp group by cube(deptno,job);
七、临时表
只在会话期间或在事务处理期间存在的表.
临时表在插入数据时,动态分配空间
create global temporary table temp_dept
(dno number,
dname varchar2(10))
on commit delete rows;
insert into temp_dept values(10,'ABC');
commit;
select * from temp_dept; --无数据显示,数据自动清除
on commit preserve rows:在会话期间表一直可以存在(保留数据)
on commit delete rows:事务结束清除数据(在事务结束时自动删除表的数据)
========================== 连接操作 ================================
例如有A,B两张表:
A表 B表
a b c d
1 0 4 7
2 9 1 5
select * from A,B where A.a = B.c
等同于
select * from A join B on A.a = B.c
结果:
a b c d
1 0 1 5
左连接:
select * from A,B where A.a = B.c(+)
等同于
select * from A left join B on A.a = B.c
即以A表查询为主,附带查询出满足A.a = B.c条件的B表中的结果
结果:
a b c d
1 0 1 5
2 9
右连接:
select * from A,B where A.a(+) = B.c
等同于
select * from A right join B on A.a = B.c
此查询为左连接,即以A表查询为主,附带查询出满足A.a = B.c条件的B表中的结果
结果:
c d a b
1 5 1 0
4 7
===============================================================
===================== oracle
函数 ===============================
DECODE:
decode(条件,值1,翻译值1,值2,翻译值2,...值n,翻译值n,缺省值)
A表
a b c
1 3 0
3 2 9
1 0 5
3 7 7
5 5 9
select decode(A.a,1,4,3,8),A.b,A.c form A
意思:如果A.a的值为1,则将A.a的值查询为4,如果A.a的值为3,则将A.a的值查询为8
结果:
a b c
4 3 0
8 2 9
4 0 5
8 7 7
5 5 9
select decode(A.a,1,4,8),A.b,A.c form A
意思:如果A.a的值为1,则将A.a的值查询为4,否则A.a的值查询为8
结果:
a b c
4 3 0
8 2 9
4 0 5
8 7 7
8 5 9
select decode(A.a,1,4,3,8,7),A.b,A.c form A
意思:如果A.a的值为1,则将A.a的值查询为4,如果A.a的值为3,则将A.a的值查询为8,否则查询为7
结果:
a b c
4 3 0
8 2 9
4 0 5
8 7 7
7 5 9
===============================================================
==========================SEQUENCE=====================================
SEQUENCE: CREATE SEQUENCE LOCATIONS_SEQ
INCREMENT BY 1
START WITH 1
MAXVALUE 9900
MINVALUE 1
SELECT LOCATIONS_SEQ.currval FROM DUAL ;
SELECT LOCATIONS_SEQ.nextval FROM DUAL ;
============================SEQUENCE===================================
============================函数===================================
日期函数:
add_months(d,n) 日期d加n个月
last_day(d) 包含d的月份的最后一天的日期
month_between(d,e) 日期d与e之间的月份数,e先于d
new_time(d,a,b) a时区的日期和时间d在b时区的日期和时间
next_day(d,day) 比日期d晚,由day指定的周几的日期
sysdate 当前的系统日期和时间
greatest(d1,d2,...dn) 给出的日期列表中最后的日期
least(d1,k2,...dn) 给出的日期列表中最早的日期
to_char(d [,fmt]) 日期d按fmt指定的格式转变成字符串
to_date(st [,fmt]) 字符串st按fmt指定的格式转成日期值,若fmt忽略,st要用缺省格式
round(d [,fmt]) 日期d按fmt指定格式舍入到最近的日期
trunc(d [,fmt]) 日期d按fmt指定格式截断到最近的日期
分组函数:
avg([distinct/all] n) 列n的平均值
count([all] *) 返回查询范围内的行数包括重复值和空值
count([distinct/all] n) 非空值的行数
max([distinct/all] n) 该列或表达式的最大值
min([distinct/all] n) 该列或表达式的最小值
stdev([distinct/all] n) 该列或表达式的标准偏差,忽略空值
sum([distinct/all] n) 该列或表达式的总和
variance([distinct/all] n) 该列或表达式的方差,忽略空值
数值函数:
abs(m) m的绝对值
mod(m,n) m被n除后的余数
power(m,n) m的n次方
round(m[,n]) m四舍五入至小数点后n位的值(n缺省为0)
trunc(m[,n]) m截断n位小数位的值(n缺省为0)
字符函数:
initcap(st) 返回st将每个单词的首字母大写,所有其他字母小写
lower(st) 返回st将每个单词的字母全部小写
upper(st) 返回st将每个单词的字母全部大写
concat(st1,st2) 返回st为st2接st1的末尾(可用操作符"||")
lpad(st1,n[,st2]) 返回右对齐的st,st为在st1的左边用st2填充直至长度为n,st2的缺省为空格
rpad(st1,n[,st2]) 返回左对齐的st,st为在st1的右边用st2填充直至长度为n,st2的缺省为空格
ltrim(st[,set]) 返回st,st为从左边删除set中字符直到第一个不是set中的字符。缺省时,指的是空格
rtrim(st[,set]) 返回st,st为从右边删除set中字符直到第一个不是set中的字符。缺省时,指的是空格
replace(st,search_st[,replace_st]) 将每次在st中出现的search_st用replace_st替换,返回一个st。缺省时,删除search_st
substr(st,m[,n]) n=返回st串的子串,从m位置开始,取n个字符长。缺省时,一直返回到st末端
length(st) 数值,返回st中的字符数
instr(st1,st2[,m[,n]]) 数值,返回st1从第m字符开始,st2第n次出现的位置,m及n的缺省值为1
发表评论
-
黑客狙击Oracle系统的八大套路
2009-03-18 16:32 835简介 Oracle的销售 ... -
SQL游标
2009-03-09 11:00 897问题描述:有以下2 ... -
Oracle体系结构之-内存结构
2009-03-04 17:19 984一、系统全局区(SGA)系 ... -
Oracle体系结构之-逻辑结构
2009-03-04 17:18 938一、Oracle 逻辑结构简介 oracle的逻 ... -
Oracle体系结构之-Oracle中各种名称
2009-03-04 15:08 1035一、数据库名 数据库名是数据库的“身份证号码”,用于标示一个 ... -
Oracle体系结构之-数据库、表空间、实例简介
2009-03-04 15:05 2007一、数据库 数据库顾名思义是数据的集合,而Oracle则是 ... -
Oracle体系结构之-连接配置结构
2009-03-04 14:50 895Oracle的连接可以分成两种: 一、专用服务器连接结构(D ... -
MySql常用命令总结
2009-03-02 22:11 6581:使用SHOW语句找出在服务器上当前存在什么数据库: ... -
oracle临时表-优化查询速度
2009-02-28 17:30 9551、前言 目前所 ... -
SYSDATE与CURRENT_DATE区别
2009-02-25 16:43 2228SYSDATE与CURRENT_DATE都是取当前 ... -
Oracle中Varchar 型数据 计算时间差
2009-02-24 21:18 2268在开发程序时,我们经常会遇到要计算从startTime到 ... -
ORACLE查询树型关系(start with connect by prior )
2009-02-20 10:05 2502oracle中的select语句可以用START WITH.. ... -
SQLyog
2009-02-19 19:59 1557SQLyog是MySQL的客户端工具,这个工具介于mysql ...
相关推荐
文档中汇总了oracle PLSQL常用方法,希望对大家有用,有需要的可下载。
Oracle PL/SQL 中的常用方法汇总 Oracle PL/SQL 是一种强大的编程语言,广泛应用于 Oracle 数据库管理系统中。下面是 Oracle PL/SQL 中的一些常用方法汇总: 一、表操作 在 Oracle PL/SQL 中,表操作是最基本也是...
根据给定的信息,本文将对PL/SQL中的几个核心知识点进行详细介绍:表操作、运算符以及常用的Oracle函数。 ### 一、有关表的操作 #### 1. 创建表 在PL/SQL中创建表通常有两种方式: - **通过查询语句创建表**: `...
本文将对PLSQL常用方法进行汇总,包括表操作、运算符、集合运算符、 Oracle 函数等。 一、有关表的操作 在PLSQL中,表操作是最基本的操作之一。常用的表操作包括建表、插入数据、删除数据、更新数据等。 1. 建表...
本文将根据提供的标题“PLSQL常用语句汇总”、描述及部分内容,深入探讨PL/SQL中的关键知识点,涵盖表操作、运算符、以及常用的Oracle函数,帮助读者全面理解并熟练应用这些技术。 #### 一、表操作 表是数据库的...
oracle_PLSQL_语法详细手册&11g;.doc ORACLE_维护手册.doc oracle+110个常用函数.doc oracle分析函数.doc Oracle数据库日常维护手册.docx PLSQL开发笔记和小结.doc 这些文档还不错,自己也想里面添加了一些语法。
### Oracle9i SQL与PL/SQL...随着Oracle产品的不断演进,尽管本书针对的是Oracle9i版本,但其中的原理和方法依然适用于后续版本的学习和实践。对于追求高效、安全数据管理的专业人士而言,这无疑是一份不可多得的资源。
本资料“PLSQL使用大全”深入探讨了PLSQL的各种语法和常用的SQL函数,对于理解和掌握Oracle数据库的开发至关重要。 1. **PLSQL基本结构** - PLSQL由声明部分、执行部分和异常处理部分组成。声明部分包括变量、常量...
Oracle 常用 SQL 语句汇总 Oracle 是一个功能强大且复杂的关系数据库管理系统,它提供了多种 SQL 语句来管理和操作数据库。在本文中,我们将详细介绍 Oracle 中常用的 SQL 语句,包括数据控制语句(DML)、数据定义...
### Oracle PL/SQL 编程基础与应用 #### 一、SQL*Plus 基础命令 在 Oracle 数据库管理中,SQL*Plus 是一个非常重要的工具,它可以帮助用户执行 SQL 语句并查看结果。以下是一些常用的基础命令: 1. **数据定义...
### PL/SQL Developer 教程知识点汇总 #### 一、简介 **PL/SQL Developer**是一款功能强大的集成开发环境(IDE),专为Oracle数据库的PL/SQL编程而设计。它提供了一系列工具,帮助开发者高效地编写、调试和优化PL/...
这里提供的"Oracle常用高级语句.rar"压缩包包含了多个与Oracle数据库相关的文档,涵盖了PL/SQL编程、函数应用、控制流以及数据库管理等多个方面。下面将详细解析这些文件中的关键知识点。 1. **PLSQL美化**: PL/...
### PL/SQL Developer 教程知识点汇总 #### 一、简介 **PL/SQL Developer** 是一款专为 Oracle 数据库设计的集成开发环境(IDE),它提供了丰富的功能来支持 PL/SQL 的开发、测试和调试过程。相比于传统的 Oracle ...
oracle入门级PPT文档,PLSQL Developer操作界面讲解、数据结构说明,建表语句、增删改查数据,以及常用的sql查询摘要汇总,试图基础语法等,节省您的学习时间。
通过上述知识点的详细解释,我们可以看到,PLSQL培训教程涵盖了从基础SQL概念到高级PL/SQL编程技术的广泛内容,旨在培养学员掌握Oracle数据库管理和应用程序开发的核心技能。无论是初学者还是有一定经验的数据库管理...
### PL/SQL培训教程知识点详解 #### UNIT1: SQL、PL/SQL概要 ...以上是针对“PL/SQL培训教程”中的关键知识点的详细解析,旨在帮助学习者深入了解SQL和PL/SQL的基础知识及其在Oracle数据库中的应用。
### Oracle SQL 学习资料详解 #### 一、Oracle SQL 概述 Oracle SQL 是 Oracle 数据库的标准查询语言,用于管理、检索和处理 Oracle 数据库中的数据。它提供了丰富的功能来执行各种数据库操作,包括数据定义(如...