Oracle SQL脚本学习6

Oracle SQL脚本学习6

——————-目标 利用存储过程 游标 包 实现分页查询 并通过java 调用  这个存储过程 select * from book; ——添加表字段 alter table book add bprice number(4,2); desc book; ——修改表字段 alter table book rename column bplud to bpublish; desc book; ——修改字段类型 alter table book modify bpublish varchar2(20); desc book; ——删除表一个字段 alter table book add btemp number(4,2); desc book; alter table book drop column btemp; desc book; —————————————————————- alter table book add bookId number; ———————编写过程 drop table book; create table book (bookid number,bookname varchar2(20),bprice number(4,2)); desc book; ——-in  默认的可以省略 输入参数 create or replace procedure sp_book_pro(spbpBookid in number, spbpBookName in varchar2,spbpbprice in number)is begin insert into book values (spbpBookid,spbpBookName,spbpbprice); end; / —pro_IP_158.java 调用  无返回信息 select * from book; commit;   ————————————–编写过程能返回书的信息  update book set bookid=2 where bprice=19.1; desc book; –create or replace procedure sp_book_proV(spbpbookid in number,spbpbookname out varchar2, spbpbprice out number)is –begin –  select bookname into spbpbookname, bprice into spbpbprice from book where bookid = spbpbookid; –end; create or replace procedure sp_book_proV(spbpbid in number,spbpbookname out varchar2 , spbpprice out number ) is begin   select bookname,bprice into spbpbookname,spbpprice from book where bookid = spbpbid; end; / commit; desc book; select * from book; – select bookname , bprice from book where bookid=1; ————————-返回结果集 —包 –过程– alter table book add bsorts number; desc book; select * from book; insert into book values (4,’beiji4ng’,30.5,2); insert into book values (5,’beij5ing’,30.5,3); insert into book values (6,’beij6ing’,30.5,3); insert into book values (7,’beij7ing’,30.5,2); commit; –创建一个 包  用 AS –在包定义了一个 类型 游标类型的  即内部声明 create or replace package bysortpackage as type bsp_cursor is ref cursor; end bysortpackage; / commit; —创建过程 create or replace procedure sp_bysortsbooks(spbooksorts in number, sp_cursor out bysortpackage.bsp_cursor)is begin open sp_cursor for select * from book where bsorts=spbooksorts; end; / commit; ———————————————-分页显示 –oracle 分页  可以当一个模板使用 select t1.* ,rownum rn from(select * from book order by bookid desc) t1; select t1.* ,rownum rn from(select * from book order by bookid desc) t1 where rownum<=5; select * from (   select t1.* ,rownum rn from(select * from book order by bookid desc) t1 where rownum<=5 ) where rn>=2; –分页的过程 create or replace package fenyepackage as type fy_cursor is ref cursor; end fenyepackage; / commit; create or replace procedure pageno (tableName in varchar2,  pagesize in number,—每页显示条数  pageNow in number, —显示第几页  myrows out number,–总记录数  mypagecounts out number,  –总页数  p_cursor out fenyepackage.fy_cursor –返回的记录数  )is  –定义一个SQL 语句 字符串  v_sql varchar2(1000);  v_begin number:=(pageNow-1)*pagesize+1;  v_end number:=pageNow*pagesize;  begin  v_sql:=’select * from (select t1.* ,rownum rn from(select * from ‘||  tableName||’ order by bookid desc) t1 where rownum<=’||v_end||’)where rn>=’||v_begin;  –打开游标 和sq语句关联  open p_cursor for v_sql;    –计算   myrows  mypagecounts   –组织一个sql语句  v_sql:=’select count(*) from ‘||tablename;  –执行sql并把返回的值 赋给myrows  execute immediate v_sql into myrows;    –计算mypagecounts  mod取余  if mod(myrows,pagesize)=0 then   mypagecounts:=myrows/pagesize;  else   mypagecounts:=myrows/pagesize+1;  end if;  – 关闭游标  – close p_cursor;  end;  / create or replace procedure pageno (tableName in varchar2,  pagesize in number,  pageNow in number,   myrows out number,  mypagecounts out number,   p_cursor out fenyepackage.fy_cursor  )is  v_sql varchar2(1000);  v_begin number:=(pageNow-1)*pagesize+1;  v_end number:=pageNow*pagesize;  begin  v_sql:=’select * from (select t1.* ,rownum rn from(select * from ‘||  tableName||’ order by bookid desc) t1 where rownum<=’||v_end||’)where rn>=’||v_begin;  open p_cursor for v_sql;  v_sql:=’select count(*) from ‘||tablename;  execute immediate v_sql into myrows;  if mod(myrows,pagesize)=0 then   mypagecounts:=myrows/pagesize;  else   mypagecounts:=myrows/pagesize+1;  end if;  end;  / —————————————————–分页完成 ——————————————————–例外处理 declare v_bname book.bookname%type; begin   select bookname into v_bname from book where bookid=&gno;   dbms_output.put_line(‘bookname:’||v_bname); exception     when no_data_found then     dbms_output.put_line(‘the bookid is not exist’); end; / set serveroutput on; –自定义开发 create or replace procedure ex_test(spno in number) is myex exception; begin   update book set bookname=bookname+’ex’ where bookid=spno;   –sql%notfound 表示没有 update   –raise myex 触发myex   if sql%notfound then   raise myex;   end if;     exception   when myex then   dbms_output.put_line(‘no data’); end;   / create or replace procedure ex_test(spno in number) is myex exception; begin   update book set bookname=bookname+’ex’ where bookid=spno;   if sql%notfound then   raise myex;   end if;   exception   when myex then   dbms_output.put_line(‘no data’); end;   / set serveroutput on; exec ex_test(56); select * from book; alter table book modify bookname varchar2(20); desc book;

