Oracle数据库基本概念理解(3)

/*
===========================================================
|         PL/SQL编程
============================================================
*/
--声明变量
DECLAREV_NAME VARCHAR2(20); --一般变量V_AGE NUMBER(2);v_id   SUN.TUSER.USERID%TYPE:=14;--属性变量v_user SUN.TUSER%ROWTYPE; --行属性变量
BEGIN--赋常量值V_NAME:='Tom';V_AGE :=20;DBMS_OUTPUT.put_line('姓名:'||V_NAME||'年龄:'||V_AGE);--SELECT *  FROM SUN.TUSER;--通过SELECT INTO给变量赋值SELECT USERNAME,USERID INTO V_NAME,V_AGE  FROM SUN.TUSER;-- WHERE USERID=v_id;DBMS_OUTPUT.put_line('姓名:'||V_NAME||'年龄:'||V_AGE);--给行属性变量赋值select * into v_user from sun.tuser where userid=v_id;dbms_output.put_line('----------------------------');dbms_output.put_line(v_user.username);dbms_output.put_line('----------------------------');
EXCEPTION--异常处理WHEN NO_DATA_FOUND THENDBMS_OUTPUT.put_line('用户编号不正确!');WHEN OTHERS THENDBMS_OUTPUT.put_line('错误:'||SQLERRM); 
END;--循环
/*
===========================================================
|         循环语句
============================================================
*/
declarev_count number:=1; --声明变量并赋值v_sum number:=0;
begin/*loop   --loop循环v_sum:=v_sum+v_count;v_count:=v_count+1;exit when v_count>10;end loop;*//* while v_count<=10 loop  --while 循环v_sum:=v_sum+v_count;v_count:=v_count+1;end loop;*/for i in 1..10 loop --for循环v_sum:=v_sum+i; end loop; dbms_output.put_line(v_sum);
end;/*
===========================================================
|         游标
============================================================
*/DECLARE --声明游标CURSOR USER_CUR ISSELECT USERID,USERNAME FROM SUN.TUSER;V_ID SUN.TUSER.USERID%TYPE;V_NAME SUN.TUSER.USERNAME%TYPE;   
BEGIN--第一种使用游标方式/* OPEN USER_CUR;--打开游标LOOP   --遍历游标FETCH USER_CUR INTO V_ID,V_NAME;EXIT WHEN USER_CUR%NOTFOUND;DBMS_OUTPUT.put_line('第'||USER_CUR%ROWCOUNT||'个学生:'||V_ID||' '||V_NAME);END LOOP;close user_cur; --关闭游标*/--第二种使用方式  for 遍历游标  这种方式不用先打开游标for v_user in USER_CUR LOOPDBMS_OUTPUT.put_line('第'||USER_CUR%ROWCOUNT||'个学生:'||v_user.USERID||' '||V_USER.USERNAME);END LOOP;  
END;  /*
===========================================================
|          存储过程
============================================================
*/ 
--创建存储过程CREATE or replace PROCEDURE INSERT_USER( V_USERID NUMBER,V_NAME VARCHAR2,V_PWD VARCHAR2)ISBEGININSERT INTO SUN.TUSER(USERID,USERNAME,PWD)VALUES(V_USERID,V_NAME,V_PWD);END;/*
===========================================================
|         存储过程调用 
============================================================
*/ 
--存储过程调用 begin  --按位置调用--INSERT_USER(14,'111','111') ;--按名称INSERT_USER(V_USERID=>15,V_PWD=>'222',V_NAME=>'222') ;
end;  --符合规则的存储过程CREATE PROCEDURE INSERT_USER2 (V_USERID SUN.TUSER.USERID%TYPE, --使用属性变量V_NAME SUN.TUSER.USERNAME%TYPE,V_PWD SUN.TUSER.PWD%TYPE,ON_FLAG OUT NUMBER,  --输出参数ON_MSG OUT VARCHAR2  )ISBEGINON_FLAG:=1;ON_MSG:='添加成功!';INSERT INTO SUN.TUSER(USERID,USERNAME,PWD)VALUES(V_USERID,V_NAME,V_PWD);EXCEPTION  --异常处理WHEN OTHERS THEN ON_FLAG:=SQLCODE; --异常代码ON_MSG:=SQLERRM; --异常信息输出变量rollback;END;
--调用
DECLAREV_FLAG NUMBER;V_MSG VARCHAR2(100);
BEGININSERT_USER2(16,'555','555',V_FLAG,V_MSG );DBMS_OUTPUT.put_line(V_FLAG||V_MSG);-- select * from sun.tuser;
END;     

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/328149.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

