请问Oracle数据库存储过程中:=是什么意思

jee1987vip 2010-01-19 11:00:04
能举例说明吗,谢谢大家
...全文
1454 19 打赏 收藏 转发到动态 举报
写回复
用AI写文章
19 条回复
切换为时间正序
请发表友善的回复…
发表回复
happyzhang2007 2011-12-16
  • 打赏
  • 举报
回复
[Quote=引用 17 楼 jinglingqaz 的回复:]
:= 赋值的意思区别于java的 =
|| 连接意思区别于java的 +
[/Quote]
+1
SambaGao 2010-01-20
  • 打赏
  • 举报
回复
看来楼主是刚学习sql 我也正在学。可以的话。一起学吧。
Hemes_MC 2010-01-20
  • 打赏
  • 举报
回复
[Quote=引用 13 楼 sxq129601 的回复:]
赋值
[/Quote]

来拿分的
sxq129601 2010-01-20
  • 打赏
  • 举报
回复
赋值
fan123123 2010-01-20
  • 打赏
  • 举报
回复
5 SQL*PLUS报表功能
SQL*PLUS的一些基本格式命令
column deptno heading department

column ename heading name

column sal heading salary

column sal format $99,999.00

ttitle sample report for|hitech corp

btitle strictly confidential

break on deptno

compute sum of sal on deptno

run

表头和表尾
ttitle sample report for|hitech corp
btitle right strictly confidential

“|”表示换行,结尾不必加分号
选项有三种:left right center

使用TTITLE,系统将自动地在每页的顶部显示日期和页号。
TTITLET和BTITLE命令有效,直至重新设置表头或表尾,或退出SQL*PLUS。

下面命令使标题语句失效
TTITLE OFF
BTITLE OFF

列名
column命令定义用于显示列名
若名字为一个单词,不必加引号
column ename heading employee

column ename heading 'employee|name'
(|为换行)

取消栏定义
column ename clear

列的格式
column ename format A15

column sal format $9,999.99

column comm like sal

like子句,使得某一列的格式参照另一列格式,它拷贝列名及其格式

控制记录显示分组顺序
break on deptno
(不显示重复值)

select deptno,ename
from emp
order by deptno;
(ORDER BY子句用于控制BREAK)

显示为
10 clark
niller
20 smith
scott
30 allen
blake

每次只有一个BREAK命令起作用,但一次可以在多个列上使用BREAK命令
break on 列名1 on 列名2

记录分组
break on deptno skip 2
select deptno,ename
from emp
order by deptno;

每个deptno之间空两行
clear break(取消BREAK命令)
break on page(每次从一新页开始)
break on report(每次从一新报表开始)
break on page on report(联合使用)

分组计算
break on deptno skip 2
compute sum of sal on deptno
计算每个部门的工资总和
skip子句使部门之间的信息分隔开

其他计算命令
compute avg of sal on deptno(平均值)
count 非空值的总数
MAX 最大值
MIN 最小值
STD 标准偏差
VAR 协方差
NUMBER 行数

使compute命令失效
一旦定义了COMPUTE,则一直有效,直到
关闭COMPUTE(clear compute)

SQL/PLUS环境命令
show 选项
(显示当前参数设置情况)

show all(显示全部参数)

设置参数
set 选项 值或开关

set autocommit on

SET命令包括
set autocommit {off|on|immediate}
(自动提交,OFF缺省)

set echo {off|on}
(命令文件执行,是否在终端上显示命令本身,OFF缺省)

set feedback {off|on}
(ON:查询结束时,给出结果,记录数的信息,缺省;
OFF:无查询结果,记录数的信息)

set heading {off|on}
(ON:列的头标在报表上显示,缺省;OFF:不在报表上显示)

set linesize {n}
一行显示的最大字符数,缺省为80

set pagesize {n}
每页的行数,缺省是14

set pause {off|on|text}
(ON:当报表超过一页时,每显示一屏就暂停显示,等待用户打回车键,再接着显示;
OFF:页与页不停顿,缺省;text:页与页停顿,并向用户提示信息)

SET BUFFER buffer
设置当头的命令缓冲区,通常情况下,SQL命令缓冲区已为当前缓冲区。
由于SQL命令缓冲区只能存放一条SQL命令,
所以可用其它缓冲区来存放SQL命令和SQL*PLUS命令。