转载于:https://my.oschina.net/wmsjhappy/blog/272540

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/109812.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • oracle报错未明确定义列_查询块具有不正确的结果列数

    oracle报错未明确定义列_查询块具有不正确的结果列数运行环境:Oracle10gsqlplus环境下。 在查询语句中,经常会出现一个错误: SQL基础:ORA-00918:未明确定义列的错误。 当前遇到有两种情况。原因为:当查询语句中,查询的表(数据集)中有相同的字段名,查询字段无法确认是改查那个字段 时,就会报未明确定义列的错误。 第一种情况: 1.单表时: 比如fconsign表中存在三个字段:fcsg_c

    2022年10月4日
    3
  • git pycharm_怎么把git上放到pycharm

    git pycharm_怎么把git上放到pycharm首先检查pycharm是否安装了ignore插件项目目录如图:选中项目automationTest名称,右击–>New–>查看是否有ignorefile选项,如果有表示Pycahrm已经配置了ignore插件,如果没有,则需要安装插件pycharm安装.ignore插件File–>Settings–>Plugins–在右…

    2022年8月28日
    2
  • 小米5 MIUI 10系统完全Root教程 (Root思想通用所有机型)

    小米5 MIUI 10系统完全Root教程 (Root思想通用所有机型)WrittenbyQingXiaonan2018-8-251.摘要  虽然手机在完全root后存在一定风险,但是可以从事一些具有探索性的工作如修改手机游戏、修改APP权限要求、编写按键脚本等。此外,完全root非常适合那些拥有两个手机的人。这篇帖子以小米5最新MIUI10开发版系统完全root过程为例,介绍了一种通用的小米机型完全Root办法。2.重要概念…

    2022年6月4日
    42
  • redis默认端口为什么是6379_redis 端口

    redis默认端口为什么是6379_redis 端口1、如果开了redis服务,先将服务关闭2、在window上找到redis的安装目录,修改redis.windows.conf文件,在里面将默认端口改为你想要的端口号3、将redis.windows.conf文件直接拖入redis-server.exe,弹出窗口

    2022年9月18日
    3
  • ansi编码是什么意思_编码ANSI

    ansi编码是什么意思_编码ANSIANSI就是其他外文编码,且不同国家和地区的ANSI各有不同,即不兼容。举例,在中文简体下,你如果想编码表,保存时

    2022年9月23日
    2
  • 3.3v与5v电平转换_5v电压经过10位A/D转换

    3.3v与5v电平转换_5v电压经过10位A/D转换问题背景在设计一个带MCU或者ARM系统电路时候,经常遇见MCU的VCC是3.3V,但是外围电路需要5V,有时候是反过来。虽然现在MCU的IO都声称支持TTL电平,但是我们谁也不想将MCU的IO口直接接上5V,即使IO口先串联一个电阻,然后再接上5V,这样总是不放心,担心烧掉MCU。再说了,MCU声称IO口支持TTL电平,但是并不是所有的IO都是这样,反正有隐患。解决方法就是电平转换。具体的我只说我在实际项目中运用到的方法,而且在项目中运用比较方便的,其他的都不再说了。法一:基于门电路第一种:利用O

    2022年8月10日
    10

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号