1.语句结构模板

declare --声明
begin
dbms_output.put_line('Legend Hello world');
end;

2.变量使用 & 是输入符号

declare
c_name constant varchar2(20) :='Legend';
v_num number(3) :='I am';
begin
dbms_output.put_line(v_num ||c_name || &n);
end;

3.rowtype的运用

declare
v_dept dept%rowtype;
begin
select * into v_dept from dept where deptno=&n;
dbms_output.put_line('部门编号:' || v_dept.DEPTNO ||'部门名称:'|| v_dept.DNAME ||'部门位置' || v_dept.LOC);
end;

4.record的使用

declare
type type_emp_dept is record(
v_ename emp.ename%type,
v_sal emp.sal%type,
v_dname dept.dname%type
); v_record type_emp_dept; begin
select e.ename,e.sal,d.dname into v_record from emp e,dept d where d.deptno = e.deptno and e.empno=&n;
dbms_output.put_line('员工姓名:'|| v_record.v_ename ||'员工工资:' || v_record.v_sal ||'部门名称:'|| v_record.v_dname);
end;

5.作业练习

/*

提示:获得键盘输入操作,可使用 empno=&名称

*/

1、使用块结构输出:学校:XXX学号:XXX,姓名:XXX,性别:XXX.

declare
v_school varchar2(20) :='桂林理工大学';
v_sid number(20) :=01;
v_sname varchar2(30) :='Legend';
v_sex varchar2(5) :='男';
begin
dbms_output.put_line('学校:' ||v_school || '学号:' || v_sid || '姓名:'|| v_sname ||'性别:' || v_sex);
end;

2、输入员工号,显示员工姓名、工资(使用%type完成)。

declare
v_ename emp.ename%type;
v_sal emp.sal%type;
begin
select ename,sal into v_ename,v_sal from emp where empno=&n;
dbms_output.put_line('姓名:'|| v_ename ||'工资:' || v_sal);
end;

3、输入员工号,显示员工姓名、工资(使用%rowtype完成)。

declare
v_emp emp%rowtype;
begin
select ename,sal into v_emp.ename,v_emp.sal from emp where empno=&n;
dbms_output.put_line('姓名:'||v_emp.ename||'工资:'||v_emp.sal);
end;

4、输入员工姓名,显示员工编号、工资、及工作(使用record完成)

declare
type type_emp is record(
v_empno emp.empno%type,
v_sal emp.sal%type,
v_job emp.job%type
);
v_record type_emp;
begin
select empno,sal,job into v_record from emp where ename='&n';
dbms_output.put_line('员工编号:'||v_record.v_empno || '工资:'||v_record.v_sal||'工作:'||v_record.v_job);
end;

5、输入员工号,显示雇员姓名、工资、个人所得税(税率为0.03)为例(使用record、%type完成).

declare
type type_emp is record(
v_ename emp.ename%type,
v_sal emp.sal%type,
v_money emp.sal%type
);
v_record type_emp;
begin
select ename,sal,sal-sal*0.03 into v_record from emp where empno=&n;
dbms_output.put_line('姓名'||v_record.v_ename ||'工资'|| v_record.v_sal || '个人所得税'||v_record.v_money);
end;

6、输出最高工资员工的名字,工作岗位。

declare
v_name emp.ename%type;
v_job emp.job%type;
begin
select ename,job into v_name,v_job from emp where sal=(select max(sal) from emp);
dbms_output.put_line('员工的名字'||v_name||'工作岗位'||v_job);
end;

7、输出员工中最高工资和最低工资

declare
v_max number(20);
v_min number(20);
begin
select max(sal),min(sal) into v_max,v_min from emp;
dbms_output.put_line('最高工资:'|| v_max ||'最低工资:' || v_min);
end;

8、输入员工的编号,显示员工的姓名,部门名称,工资及工资的级别

declare
type type_emp_dept_salgrade is record(
v_ename emp.ename%type,
v_dname dept.dname%type,
v_sal emp.sal%type,
v_grade salgrade.grade%type
);
v_record type_emp_dept_salgrade;
begin
select e.ename,d.dname,e.sal,s.grade into v_record from emp e ,salgrade s,dept d where e.deptno=d.deptno and e.sal between s.lowsal and s.hisal
and e.empno=&n;
dbms_output.put_line('员工姓名:' || v_record.v_ename || '部门名称:' || v_record.v_dname || '员工工资 : ' || v_record.v_sal ||'工资级别 : ' || v_record.v_grade);
end;

2.第二个中方法不显示会报错

declare
v_name emp.ename%type;
v_job dept.dname%type;
v_sal emp.sal%type;
v_grade salgrade.grade%type;
begin
select e.ename,d.dname,e.sal,s.grade into v_name,v_job,v_sal,v_grade from emp e,dept d,salgrade s where empno=&no
and e.deptno = d.deptno
and e.sal between s.losal and s.hisal;
dbms_output.put_line('员工号:'||v_name ||'工作:'||v_job||'工资:'||v_sal|| '工资级别: '||v_grade);
end;

