PL/SQL(Procedural Language/SQL)是oracle中引入的一种过程化编程语言
PLS-00103:出现符号"declare"在需要下列之一时
符号"begin"被替换为"declare"后继续
存储过程里不需要用declare关键字
PLS-00103:出现符号"end-of-file"在需要下列之一时:
end要和if以及begin匹配,完了之后要用/来表示完了
create or replace procedure addStu is
v_NewMajor varchar2(10):='Chemistry';
v_FirstName varchar2(10):='Scott';
v_LastName varchar2(10):='Tiger';
begin
update students
set major=v_NewMajor
where first_name=v_FirstName
and last_name = v_LastName; if sql%notfound then
insert into students (first_name, last_name, major)
values (v_FirstName, v_LastName, v_NewMajor);
end if;
end;
/
select text from user_source where name = upper('addStu') and type = 'PROCEDURE';
这里好像一定要用upper('addStu')不然就会出现为选行。
执行过程的时候
exec 过程名
call 过程或函数
首先创建一个临时表
create table temp_table (
my_com varchar2(35),
vcomment varchar2(35));
spool命令可以指定路径和文件名,需要有写权
create or replace procedure edtmp is
/* 存储过程编程示例 */
v_Number number(5) :=115;
v_Comment varchar2(35);
begin
if v_Number < 500 then v_Comment := 'Too small';
insert into temp_table (my_com, vcomment)
values ('This is too cazy', v_Comment); elsif v_Number < 1000 then v_Comment := 'A little bigger';
insert into temp_table (my_com, vcomment)
values ('This is only luck', v_Comment); else v_Comment := 'That enough';
insert into temp_table (my_com, vcomment)
values ('Maybe good',v_Comment); end if;
end;
/
PL/SQL构建于SQL之上,可以用来编写包含SQL语句的程序。
(那么这个和其他编程语言通过驱动连接到数据库对数据进行操作的不同之出在于?)
PL/SQL中可以包括:
块结构
变量和类型
条件逻辑
循环
游标,保存查询返回的结果
过程
函数
包,可以把过程和函数组合到一个单元中。
数据抽象
create type可以用来定义对象类型
在过程中执行另一个过程时直接写过程名就行了
PLS-00428:在此select语句中缺少INTO子句
答:在PL/SQL程序中不允许出现不带into子句的select语句,查询出来的数据必须得找个容器来装。
有这样一段过程
create or replace procedure instu is
rem 使用单行注释
v_major varchar2(10):='Germany'; -- 定义专业
v_first_name varchar2(10):='Fisher'; -- 定义姓氏
v_last_name varchar2(10):='Mark'; -- 定义名字
begin
-- 将这三个作为一条信息插入到表中
insert into students (major, first_name, last_name) values
(v_major, v_first_name, v_last_name);
end;
/
然后就报错了
PLS-00103:出现符号在需要下列之一时
:= . ( @ %
; not null range default character
我还以为中文字符打进去了,原来全是第二句报的错。
http://www.linuxidc.com/Linux/2012-07/65272.htm
这里给了我答案,原来rem是remark的缩写,只能用在sql plus 的单行命令中,
而不能用在PL/SQL中,在PL/SQL中只能使用--或者/* */进行注释,这个问题纠结了半天,就是没想到是该死的rem,
真真是叫哔了狗。
在oracle中重新编译存储过程的方法:
http://blog.itpub.net/26686207/viewspace-1144800/
第一种:如果使用PL/SQL Developer工具
左侧工具栏中选中“存储过程”-》选择已经失效的procedure-》右键-》选择重新编译即可
第二种:命令行版
1、查找无效对象
select 'Alter '|| object_type ||' '||object_name||' compile;' from user_objects where status = 'INVALID';
2、重新编译存储过程procedure_name,执行下面的脚本即可
alter procedure procedure_name compile;
my_title books.title%TYPE;
这里的意思是my_title这个变量的类型和表books中字段title的类型是一样的
oracle设置显示的行数和列数
show pagesize;
set pagesize 100;
shole linesize;
set linesize 100;
DBMS_OUTPUT是用来输出信息的,这是一个PL/SQL的系统包,但是有个前提是要设置一下:
set serveroutput on
为何感觉我总是很逗比
create or replace procedure usecur as -- 声明这两个变量
v_first_name varchar2(20);
v_last_name varchar2(20); -- 声明游标
cursor c_Students is
select first_name, last_name
from students; begin
-- 启动游标进程
open c_Students;
loop
fetch c_Students into v_first_name, v_last_name;
exit when c_Students%NOTFOUND;
--如果找到Scott就退出
while v_first_name = 'Scott' loop
exit;
end loop;
end loop;
-- 过程结束
-- 不用的话就及时关闭游标进程
close c_Students;
if v_first_name = 'Scott' then
DBMS_OUTPUT.PUT_LINE('找到这个傻叉了');
else
DBMS_OUTPUT.PUT_LINE('找不到这个傻叉');
end if;
end;
/
oracle PL/SQL基础编程的更多相关文章
-
Oracle数据库—— PL/SQL基础编程
一.涉及内容 1. 掌握PL/SQL程序块的结构,理解并熟悉各种变量的应用. 二.具体操作 (一)使用system用户登录SQL*PLUS,使用SQL语句创建用户:u_你的姓名首字母(例如:u_zs) ...
-
二十、oracle pl/sql基础
一.pl/sql developer开发工具pl/sql developer是用于开发pl/sql块的集成开发环境(ide),它是一个独立的产品,而不是oracle的一个附带品. 二.pl/sql介绍 ...
-
oracle pl/sql 基础
一.pl/sql developer开发工具pl/sql developer是用于开发pl/sql块的集成开发环境(ide),它是一个独立的产品,而不是oracle的一个附带品. 二.pl/sql介绍 ...
-
PL/SQL 基础编程
PL/Sql 编程 PL/Sql结构 [declare] --声明变量 begin --执行部分 [exception] ---异常处理部分 end PL/Sql 基本数据类型 数值类型 1. nu ...
-
Oracle pl/sql 基础入门语法
PL/SQL是一种块结构的语言,这意味着PL/SQL程序被划分和编写代码的逻辑块.每块由三个子部分组成:1 声明 此部分开头使用关键字DECLARE.它是一个可选的部分,并限定在该程序中使用的 ...
-
Oracle PL/SQL 高级编程
1. 复合数据类型--记录类型 Ø 语法格式 type 类型名 is record ( 字段1 字段1类型 [not null]:=表达式1; 字段2 字段2类型 [not n ...
-
Oracle PL/SQL DBA 编程实践基础
[附:一文一图]
-
Oracle PL/SQL基础
1.下载sql developer数据库连接可视化工具 连接地址:点我下载 下载完成,安装有Java环境,解压即可运行,也可以在linux系统中运行.
-
浅析Oracle PL/SQL 学习--未完待续
这是一篇关于Oracle Pl/SQL数据库编程的课程学习分享... 首先说明几点: 学习这门课程之前,已经学过并且掌握一些基础的SQL语句.数据库结构分析.ER图设计等知识: 这里也只是较为大概地将 ...
随机推荐
-
Jenkins + Ant + Git + Tomcat自动化部署
环境linux下,大致的配置内容如下: 首先安装JDK配置环境变量等. 其次安装ANT配置ANT_HONE并把bin目录加入PATH中. 然后安装Git,并生成sshkey配置ssh 安装tomcat ...
-
java安全沙箱(四)之安全管理器及Java API
java是一种类型安全的语言,它有四类称为安全沙箱机制的安全机制来保证语言的安全性,这四类安全沙箱分别是: 类加载体系 .class文件检验器 内置于Java虚拟机(及语言)的安全特性 安全管理器及J ...
-
ICSharpCode.SharpZipLib
ICSharpCode.SharpZipLib 压缩.解压文件 附源码 http://www.icsharpcode.net/opensource/sharpziplib/ 有SharpZipli ...
-
How to run a (Tomcat)Java application server on a Azure virtual machine
http://www.windowsazure.com/en-us/documentation/articles/virtual-machines-java-run-tomcat-applicatio ...
-
BZOJ 1835 基站选址(线段树优化DP)
题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=1835 题意:有N个村庄坐落在一条直线上,第 i(i>1)个村庄距离第1个村庄的距离 ...
-
JVM学习记录-对象已死吗
前言 先来回顾一下,在jvm运行时数据区,分为两部分,一个部分是线程共享区,主要包括堆和方法区,另一部是线程私有区分包括本地方法栈,虚拟机栈和程序计数器.在线程私有部分的三个区域是随着线程生和灭的.栈 ...
-
RabbitMQ实战经验分享
前言 最近在忙一个高考项目,看着系统顺利完成了这次高考,终于可以松口气了.看到那些即将参加高考的学生,也想起当年高三的自己. 下面分享下RabbitMQ实战经验,希望对大家有所帮助: 一.生产消息 关 ...
-
协程及Python中的协程
1 协程 1.1协程的概念 协程,又称微线程,纤程.英文名Coroutine.一句话说明什么是线程:协程是一种用户态的轻量级线程.(其实并没有说明白~) 我觉得单说协程,比较抽象,如果对线程有一定了解 ...
-
docker 给运行的容器映射本地端口
1.提交运行中的容器为一个镜像 (这样不会丢失在容器的各种操作) docker commit tang tang1 ### tang(运行容器名称) tang1(生成镜像名称) 2 ...
-
HAL层编写规范
andriod HAL模块也有一个通用的入口地址,这个入口地址就是HAL_MODULE_INFO_SYM变量,通过它,我们可以访问到HAL模块中的所有想要外部访问到的方法. 在Linux系统中,后缀 ...