本文将介绍Java怎样实现对存数过程的调用方法,作者用了几个样例进行了具体的说明,简单明了,很适合刚開始学习的人。

一、Java怎样实现对存储过程的调用:

A:不带输出參数的

  1. create procedure getsum
  2. @n int =0<--此处为參数-->
  3. as
  4. declare @sum int<--定义变量-->
  5. declare @i int
  6. set @sum=0
  7. set @i=0
  8. while @i<=@n begin
  9. set @sum=@sum+@i
  10. set @i=@i+1
  11. end
  12. print 'the sum is '+ltrim(rtrim(str(@sum)))

在SQL中运行:

exec getsum 100

在JAVA中调用:

JAVA能够调用 可是在JAVA程序却不能去显示该存储过程的结果 由于上面的存储过程的參数类型int 传递方式是in(按值)方式

  1. import java.sql.*;
  2. public class ProcedureTest
  3. {
  4. public static void main(String args[]) throws Exception
  5. {
  6. //载入驱动
  7. DriverManager.registerDriver(new sun.jdbc.odbc.JdbcOdbcDriver());
  8. //获得连接
  9. Connection conn=DriverManager.getConnection("jdbc:odbc:mydata","sa","");
  10. //创建存储过程的对象
  11. CallableStatement c=conn.prepareCall("{call getsum(?)}");
  12. //给存储过程的參数设置值
  13. c.setInt(1,100); //将第一个參数的值设置成100
  14. //运行存储过程
  15. c.execute();
  16. conn.close();
  17. }
  18. }

B:带输出參数的

1:返回int

  1. alter procedure getsum
  2. @n int =0,
  3. @result int output
  4. as
  5. declare @sum int
  6. declare @i int
  7. set @sum=0
  8. set @i=0
  9. while @i<=@n begin
  10. set @sum=@sum+@i
  11. set @i=@i+1
  12. end
  13. set @result=@sum

在查询分析器中运行:

  1. declare @myResult int
  2. exec getsum 100,@myResult output
  3. print @myResult

在JAVA中调用:

  1. import java.sql.*;
  2. public class ProcedureTest
  3. {
  4. public static void main(String args[]) throws Exception
  5. {
  6. //载入驱动
  7. DriverManager.registerDriver(new sun.jdbc.odbc.JdbcOdbcDriver());
  8. //获得连接
  9. Connection conn=DriverManager.getConnection("jdbc:odbc:mydata","sa","");
  10. //创建存储过程的对象
  11. CallableStatement c=conn.prepareCall("{call getsum(?,?)}");
  12. //给存储过程的第一个參数设置值
  13. c.setInt(1,100);
  14. //注冊存储过程的第二个參数
  15. c.registerOutParameter(2,java.sql.Types.INTEGER);
  16. //运行存储过程
  17. c.execute();
  18. //得到存储过程的输出參数值
  19. System.out.println (c.getInt(2));
  20. conn.close();
  21. }
  22. }

2:返回varchar

存储过程带游标:

在存储过程中带游标 使用游标不停的遍历orderid

  1. create procedure CursorIntoProcedure
  2. @pname varchar(8000) output
  3. as
  4. --定义游标
  5. declare cur cursor for select orderid from orders
  6. --定义一个变量来接收游标的值
  7. declare @v varchar(5)
  8. --打开游标
  9. open cur
  10. set @pname=''--给@pname初值
  11. --提取游标的值
  12. fetch next from cur into @v
  13. while @@fetch_status=0
  14. begin
  15. set @pname=@pname+';'+@v
  16. fetch next from cur into @v
  17. end
  18. print @pname
  19. --关闭游标
  20. close cur
  21. --销毁游标
  22. deallocate cur

运行存储过程:

  1. exec CursorIntoProcedure ''