经常用到的设置可放在login.sql文件中。

SET NULL
set null 'no data'

select ename,comm
from emp
where deptno=30;
把部门30中无佣金雇员的佣金显示为“NO DATA”。

set null是SQL*PLUS命令,用它来标识空值(NULL),可以设置为任意字符串。

存盘命令SAVE
save 文件名

input
1 select empno,ename,job
2 from emp
3 where job='analyst'

save research

目录中会增加一个research.sql文件。

编辑命令EDIT
edit

EDIT编辑当前缓冲区中的内容。

编辑一个文件
edit research

调入命令GET
get research
把磁盘上的文件内容调入缓冲区,并显示在屏幕上,文件名尾不必加.sql。

START命令
运行指定的文件
start research

输出命令SPOOL
spool tryfile
不仅可以使查询结果在屏幕上显示,还可以使结果存入文件

停止向文件输出
spool off

把查询结果在打印机上输出,先把它们存入一个文件中,
然后不必使用SPOOL OFF,而用:
spool out
SPOOL OUT关闭该文件并在系统缺省的打印机上输出

制作报表举例
edit tryfile

set echo off
set autocommit on
set pagesize 25
insert into emp (empno,ename,hiredate)
values(9999,'geiger',sysdate);
insert into emp (empno,ename,deptno)
values(3333,'samson',20);
spool new_emp
select * from emp
where deptno=20
or deptno is null
/
spool off
set autocommit off

用start命令执行这个文件

--------
6 函数
字符型函数
initcap(ename);将ename中每个词的第一个字母改为大写。
如:jack smith--Jack Smith

length(ename);计算字符串的长度。

substr(job,1,4);

其它
lower
upper
least 取出字符串列表中按字母排序排在最前面的一个串
greatest 取出字符串列表中按字母排序排在最后的一个串

日期函数
add_month(hiredate,5) 在雇佣时间上加5个月
month_between(sysdate,hiredate) 计算雇佣时间与系统时间之间相差的月数
next_day(hiredate,'FRIDAY') 计算受雇日期之后的第一个星期五的日期


select ename,sal,next_day(sysdate,'FRIDAY') as_of
from emp
where deptno=20;
(as_of是别名)

如果不用to_char函数,日期在ORACLE中的缺省格式是'DD_MON_YY'
to_char(date,date picture)

select ename,to_char(hiredate,'Dy Mon dd,yyyy') hired
from emp
where deptno=10;

to_date(字符串,格式)

insert into emp(empno,ename,hiredate)
values(7999,'asms',to_date('070387083000','MMDDYYHHMISS'));

日期型数据的格式
dd 12
dy fri
day friday
ddspth twelfth

mm 03
mon mar
month march

yy 87
yyyy 1987


Mar 12,1987 'Mon dd,yyyy'
MAR 12,1987 'MON dd,yyyy'
Thursday MARCH 12 'Day MONTH dd'
Mar 12 11:00am 'Mon dd hh:miam'
Thu,the twelfth 'Dy,"the"ddspth'

算术函数
least(v1,v2)

select ename,empno,mgr,least(empno,mgr) lownum
from emp
where empno0

trunc(sal,0)
取sal的近似值(截断)

空值函数
nvl(v1,v2)
v1为列名,如果v1不是空值,nvl返回其列值。
v1为空值,返回v2的值。

聚组函数
select sum(comm)
from emp;
(返回一个汇总信息)
不能把sum用在select语句里除非用group by

字符型、日期型、数字型的聚组函数
min max count可用于任何数据类型

select min(ename)
from emp;

select min(hiredate)
from emp;

select min(sal)
from emp;

有多少人有工作?
select count(job)
from emp;

有多少种不同的工种?
select count(distinct job)
from emp;

count distinct 计算某一字段中不同的值的个数

其它聚组函数(只用于数字型数据)
avg 计算平均工资
select avg(sal)
from emp;

stddev 计算工资的平均差
select stddev(sal)
from emp;

sum 计算总工资
select sum(sal)
from emp;

group by子句
select deptno,sum(sal),avg(sal)
from emp
group by deptno;