服务器io修改,更改 Linux I/O 调度器来改善服务器性能

为了从 Linux 服务器榨取尽可能多的性能&#xff0c;请了解如何更改 I/O 调度器以满足你的需求。Linux I/O 调度器()控制内核提交读写请求给磁盘的方式。自从 2.6 内核以来&#xff0c;管理员已经能够更改这个调度器&#xff0c;所以他们可以自定义他们的平台以完全适合他们的需…

如何合理的规划一次 JVM 性能调优

转载自 如何合理的规划一次 JVM 性能调优摘要: JVM性能调优涉及到方方面面的取舍&#xff0c;往往是牵一发而动全身,需要全盘考虑各方面的影响&#xff0c;那么如何进行一次优雅的调优&#xff0c;提升应用的性能&#xff1f;这是 JVM 优化系列第三篇&#xff1a;JVM 调优系列…

服务器复制不了文档,服务器复制粘贴不了

服务器复制粘贴不了 内容精选换一换帮助用户完成专属云服务器备份任务的创建&#xff0c;快速完成服务器数据保护。专属云服务器不支持应用一致性备份。当专属对象存储的容量不足时&#xff0c;会导致专属云服务器备份创建失败。已开通专属对象存储。登录管理控制台。单击&…

大神开发的模板框架 包括常见的功能

https://gitee.com/lcg0124/bootdo http://localhost/ 就可以访问了 http://localhost/blog

在Linux开发.NET——拜拜了Win10

我是一个有多年开发经验的.NET程序员。最近&#xff0c;我决定使用*NIX系统来开发.NET程序&#xff0c;虽然看起来有些激进&#xff0c;但是我可以说&#xff0c;这是我做过最好的决定了。 事情的起因是这样的&#xff0c;上周星期五&#xff08;十月14日&#xff09;&#xff…

20个非常有用的Java程序片段

转载自 20个非常有用的Java程序片段下面是20个非常有用的Java程序片段&#xff0c;希望能对你有用。 1. 字符串有整型的相互转换String a String.valueOf(2); //integer to numeric string int i Integer.parseInt(a); //numeric string to an int 2. 向文件末尾添加内…

从工程转向管理,访谈Github公司的Phil Haack

在本次播客中&#xff0c;QCon旧金山大会、 伦敦大会和纽约大会的主席Wes Reisz访谈了GitHub的工程主管Phil Haack&#xff0c;Haack在Github的工作聚焦于实现将软件推送到开发人员的桌面&#xff0c;当前正致力于发布GitHub Desktop这样的软件。GitHub Desktop是用于Visual St…

怎样往阿里云windows服务器传文件

怎样往阿里云windows服务器传文件 2017年12月05日 21:28:56 阿杜_ardo 阅读数 9169 1、在本地电脑上&#xff0c;快捷键“WINR"在“运行”中输入“MSTSC”&#xff0c;点击确定。 2、在“远程桌面连接”框框点击“选项”展开。&#xff08;计算机中输入阿里云服务器的IP地…

Hibernate基本概念

--用户解锁alter user scott account unlock;一个项目对应一个表空间oracle:--创建表空间--创建用户create user 用户名idendified by 密码default tablespace 表空间名-- 授权grant 权限(角色) to 用户--建表--增删改查--存储过程对象 ->jdbc->数据库&#xff08;表…

手机app 服务器 网页同步,手机app接入云服务器