JAVA调用:

  1. import java.sql.*;
  2. public class ProcedureTest
  3. {
  4. public static void main(String args[]) throws Exception
  5. {
  6. //载入驱动
  7. DriverManager.registerDriver(new sun.jdbc.odbc.JdbcOdbcDriver());
  8. //获得连接
  9. Connection conn=DriverManager.getConnection("jdbc:odbc:mydata","sa","");
  10. CallableStatement c=conn.prepareCall("{call CursorIntoProcedure(?)}");
  11. c.registerOutParameter(1,java.sql.Types.VARCHAR);
  12. c.execute();
  13. System.out.println (c.getString(1));
  14. conn.close();
  15. }
  16. }

C:删除数据的存储过程

存储过程:

  1. drop table 学生基本信息表
  2. create table 学生基本信息表
  3. (
  4. StuID int primary key,
  5. StuName varchar(10),
  6. StuAddress varchar(20)
  7. )
  8. insert into 学生基本信息表 values(1,'三毛','wuhan')
  9. insert into 学生基本信息表 values(2,'三毛','wuhan')
  10. create table 学生成绩表
  11. (
  12. StuID int,
  13. Chinese int,
  14. PyhSics int
  15. foreign key(StuID) references 学生基本信息表(StuID)
  16. on delete cascade
  17. on update cascade
  18. )
  19. insert into 学生成绩表 values(1,99,100)
  20. insert into 学生成绩表 values(2,99,100)

创建存储过程:

  1. create procedure delePro
  2. @StuID int
  3. as
  4. delete from 学生基本信息表 where StuID=@StuID
  5. --创建完成
  6. exec delePro 1 --运行存储过程
  7. --创建存储过程
  8. create procedure selePro
  9. as
  10. select * from 学生基本信息表
  11. --创建完成
  12. exec selePro --运行存储过程

在JAVA中调用:

  1. import java.sql.*;
  2. public class ProcedureTest
  3. {
  4. public static void main(String args[]) throws Exception
  5. {
  6. //载入驱动
  7. DriverManager.registerDriver(new sun.jdbc.odbc.JdbcOdbcDriver());
  8. //获得连接
  9. Connection conn=DriverManager.getConnection("jdbc:odbc:mydata","sa","");
  10. //创建存储过程的对象
  11. CallableStatement c=conn.prepareCall("{call delePro(?)}");
  12. c.setInt(1,1);
  13. c.execute();
  14. c=conn.prepareCall("{call selePro}");
  15. ResultSet rs=c.executeQuery();
  16. while(rs.next())
  17. {
  18. String Stu=rs.getString("StuID");
  19. String name=rs.getString("StuName");
  20. String add=rs.getString("StuAddress");
  21. System.out.println ("学号:"+" "+"姓名:"+" "+"地址");
  22. System.out.println (Stu+" "+name+" "+add);
  23. }
  24. c.close();
  25. }
  26. }

D:改动数据的存储过程

创建存储过程:

  1. create procedure ModPro
  2. @StuID int,
  3. @StuName varchar(10)
  4. as
  5. update 学生基本信息表 set StuName=@StuName where StuID=@StuID

运行存储过程:

  1. exec ModPro 2,'四毛'

JAVA调用存储过程:

  1. import java.sql.*;
  2. public class ProcedureTest
  3. {
  4. public static void main(String args[]) throws Exception
  5. {
  6. //载入驱动
  7. DriverManager.registerDriver(new sun.jdbc.odbc.JdbcOdbcDriver());
  8. //获得连接
  9. Connection conn=DriverManager.getConnection("jdbc:odbc:mydata","sa","");
  10. //创建存储过程的对象
  11. CallableStatement c=conn.prepareCall("{call ModPro(?,?)}");
  12. c.setInt(1,2);
  13. c.setString(2,"美女");
  14. c.execute();
  15. c=conn.prepareCall("{call selePro}");
  16. ResultSet rs=c.executeQuery();
  17. while(rs.next())
  18. {
  19. String Stu=rs.getString("StuID");
  20. String name=rs.getString("StuName");
  21. String add=rs.getString("StuAddress");
  22. System.out.println ("学号:"+" "+"姓名:"+" "+"地址");
  23. System.out.println (Stu+" "+name+" "+add);
  24. }
  25. c.close();
  26. }
  27. }

E:查询数据的存储过程(模糊查询)