按多个条件分组
每个部门的雇员数
select deptno,count(*)
from emp
group by deptno;

每个部门的每个工种的雇员数
select deptno,job,count(*)
from emp
group by deptno,job;

满足条件的分组
(where是针对select的,having是针对group by的)
哪些部门的工资总和超过了9000
select deptno,sum(sal)
from emp
group by deptno
having sum(sal)>9000;

select小结
除去职员,哪些部门的工资总和超过了8000
select deptno,sum(sal)
from emp
where job!='clerk'
group by deptno
having sum(sal)>8000
order by sum(sal);
fan123123 2010-01-20
  • 打赏
  • 举报
回复
SQL命令的编辑
list or l 显示缓冲区的内容
list 4 显示当前SQL命令的第4行,并把第4行作为当前行,在该行号后面有个*。
change or c 用新的内容替换原来在一行中第一次出现内容
SQL>c/(...)/('analyst')/
input or i 增加一行或多行
append or a 在一行后追加内容
del 删除当前行 删除SQL缓冲区中的当前行
run 显示并运行SQL缓冲区中的命令
/ 运行SQL缓冲区中的命令
edit 把SQL缓冲区中的命令写到操作系统下的文本文件,
并调用操作系统提供的编辑器执行修改。

-------------
3 数据操纵
数据的插入
insert into dept
values (10,'accounting','new york');

insert into dept (dname,deptno)
values ('accounting',10);

从其它表中选择插入数据
insert into emp (empno,ename,deptno)
select id,name,department
from old_emp
where department in(10,20,30,40);

使用参数
insert into dept
values(&deptno,&dname,&loc);
执行时,SQL/PLUS对每个参数将有提示用户输入

参数对应日期型或字符型数据时,可在参数上加引号,输入时就可不用引号
insert into dept
values(&deptno,'&dname','&loc');

插入空值(NULL)
insert into dept
values(50,'education',null);

插入日期型数据
日期型数据缺省格式:DD-MON-YY
insert into emp
(empno,ename,hiredate)
values(7963,'stone','07-APR-87');

系统时间:SYSDATE
insert into emp
(empno,ename,hiredate)
values(7600,'kohn',SYSDATE);

数据更新
update emp
set job='manager'
where ename='martin';

update emp
set job='market rep'
where ename='salesman';

update emp
set deptno=40,job='market rep'
where job='salesman';

数据删除
delete emp
where empno=765;

更新的提交
commit

自动提交方式
set autocommit on
如果状态设为开,则使用inesrt,update,delete会立即提交。

更新取消
rollback

两次连续成功的commit之间的操作,称为一个事务

---------------
4 创建基表、视图
创建基表
create table dept
(deptno number(2),
dname char(14),
loc char(13));

数据字典会自动更新。
一个基表最多254列。