2018.5.24 Oracle下的sqlplus编程 块结构的更多相关文章

  1. 2018.6.24 oracle数据库的 事务及视图

    第06章 事务及视图 本章内容  事务  视图 1 事务 1.1 什么是事务 事务也称工作单元,是一个或多个SQL语句组成的序列,这些个SQL操作作为一个完整的工作单元要么全部执行,要么全不执行. ...

  2. 转:Oracle下创建ASM磁盘总结

    Oracle下创建ASM磁盘总结 文章转载:https://blog.csdn.net/okhymok/article/details/78791841?utm_source=blogxgwz1 2. ...

  3. winsock教程- windows下的socket编程(c语言实现)

    winsock教程- windows下的socket编程(c语言实现) 使用winsock进行socket 编程     这是一个学习windows下socket编程(c语言)的快速指南.这是因为一下 ...

  4. Oracle与SQL SERVER编程差异分析(入门)

    网上有关Oracle与SQL SERVER性能差异的文章很多,结论往往是让你根据数据量与预算来选择数据库.但实际项目中,特别是使用 .Net 开发的系统,支持以上两种数据库或者更多已经成为Boss的普 ...

  5. linux 操作系统下c语言编程入门

    2)Linux程序设计入门--进程介绍 3)Linux程序设计入门--文件操作 4)Linux程序设计入门--时间概念 5)Linux程序设计入门--信号处理 6)Linux程序设计入门--消息管理  ...

  6. linux下使用sqlplus使用上下键显示历史命令

    在linux下使用sqlplus没有在windows下方便,既不好用习惯的退格键,也无法通过上键来显示上一条的命令,这里我们使用rlwrap来解决. 1.安装rlwrap [root@toughhou ...

  7. 【在Windows下进行的编程人员,你真的需要学习下Linux】

    从业几年,发现好多编程人员,严重依赖UI工具.对一些命令操作,十分的反感.尤其是从事Windows系统中的程序开发的人员.由于微软对开发工具,编程套件的极限优化.开发出更多的 面向UI的开发工具.从V ...

  8. python中使用Opencv进行车牌号检测——2018.10.24

    初学Python.Opencv,想用它做个实例解决车牌号检测. 车牌号检测需要分为四个部分:1.车辆图像获取.2.车牌定位.3.车牌字符分割和4.车牌字符识别 在百度查到了车牌识别部分车牌定位和车牌字 ...

  9. oracle下导出某用户所有表的方法

    oracle下导出某用户所有表的方法 scott/tiger是用户名和密码,handson是导出的实例名 按用户方式导出数据(owner当中写的是用户名) exp scott/tiger@handso ...

随机推荐

  1. 二进制数(dp,记忆化搜索)

    二进制数(dp,记忆化搜索) 给定k个<=1e6的正整数x(k不大于10),问最小的,能被x整除且只由01组成的数. 首先,dp很好写.用\(f[i][j]\)表示i位01串,模ki的值是j的数 ...

  2. 线段树 洛谷P3932 浮游大陆的68号岛

    P3932 浮游大陆的68号岛 题目描述 妖精仓库里生活着黄金妖精们,她们过着快乐,却随时准备着迎接死亡的生活. 换用更高尚的说法,是随时准备着为这个无药可救的世界献身. 然而孩子们的生活却总是无忧无 ...

  3. boost asio one client one thread

    总结了一个简单的boost asio的tcp服务器端与客户端通信流程.模型是一个client对应一个线程.先做一个记录,后续再对此进行优化. 环境:VS2017  + Boost 1.67 serve ...

  4. Codeforces Round #501 (Div. 3) 1015A Points in Segments (前缀和)

    A. Points in Segments time limit per test 1 second memory limit per test 256 megabytes input standar ...

  5. Exadata中的dbserver_backup.sh脚本

    dbserver_backup.sh脚本在老版本的exadata中,它存放在/opt/oracle.SupportTools目录中,主要用于/根文件系统和/boot分区的备份.dbserver_bac ...

  6. Luogu P3265 [JLOI2015]装备购买

    好吧刚开始不知道自己在写什么,,,后来写了线性方程组,又过了一天一上午终于明白了... 当然题意很显然:求代价最小的极大线性无关组. 那就高斯消元(好吧刚开始我不会用它来解这道题qwq) 第一个循环是 ...

  7. Helvetic Coding Contest 2016 online mirror F1

    Description Heidi has finally found the mythical Tree of Life – a legendary combinatorial structure ...

  8. excel单元格内容合并

    这几天在整理数据,有时候数据都在表格的不同单元格中,想把两格内容合并为一格,于是验证了两种方法 方法一: (1)在B1输入公式=A1&B1 (2)做完第一步后,选中B1后,鼠标移到单元格右下出 ...

  9. 20-----定位 (Position)

    定位 定位有三种: 1.相对定位 2.绝对定位 3.固定定位 这三种定位,每一种都暗藏玄机,所以我们要一一单讲. 相对定位 相对定位:相对于自己原来的位置定位 现象和使用: 1.如果对当前元素仅仅设置 ...

  10. Silverlight Telerik 学习之主题的设置

    Telerik控件版本:RadControls for Silverlight Q1 2013 当前的Telerik Silverlight 控件支持以下主题 Office Black - 这是默认主 ...