存储过程:

  1. create procedure FindCusts
  2. @cust varchar(10)
  3. as
  4. select customerid from orders where customerid
  5. like '%'+@cust+'%'

运行:

  1. execute FindCusts 'alfki'

在JAVA中调用:

  1. import java.sql.*;
  2. public class ProcedureTest
  3. {
  4. public static void main(String args[]) throws Exception
  5. {
  6. //载入驱动
  7. DriverManager.registerDriver(new sun.jdbc.odbc.JdbcOdbcDriver());
  8. //获得连接
  9. Connection conn=DriverManager.getConnection("jdbc:odbc:mydata","sa","");
  10. //创建存储过程的对象
  11. CallableStatement c=conn.prepareCall("{call FindCusts(?)}");
  12. c.setString(1,"Tom");
  13. ResultSet rs=c.executeQuery();
  14. while(rs.next())
  15. {
  16. String cust=rs.getString("customerid");
  17. System.out.println (cust);
  18. }
  19. c.close();
  20. }
  21. }

F:添加数据的存储过程

存储过程:

  1. create procedure InsertPro
  2. @StuID int,
  3. @StuName varchar(10),
  4. @StuAddress varchar(20)
  5. as
  6. insert into 学生基本信息表 values(@StuID,@StuName,@StuAddress)

调用存储过程:

  1. exec InsertPro 5,'555','555'

在JAVA中运行:

  1. import java.sql.*;
  2. public class ProcedureTest
  3. {
  4. public static void main(String args[]) throws Exception
  5. {
  6. //载入驱动
  7. DriverManager.registerDriver(new sun.jdbc.odbc.JdbcOdbcDriver());
  8. //获得连接
  9. Connection conn=DriverManager.getConnection("jdbc:odbc:mydata","sa","");
  10. //创建存储过程的对象
  11. CallableStatement c=conn.prepareCall("{call InsertPro(?,?,?)}");
  12. c.setInt(1,6);
  13. c.setString(2,"Liu");
  14. c.setString(3,"wuhan");
  15. c.execute();
  16. c=conn.prepareCall("{call selePro}");
  17. ResultSet rs=c.executeQuery();
  18. while(rs.next())
  19. {
  20. String stuid=rs.getString("StuID");
  21. String name=rs.getString("StuName");
  22. String address=rs.getString("StuAddress");
  23. System.out.println (stuid+" "+name+" "+address);
  24. }
  25. c.close();
  26. }
  27. }

G:在JAVA中创建存储过程 而且在JAVA中直接调用

  1. import java.sql.*;
  2. public class ProcedureTest
  3. {
  4. public static void main(String args[]) throws Exception
  5. {
  6. //载入驱动
  7. DriverManager.registerDriver(new sun.jdbc.odbc.JdbcOdbcDriver());
  8. //获得连接
  9. Connection conn=DriverManager.getConnection("jdbc:odbc:mydata","sa","");
  10. Statement stmt=conn.createStatement();
  11. //在JAVA中创建存储过程
  12. stmt.executeUpdate("create procedure OOP as select * from 学生成绩表");
  13. CallableStatement c=conn.prepareCall("{call OOP}");
  14. ResultSet rs=c.executeQuery();
  15. while(rs.next())
  16. {
  17. String chinese=rs.getString("Chinese");
  18. System.out.println (chinese);
  19. }
  20. conn.close();
  21. }
  22. }