手机app接入云服务器 内容精选换一换通过内网连接云手机实例时&#xff0c;需要在租户VPC中创建一台弹性云服务器&#xff0c;作为连接云手机的跳板机器。若创建云手机服务器时未使用自定义网络&#xff0c;还需在云手机租户的VPC和服务器所在VPC之间建立对等连接&#xff0c;如…

Java中的OutOfMemoryError

转载自 Java中的OutOfMemoryError引子&#xff1a;今天在<Sharding-JDBC官方群>里有个哥们称“不连sjdbc不会把内存吃光&#xff0c;连sjdbc跑一会就把内存吃光”&#xff0c;倍感诧异&#xff0c;我们已经用sj很久了&#xff0c;一直未发现sj吃内存的情况&#xff0c;遂…

沉沦17年,这位昔日科技霸主、最值钱企业,终于回来了……

1999年12月30日&#xff0c;这是微软最高光的时刻。当天其股价创出历史最高位59.97美元/股&#xff0c;市值达到了6130亿美元&#xff0c;是有史以来最值钱的公司——直至13年后&#xff0c;苹果公司的市值才超越这一纪录。 ▲微软股价 处在新千年之交&#xff0c;意气风发的微…

mysql5.5安装配置 在阿里云服务器上 本地navicat连接

MySQL 5.5安装配置教程. 2018年03月20日 19:18:49 沸点数据 阅读数 18046 1、官网下载MySQL 5.5。 下载地址&#xff1a;https://dev.mysql.com/downloads/mysql/5.5.html#downloads 2、安装MySQL5.5 注意&#xff1a;安装之前&#xff0c;请关闭杀毒软件。 &#xff08;1…

Hibernate基本概念 (2)

框架&#xff1a;1.一个应用程序的半成品2.提供了一系列可以重用的API3.能开发效率更高&#xff0c;性能更好的项目Hibernate:持久化&#xff08;jdbc&#xff09; ORM( 对象 关系 映射)hibernate环境搭建1.导包&#xff1a;核心包&#xff0c;必须包&#xff0c;数据驱动包2…

通过网页查看服务器算法,java分析html算法(java网页蜘蛛算法示例)

遇到复杂而繁琐的html页面大家都望而却步。因为很难获取到相应的数据。最古老的办法的是尝试用正则表达式&#xff0c;估计那么繁琐的东西得不偿失&#xff0c;浪费我们宝贵的时间。第二个办法用开源组织htmlparser的包&#xff0c;这个是一个比较老的项目&#xff0c;但是效果…

JVM 调优系列之监控工具

转载自 JVM 调优系列之监控工具 摘要: 项目部署线上之后&#xff0c;我们该如何基于监控工具来快速定位问题.... 通过上一篇的jvm垃圾回收知识&#xff0c;我们了解了jvm对内存分配以及垃圾回收是怎么来处理的。理论是指导实践的工具&#xff0c;有了理论指导&#xff0c;定位…

写给开发者:记录日志的10个建议

尽管在写这篇博文的时候&#xff0c;我是在负责运维工作&#xff0c;不过本文主要是写给开发者的。 对我来说&#xff0c;明白如何记录日志和记录什么&#xff0c;是软件工程师必须明了的最艰巨的任务之一。之所以这么说&#xff0c;是因为这项任务与预测&#xff08;divinatio…

解决org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)错误

解决org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)错误 2018年07月23日 16:55:42 犹抱琵琶半遮面 阅读数 29677 &#xff01;&#xff01;&#xff01;此类问题出现的原因是——不细心 一般的原因 Mapper interface和xml文件的定义对应…

Java 9 中的 GC 调优基础

转载自 Java 9 中的 GC 调优基础在经过了几次跳票之后&#xff0c;Java 9终于在原计划日期的整整一年之后发布了正式版。Java 9引入了很多新的特性&#xff0c;除了闪瞎眼的Module System和REPL&#xff0c;最重要的变化我认为是默认GC&#xff08;Garbage Collector&#xf…