表名列名命名规则:
限制
第一个字符必须是字母,后面可任意(包括 $ # _ 但不能是逗号)。
名字不得超过30个字符。

唯一
某一用户的基表名必须唯一,不能是ORACLE的保留字,同一基表的列名互不相同。

使用双引号
如果表名用双引号括起来,则可不满足上述规则;
只有使用双引号,才能区别大、小写;
命名时使用了双引号,在以后的操作也必须使用双引号。

数据类型:
char(n) (不得超过240字符)
number(n,d)
date
long (最多65536字符)
raw (二进制原始数据)

空值处理
有时要求列值不能为空
create table dept
(deptno number(2) not null,
dname char(14),
loc char(13));

在基表中增加一列
alter table dept
add (headcnt number(3));

修改已有列属性
alter table dept
modify dname char(20);
注:只有当某列所有值都为空时,才能减小其列值宽度。
只有当某列所有值都为空时,才能改变其列值类型。
只有当某列所有值都为不空时,才能定义该列为not null。
例:
alter table dept modify (loc char(12));
alter table dept modify loc char(12);
alter table dept modify (dname char(13),loc char(12));

创建视图
create view managers as
select ename,job,sal
from emp
where job='manager';

为视图列名取别名
create view mydept
(person,title,salary)
as select ename,job,sal
from emp
where deptno=10;

with check option选项
使用with check option,保证当对视图插入或更新数据时,
该数据必须满足视图定义中select命令所指定的条件。
create view dept20 as
select ename,job,sal,deptno
from emp
where deptno=20
with check option;
在做下述操作时,会发生错误
update dept20
set deptno=30
where ename='ward';

基表、视图的拷贝
create table emp2
as select * from emp;

基表、视图的删除
drop table 表名
drop view 视图名
fan123123 2010-01-20
  • 打赏
  • 举报
回复
一、SQL PLUS
1 引言

SQL命令
以下17个是作为语句开头的关键字:
alter drop revoke
audit grant rollback*
commit* insert select
comment lock update
create noaudit validate
delete rename
这些命令必须以“;”结尾
带*命令句尾不必加分号,并且不存入SQL缓存区。

SQL中没有的SQL*PLUS命令
这些命令不存入SQL缓存区
@ define pause
# del quit
$ describe remark
/ disconnect run
accept document save
append edit set
break exit show
btitle get spool
change help sqlplus
clear host start
column input timing
compute list ttitle
connect newpage undefine
copy

---------
2 数据库查询

数据字典
TAB 用户创建的所有基表、视图和同义词清单

DTAB 构成数据字典的所有表

COL 用户创建的基表的所有列定义的清单

CATALOG 用户可存取的所有基表清单

select * from tab;

describe命令 描述基表的结构信息
describe dept

select *
from emp;

select empno,ename,job
from emp;

select * from dept
order by deptno desc;

逻辑运算符
= !=或<> > >= < <=
in
between value1 and value2
like
%
_
in null
not
no in,is not null

谓词in和not in
有哪些职员和分析员
select ename,job
from emp
where job in ('clerk','analyst');

select ename,job
from emp
where job not in ('clerk','analyst');

谓词between和not between
哪些雇员的工资在2000和3000之间
select ename,job,sal from emp
where sal between 2000 and 3000;

select ename,job,sal from emp
where sal not between 2000 and 3000;

谓词like,not like
select ename,deptno from emp
where ename like 'S%';
(以字母S开头)
select ename,deptno from emp
where ename like '%K';
(以K结尾)
select ename,deptno from emp
where ename like 'W___';
(以W开头,后面仅有三个字母)
select ename,job from emp
where job not like 'sales%';
(哪些雇员的工种名不以sales开头)

谓词is null,is not null
没有奖金的雇员(即commision为null)
select ename,job from emp
where comm is null;

select ename,job from emp
where comm is not null;

多条件查询
select ename,job
from emp
where deptno=20
and job!='clerk';

表达式
+ - * /

算术表达式
选择奖金高于其工资的5%的雇员
select ename,sal,comm,comm/sal from emp
where comm>.05*sal
order by comm/sal desc;

日期型数据的运算
add two days to 6-Mar-87
6-Mar-87 + 2 = 8-Mar-87
add two hours to 6-Mar-87
6-Mar-87 + 2/24 = 6-Mar-87 and 2hrs
add 15 seconds to 6-Mar-87
6-Mar-87 + 15/(24*60*60) = 6-Mar-87 and 15 secs

列名的别名
select ename employee from emp
where deptno=10;
(别名:employee)
select ename,sal,comm,comm/sal "C/S RATIO" from emp
where comm>.05*sal
order by comm/sal desc;
zhangwonderful 2010-01-20
  • 打赏
  • 举报
回复
就是赋值的功能
Comer 2010-01-20
  • 打赏
  • 举报
回复
赋值
Future_Hui_ 2010-01-20
  • 打赏
  • 举报
回复


加油 。。




gerrynj 2010-01-20
  • 打赏
  • 举报
回复
up
duqiangcise 2010-01-20
  • 打赏
  • 举报
回复
相当于java中的:
int i=2;
jinglingqaz 2010-01-20
  • 打赏
  • 举报
回复
:= 赋值的意思区别于java的 =
|| 连接意思区别于java的 +
kingkingzhu 2010-01-20
  • 打赏
  • 举报
回复
赋值 接分
jee1987vip 2010-01-19
  • 打赏
  • 举报
回复
谢谢大家
Phoenix_99 2010-01-19
  • 打赏
  • 举报
回复
为变量,常量赋值符号
suiziguo 2010-01-19
  • 打赏
  • 举报
回复
为变量/常量赋值符号。

declare
v_id number;
v_name varchar2(16);
c_status CONSTANT char(1) := '1';

begin
v_id := 777;
v_name := 'AC米兰';
……
end;
zhengde007 2010-01-19
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 suiziguo 的回复:]
为变量/常量赋值符号。