Java对存储过程的调用方法的更多相关文章

  1. Java对存储过程的调用方法 --转载

    一.Java如何实现对存储过程的调用: A:不带输出参数的 create procedure getsum <--此处为参数--> as declare @sum int<--定义变 ...

  2. JAVA对存储过程的调用方法(本文源于网络)

    博客分类: java java存储过程sql  一:Java如何实现对存储过程的调用:   A:不带输出参数的   ---------------不带输出参数的-------------------- ...

  3. MySql 存储过程及调用方法

    存储过程实例: DELIMITER $$drop procedure if exists ff $$CREATE /*[DEFINER = { user | CURRENT_USER }]*/ PRO ...

  4. 创建自己的java类库并加以调用方法

    第一次搞博客,心里有点发慌,记录一下:2018/2/1/   21:33 今天Think In Java第4版 中文版(英文看着可能很耗时),看到了6.1.3 定制工具库这一章节,之前作者调用自己的类 ...

  5. java对过反射调用方法

      public class InvokeTester { public InvokeTester() { } String str; public InvokeTester(String str) ...

  6. Java基础 throws 提示调用方法时要注意处理相关异常

        JDK :OpenJDK-11      OS :CentOS 7.6.1810      IDE :Eclipse 2019‑03 typesetting :Markdown   code ...

  7. C#调用JAVA(二)调用方法

    上期我们创建了jar包并放到了unity中,那么我们继续 如果您还没有看上一期请先看上一期,这是链接 C#调用JAVA(一)制作jar包 - 执著GodShadow - 博客园 (cnblogs.co ...

  8. mysql 自定义函数与自定义存储过程的调用方法

    存储过程:call  过程名(参数) 函数:      select  函数名(参数)

  9. Java基础(四)方法和数组

    一.方法 1.方法的定义 方法也叫函数,就是一个能独立完成某个功能的一段代码.方法可以看作一个整体. 语法: 修饰符 返回类型 方法名字(数据类型 变量名,数据类型 变量名,……[形式参数(0个到n个 ...

随机推荐

  1. HTTP2.0协议

    HTTP2.0协议 http2协议的草案已经出来了,阅读了一下网上的中文版,http2尽可能的兼容http1.1.改进了http1.1协议的不足. http1.0和http1.1的缺点: 1.http ...

  2. Debug with Eclipse

    In this post we are going to see how to develop applications using Eclipse and Portofino 4. The trad ...

  3. 2014在百度之星资格赛的第二个问题Disk Schedule

    事实上,我认为它可以用来费用流问题.但光建地图上加班. ..不科学啊.. . 因副作用太大,否则,必然在.最后,想啊想,或者使用dp对.... 别想了一维dp... .我不知道我是怎么想.无论如何,这 ...

  4. Zygote过程【3】——SystemServer诞生

    欢迎转载.转载请注明:http://blog.csdn.net/zhgxhuaa 在ZygoteInit的main()方法中做了几件大事.当中一件便是启动Systemserver进程.代码例如以下: ...

  5. AndroidAnnotations说明—AndroidAnnotations它是如何工作的?

    AndroidAnnotations它的工作原理很easy,它使用标准java注塑加工工具,自己主动加她一个额外的步骤生成源代码编译.         源代码是什么?每个增强的类.比方每个用@EAct ...

  6. Spring MVC 基础

    Spring MVC 基础 1.Web MVC基础 MVC的本质是表现层模式,我们以视图模型为中心,将视图和控制器分离出来.就如同分层模式一样,我们以业务逻辑为中心,把表现层和数据访问层代码分离出来是 ...

  7. 乐在其中设计模式(C#) - 提供者模式(Provider Pattern)

    原文:乐在其中设计模式(C#) - 提供者模式(Provider Pattern) [索引页][源码下载] 乐在其中设计模式(C#) - 提供者模式(Provider Pattern) 作者:weba ...

  8. partial 的好处

    1.可以将一个类中的属 性, 方法分类来写 2.方法了可以写在多个类中, 这样可以对方法进行分类   由于项目上使用了代码生成工具, 自定义的一些按钮事件默认是不生成的,得自己定义,如果把定义的代码写 ...

  9. TI C66x DSP 系统events及其应用 - 5.8(ISTP)

    中断服务表指针ISTP(Interrupt Service Table Pointer)位置寄存器用于定位的中断服务例程,那ISTP去哪里找要运行的程序,ISTP(当中的ISTB字段)就是指向IST表 ...

  10. Android - 用Fragments实现动态UI - 创建灵活的UI

    当设计程序来支持各种不一样的屏幕尺寸时,可以在不同的布局中重用fragment来根据可用的屏幕大小来优化用户体验. 例如,在手机上可能使用一个fragment来使用单窗口用户体验比较合适.但是,你可能 ...