oracle自主学习笔记,Oracle 自主学习笔记(四)

本文介绍了Oracle数据库的基本操作,包括数据插入、删除和更新,以及事务的控制机制如提交和回滚。此外,讲解了视图、序列和索引的概念,并展示了PL/SQL程序结构和条件控制的使用。同时,提到了游标及其属性在处理查询结果中的应用,最后简要提及了顺序控制和GOTO语句。
摘要由CSDN通过智能技术生成

一、

1、插入数据

不写列名,要补全

2、删除数据 delete drop truncate

3、修改数据 update

二、

Oracle提供了一种被称为“事务”的控制机制,来对数据进行有效、安全的操作,

使数据库中的数据始终处于一个数据一致性的状态。

ORACLE提供的事务控制语句有:

提交事务(commit)

回滚事务(rollback)

设置保存点(savepoint)

三、数据对象

视图:实际上是一张或者多张表上的预定义查询,这些表称为基表。

序列:用来生成连续的整数数据的对象。常常用来作为主键中增长列,可升序或降序生成

create sequence sequencename [start with num]

创建一个从1开始,默认最大值,每次增长1的序列,要求NOCYCLE,缓存中有30个预先分配好的序列号

创建索引就是对某些特定列中的数据排序,生成独立的索引表PL

四、PL/SQL 程序结构组成部分

声明 执行 异常处理部分

declare

pi constant number := 3.14;

r number default 3;

area number; 面积

begin

area := pi*r*r;  计算面积

dbms_output.put_line(area);输出圆的面积

end;

declare

pi constant number := 3.14;

r number default 3;

area number;面积

begin

area := pi*r*r;计算面积

dbms_output.put_line(area);输出圆的面积

end;

五、PL/SQL条件控制

C#中的条件控制使用关键字if和switch。PL/SQL中关于条件控制的关键字有

if-then、if-then-else、if-then-elsif 和多分支条件case

DECLARE

newSal scott.emp.sal%TYPE    newSal的数据类型和emp表中的sal一样    将变量插入

BEGIN

SELECT sal INTO newSal FROM scott.emp WHERE ename  = 'JAMES';

IF newSal > 900 THEN

UPDATE scott.emp SET comm = 800 WHERE ename = 'JAMES';

END IF;

COMMIT;  提交

END;

DECLARE

v_grade CHAR(1) := UPPER('&p_grade');

BEGIN

CASE v_grade

WHEN 'A' THEN

dbms_output.put_line('Excellent');

WHEN 'B' THEN

dbms_output.put_line('Very Good');

WHEN 'C' THEN

dbms_output.put_line('Good');

ELSE

dbms_output.put_line('NO such grade');

END CASE;

END;

where 循环  while 条件 loop

end loop

for 循环 for 变量 1..100 loop

end loop

六、PL/SQL顺序控制

当前的程序跳转到另一个地方继续运行,就需要使用顺序控制

顺序控制用到的语句:GOTO,NULL

GOTO不常用   NULL 可执行语句

只是将控制权转到下一行语句;

七、游标:是系统为用户开设的一个数据缓冲区,存放SQL语句的执行结果

%FOUND     布尔型属性  最近的FETCH语句取到了记录 属性值为TRUE

%NOTFOUND  布尔型属性  最近的FETCH语句没有返回一条记录,属性值为TRUE

%ISOPEN    布尔型属性  用来代表游标是否打开当游标已打开时返回TRUE

%ROWCOUNT  数字型属性  用来代表目前fetch到的记录的总行数。即返回已从游标中读取的记录

显示游标使用步骤

定义:declare

cursor c_name is select ename from emp;

打开     open c_name

使用     FETCH c_name INTO v_enamel;

关闭     close c_name;

隐式游标

BEGIN

UPDATE SCOTT.emp SET sal = sal+100 WHERE empno = 7876;

IF   SQL%FOUND   THEN

DBMS_OUTPUT.PUT_LINE('成功修改雇员工资');

ELSE

DBMS_OUTPUT.PUT_LINE('修改雇员工资失败!');

END IF;

END;

loop 写

declare

cursor cur is select * from emp;

userinfo emp%rowtype;

begin

open cur;

loop

exit when cur%notfound;

fetch cur

into userinfo;          游标指向为1的

dbms_output.put_line('user_id:' userinfo.empno || '-' ||

'user_name:' || userinfoi.ename);

end loop;

exception

when others then

dbms_output.put_line(sqlerrm);

close cur;

end;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值