declare
  v_id      number;
  v_name    varchar2(16);
  c_status  CONSTANT char(1) := '1';

begin
  v_id := 777;
  v_name := 'AC米兰';
  ……
end;
[/Quote]
正解
zhengde007 2010-01-19
  • 打赏
  • 举报
回复
[Quote=引用楼主 jee1987vip 的回复:]
能举例说明吗,谢谢大家
[/Quote]
正解
第一篇 Oracle管理配置 第1章 Oracle安装配置(教学视频:10分钟) 23 1.1 Oracle简介 23 1.1.1 数据库术语 23 1.1.2 主流数据库简介 24 1.1.3 Oracle数据库的特点 24 1.2 安装Oracle数据库 25 1.2.1 Oracle数据库的版本变迁及安装环境 25 1.2.2 安装过程 26 1.2.3 安装需要注意的问题 27 1.3 本章小结 28 1.4 习题 28 第2章 Oracle常用工具(教学视频:7分钟) 29 2.1 Net Configuration Assistant(网络配置助手) 29 2.1.1 监听程序配置 29 2.1.2 命名方法配置 31 2.1.3 本地Net服务名配置 32 2.2 Net Manager(网络管理员) 34 2.3 本章实例 36 2.4 本章小结 38 2.5 习题 38 第3章 SQL Plus和PL/SQL(教学视频:11分钟) 39 3.1 SQL Plus与PL/SQL简介 39 3.2 使用SQL Plus 40 3.2.1 登录SQL Plus 40 3.2.2 SQL Plus输出结果的格式化 41 3.2.3 SQL Plus小结 46 3.3 PL/SQL 46 3.3.1 PL/SQL常用开发工具 46 3.3.2 开发一个简单的PL/SQL程序 48 3.4 本章实例 49 3.5 本章小结 50 3.6 习题 50 第二篇 Oracle数据库对象 第4章 Oralce数据库(教学视频:15分钟) 51 4.1 创建Oracle数据库 51 4.2 Oracle数据库的相关术语 52 4.2.1 数据库 53 4.2.2 数据库实例和SID 53 4.2.3 ORACLE_SID 54 4.3 Oracle数据库的备份与恢复 55 4.3.1 逻辑备份/恢复(导出/导入) 55 4.3.2 物理备份/恢复 56 4.3.3 利用PL/SQL Developer备份数据库 60 4.4 本章实例 61 4.5 本章小结 61 4.6 习题 62 第5章 Oracle数据表对象(教学视频:42分钟) 63 5.1 Oracle表空间 63 5.1.1 Oracle表空间简介 63 5.1.2 创建Oracle表空间 64 5.1.3 查看表空间 66 5.1.4 修改数据库默认表空间 67 5.1.5 修改表空间名称 68 5.1.6 删除表空间 69 5.2 创建Oracle数据表 70 5.2.1 利用工具创建数据表 70 5.2.2 利用工具查看数据表 71 5.2.3 利用命令创建数据表 72 5.2.4 利用命令查看表结构 72 5.3 修改Oracle数据表结构 73 5.3.1 利用工具修改数据表结构 73 5.3.2 利用命令修改数据表结构 74 5.4 删除数据表 75 5.4.1 利用工具删除数据表 76 5.4.2 利用SQL语句删除数据表 76 5.5 备份/恢复数据表 76 5.5.1 利用工具备份/恢复数据表 77 5.5.2 利用命令备份/恢复数据表 82 5.6 临时表 83 5.6.1 临时表简介 83 5.6.2 会话级临时表 84 5.6.3 事务级临时表 85 5.6.4 查看临时表在数据库的信息 86 5.6.5 临时表的应用场景 86 5.7 特殊的表dual 87 5.7.1 分析dual表 87 5.7.2 dual表的应用场景 87 5.7.3 修改dual表对查询结果的影响 88 5.8 本章实例 89 5.9 本章小结 90 5.10 习题 90 第6章 约束(教学视频:43分钟) 91 6.1 主键约束 91 6.1.1 主键简介 91 6.1.2 创建主键约束 92 6.1.3 修改表的主键约束 94 6.1.4 主键应用场景 96 6.2 外键约束 97 6.2.1 外键简介 97 6.2.2 创建外键约束 97 6.2.3 级联更新与级联删除 100 6.2.4 修改外键属性 102 6.2.5 外键使用 104 6.3 唯一性约束 105 6.3.1 唯一性约束简介 105 6.3.2 创建唯一性约束 105 6.3.3 修改唯一性约束 107 6.3.4 唯一性约束的使用 108 6.4 检查约束 108 6.4.1 检查约束简介 108 6.4.2 创建检查约束 108 6.4.3 修改检查约束 110 6.4.4 检查约束的使用 111 6.5 默认值约束 111 6.5.1 默认值约束简介 112 6.5.2 创建默认值约束 112 6.5.3 修改默认值约束 113 6.6 本章实例 115 6.7 本章小结 116 6.8 习题 116 第7章 视图(教学视频:50分钟) 117 7.1 关系视图 117 7.1.1 建立关系视图 117 7.1.2 修改/删除视图 118 7.1.3 联接视图 120 7.1.4 编译视图 122 7.1.5 使用force选项强制创建视图 124 7.1.6 利用视图更新数据表 125 7.1.7 with check option选项 126 7.1.8 关系视图小结 128 7.2 内嵌视图 128 7.2.1 内嵌视图简介 128 7.2.2 内嵌视图的使用 128 7.2.3 内嵌视图小结 130 7.3 对象视图 131 7.3.1 对象视图简介 131 7.3.2 对象视图简介 131 7.4 物化视图 133 7.4.1 物化视图简介 133 7.4.2 物化视图的使用 133 7.4.3 物化视图的数据加载 135 7.4.4 物化视图的数据更新 135 7.4.5 查询重写 136 7.5 本章小结 136 7.6 本章实例 137 7.7 习题 137 第8章 函数与存储过程(教学视频:48分钟) 138 8.1 函数 138 8.1.1 函数简介 138 8.1.2 创建函数 139 8.1.3 函数的括号 140 8.1.4 函数的参数 141 8.1.5 函数的确定性 142 8.1.6 典型函数举例 143 8.2 存储过程 144 8.2.1 存储过程简介 144 8.2.2 创建存储过程 144 8.2.3 存储过程的参数——IN参数 146 8.2.4 存储过程的参数——OUT参数 147 8.2.5 存储过程的参数——IN OUT参数 149 8.2.6 存储过程的参数——参数顺序 149 8.2.7 存储过程的参数——参数的默认值 152 8.2.8 存储过程的参数——参数顺序总结 153 8.3 程序包 153 8.3.1 规范 153 8.3.2 主体 155 8.3.3 调用程序包的函数/存储过程 157 8.3.4 程序包的变量 158 8.4 本章实例 159 8.5 本章小结 161 8.6 习题 161 …… 第9章 游标(教学视频:36分钟) 162 第10章 触发器(教学视频:58分钟) 178 第11章 序列(教学视频:28分钟) 206 第12章 用户角色与权限控制(教学视频:45分钟) 215 第三篇 Oracle的SQL 第13章 Oracle数据类型(教学视频:21分钟) 231 第14章 Oracle的函数与表达式(教学视频:111分钟) 240 第15章 Oracle的控制语句(教学视频:16分钟) 282 第16章 SQL查询(教学视频:55分钟) 290 第17章 SQL更新数据(教学视频:34分钟) 319 第四篇 Oracle编程高级应用 第18章 数据库速度优化与数据完整性(教学视频:32分钟) 332 第19章 数据一致性与事务管理(教学视频:46分钟) 341 第20章 并发控制(教学视频:35分钟) 356 第21章 Oracle的正则表达式(教学视频:29分钟) 369 第五篇 Oracle与编程语言综合使用实例 第22章 Oracle在Java开发的应用(教学视频:38分钟) 376 第23章 Oracle在C#开发的应用(教学视频:12分钟) 391

17,377

社区成员

发帖
与我相关
我的任务
社区描述
Oracle 基础和管理
社区管理员
  • 基础和管理社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