Java对存储过程的调用方法
本文将介绍Java怎样实现对存数过程的调用方法,作者用了几个样例进行了具体的说明,简单明了,很适合刚開始学习的人。
一、Java怎样实现对存储过程的调用:
A:不带输出參数的
- create procedure getsum
- @n int =0<--此处为參数-->
- as
- declare @sum int<--定义变量-->
- declare @i int
- set @sum=0
- set @i=0
- while @i<=@n begin
- set @sum=@sum+@i
- set @i=@i+1
- end
- print 'the sum is '+ltrim(rtrim(str(@sum)))
在SQL中运行:
exec getsum 100
在JAVA中调用:
JAVA能够调用 可是在JAVA程序却不能去显示该存储过程的结果 由于上面的存储过程的參数类型int 传递方式是in(按值)方式
- import java.sql.*;
- public class ProcedureTest
- {
- public static void main(String args[]) throws Exception
- {
- //载入驱动
- DriverManager.registerDriver(new sun.jdbc.odbc.JdbcOdbcDriver());
- //获得连接
- Connection conn=DriverManager.getConnection("jdbc:odbc:mydata","sa","");
- //创建存储过程的对象
- CallableStatement c=conn.prepareCall("{call getsum(?)}");
- //给存储过程的參数设置值
- c.setInt(1,100); //将第一个參数的值设置成100
- //运行存储过程
- c.execute();
- conn.close();
- }
- }
B:带输出參数的
1:返回int
- alter procedure getsum
- @n int =0,
- @result int output
- as
- declare @sum int
- declare @i int
- set @sum=0
- set @i=0
- while @i<=@n begin
- set @sum=@sum+@i
- set @i=@i+1
- end
- set @result=@sum
在查询分析器中运行:
- declare @myResult int
- exec getsum 100,@myResult output
- print @myResult
在JAVA中调用:
- import java.sql.*;
- public class ProcedureTest
- {
- public static void main(String args[]) throws Exception
- {
- //载入驱动
- DriverManager.registerDriver(new sun.jdbc.odbc.JdbcOdbcDriver());
- //获得连接
- Connection conn=DriverManager.getConnection("jdbc:odbc:mydata","sa","");
- //创建存储过程的对象
- CallableStatement c=conn.prepareCall("{call getsum(?,?)}");
- //给存储过程的第一个參数设置值
- c.setInt(1,100);
- //注冊存储过程的第二个參数
- c.registerOutParameter(2,java.sql.Types.INTEGER);
- //运行存储过程
- c.execute();
- //得到存储过程的输出參数值
- System.out.println (c.getInt(2));
- conn.close();
- }
- }
2:返回varchar
存储过程带游标:
在存储过程中带游标 使用游标不停的遍历orderid
- create procedure CursorIntoProcedure
- @pname varchar(8000) output
- as
- --定义游标
- declare cur cursor for select orderid from orders
- --定义一个变量来接收游标的值
- declare @v varchar(5)
- --打开游标
- open cur
- set @pname=''--给@pname初值
- --提取游标的值
- fetch next from cur into @v
- while @@fetch_status=0
- begin
- set @pname=@pname+';'+@v
- fetch next from cur into @v
- end
- print @pname
- --关闭游标
- close cur
- --销毁游标
- deallocate cur
运行存储过程:
- exec CursorIntoProcedure ''
JAVA调用:
- import java.sql.*;
- public class ProcedureTest
- {
- public static void main(String args[]) throws Exception
- {
- //载入驱动
- DriverManager.registerDriver(new sun.jdbc.odbc.JdbcOdbcDriver());
- //获得连接
- Connection conn=DriverManager.getConnection("jdbc:odbc:mydata","sa","");
- CallableStatement c=conn.prepareCall("{call CursorIntoProcedure(?)}");
- c.registerOutParameter(1,java.sql.Types.VARCHAR);
- c.execute();
- System.out.println (c.getString(1));
- conn.close();
- }
- }
C:删除数据的存储过程
存储过程:
- drop table 学生基本信息表
- create table 学生基本信息表
- (
- StuID int primary key,
- StuName varchar(10),
- StuAddress varchar(20)
- )
- insert into 学生基本信息表 values(1,'三毛','wuhan')
- insert into 学生基本信息表 values(2,'三毛','wuhan')
- create table 学生成绩表
- (
- StuID int,
- Chinese int,
- PyhSics int
- foreign key(StuID) references 学生基本信息表(StuID)
- on delete cascade
- on update cascade
- )
- insert into 学生成绩表 values(1,99,100)
- insert into 学生成绩表 values(2,99,100)
创建存储过程:
- create procedure delePro
- @StuID int
- as
- delete from 学生基本信息表 where StuID=@StuID
- --创建完成
- exec delePro 1 --运行存储过程
- --创建存储过程
- create procedure selePro
- as
- select * from 学生基本信息表
- --创建完成
- exec selePro --运行存储过程
在JAVA中调用:
- import java.sql.*;
- public class ProcedureTest
- {
- public static void main(String args[]) throws Exception
- {
- //载入驱动
- DriverManager.registerDriver(new sun.jdbc.odbc.JdbcOdbcDriver());
- //获得连接
- Connection conn=DriverManager.getConnection("jdbc:odbc:mydata","sa","");
- //创建存储过程的对象
- CallableStatement c=conn.prepareCall("{call delePro(?)}");
- c.setInt(1,1);
- c.execute();
- c=conn.prepareCall("{call selePro}");
- ResultSet rs=c.executeQuery();
- while(rs.next())
- {
- String Stu=rs.getString("StuID");
- String name=rs.getString("StuName");
- String add=rs.getString("StuAddress");
- System.out.println ("学号:"+" "+"姓名:"+" "+"地址");
- System.out.println (Stu+" "+name+" "+add);
- }
- c.close();
- }
- }
D:改动数据的存储过程
创建存储过程:
- create procedure ModPro
- @StuID int,
- @StuName varchar(10)
- as
- update 学生基本信息表 set StuName=@StuName where StuID=@StuID
运行存储过程:
- exec ModPro 2,'四毛'
JAVA调用存储过程:
- import java.sql.*;
- public class ProcedureTest
- {
- public static void main(String args[]) throws Exception
- {
- //载入驱动
- DriverManager.registerDriver(new sun.jdbc.odbc.JdbcOdbcDriver());
- //获得连接
- Connection conn=DriverManager.getConnection("jdbc:odbc:mydata","sa","");
- //创建存储过程的对象
- CallableStatement c=conn.prepareCall("{call ModPro(?,?)}");
- c.setInt(1,2);
- c.setString(2,"美女");
- c.execute();
- c=conn.prepareCall("{call selePro}");
- ResultSet rs=c.executeQuery();
- while(rs.next())
- {
- String Stu=rs.getString("StuID");
- String name=rs.getString("StuName");
- String add=rs.getString("StuAddress");
- System.out.println ("学号:"+" "+"姓名:"+" "+"地址");
- System.out.println (Stu+" "+name+" "+add);
- }
- c.close();
- }
- }
E:查询数据的存储过程(模糊查询)
存储过程:
- create procedure FindCusts
- @cust varchar(10)
- as
- select customerid from orders where customerid
- like '%'+@cust+'%'
运行:
- execute FindCusts 'alfki'
在JAVA中调用:
- import java.sql.*;
- public class ProcedureTest
- {
- public static void main(String args[]) throws Exception
- {
- //载入驱动
- DriverManager.registerDriver(new sun.jdbc.odbc.JdbcOdbcDriver());
- //获得连接
- Connection conn=DriverManager.getConnection("jdbc:odbc:mydata","sa","");
- //创建存储过程的对象
- CallableStatement c=conn.prepareCall("{call FindCusts(?)}");
- c.setString(1,"Tom");
- ResultSet rs=c.executeQuery();
- while(rs.next())
- {
- String cust=rs.getString("customerid");
- System.out.println (cust);
- }
- c.close();
- }
- }
F:添加数据的存储过程
存储过程:
- create procedure InsertPro
- @StuID int,
- @StuName varchar(10),
- @StuAddress varchar(20)
- as
- insert into 学生基本信息表 values(@StuID,@StuName,@StuAddress)
调用存储过程:
- exec InsertPro 5,'555','555'
在JAVA中运行:
- import java.sql.*;
- public class ProcedureTest
- {
- public static void main(String args[]) throws Exception
- {
- //载入驱动
- DriverManager.registerDriver(new sun.jdbc.odbc.JdbcOdbcDriver());
- //获得连接
- Connection conn=DriverManager.getConnection("jdbc:odbc:mydata","sa","");
- //创建存储过程的对象
- CallableStatement c=conn.prepareCall("{call InsertPro(?,?,?)}");
- c.setInt(1,6);
- c.setString(2,"Liu");
- c.setString(3,"wuhan");
- c.execute();
- c=conn.prepareCall("{call selePro}");
- ResultSet rs=c.executeQuery();
- while(rs.next())
- {
- String stuid=rs.getString("StuID");
- String name=rs.getString("StuName");
- String address=rs.getString("StuAddress");
- System.out.println (stuid+" "+name+" "+address);
- }
- c.close();
- }
- }
G:在JAVA中创建存储过程 而且在JAVA中直接调用
- import java.sql.*;
- public class ProcedureTest
- {
- public static void main(String args[]) throws Exception
- {
- //载入驱动
- DriverManager.registerDriver(new sun.jdbc.odbc.JdbcOdbcDriver());
- //获得连接
- Connection conn=DriverManager.getConnection("jdbc:odbc:mydata","sa","");
- Statement stmt=conn.createStatement();
- //在JAVA中创建存储过程
- stmt.executeUpdate("create procedure OOP as select * from 学生成绩表");
- CallableStatement c=conn.prepareCall("{call OOP}");
- ResultSet rs=c.executeQuery();
- while(rs.next())
- {
- String chinese=rs.getString("Chinese");
- System.out.println (chinese);
- }
- conn.close();
- }
- }
Java对存储过程的调用方法的更多相关文章
- Java对存储过程的调用方法 --转载
一.Java如何实现对存储过程的调用: A:不带输出参数的 create procedure getsum <--此处为参数--> as declare @sum int<--定义变 ...
- JAVA对存储过程的调用方法(本文源于网络)
博客分类: java java存储过程sql 一:Java如何实现对存储过程的调用: A:不带输出参数的 ---------------不带输出参数的-------------------- ...
- MySql 存储过程及调用方法
存储过程实例: DELIMITER $$drop procedure if exists ff $$CREATE /*[DEFINER = { user | CURRENT_USER }]*/ PRO ...
- 创建自己的java类库并加以调用方法
第一次搞博客,心里有点发慌,记录一下:2018/2/1/ 21:33 今天Think In Java第4版 中文版(英文看着可能很耗时),看到了6.1.3 定制工具库这一章节,之前作者调用自己的类 ...
- java对过反射调用方法
public class InvokeTester { public InvokeTester() { } String str; public InvokeTester(String str) ...
- Java基础 throws 提示调用方法时要注意处理相关异常
JDK :OpenJDK-11 OS :CentOS 7.6.1810 IDE :Eclipse 2019‑03 typesetting :Markdown code ...
- C#调用JAVA(二)调用方法
上期我们创建了jar包并放到了unity中,那么我们继续 如果您还没有看上一期请先看上一期,这是链接 C#调用JAVA(一)制作jar包 - 执著GodShadow - 博客园 (cnblogs.co ...
- mysql 自定义函数与自定义存储过程的调用方法
存储过程:call 过程名(参数) 函数: select 函数名(参数)
- Java基础(四)方法和数组
一.方法 1.方法的定义 方法也叫函数,就是一个能独立完成某个功能的一段代码.方法可以看作一个整体. 语法: 修饰符 返回类型 方法名字(数据类型 变量名,数据类型 变量名,……[形式参数(0个到n个 ...
随机推荐
- HTTP2.0协议
HTTP2.0协议 http2协议的草案已经出来了,阅读了一下网上的中文版,http2尽可能的兼容http1.1.改进了http1.1协议的不足. http1.0和http1.1的缺点: 1.http ...
- Debug with Eclipse
In this post we are going to see how to develop applications using Eclipse and Portofino 4. The trad ...
- 2014在百度之星资格赛的第二个问题Disk Schedule
事实上,我认为它可以用来费用流问题.但光建地图上加班. ..不科学啊.. . 因副作用太大,否则,必然在.最后,想啊想,或者使用dp对.... 别想了一维dp... .我不知道我是怎么想.无论如何,这 ...
- Zygote过程【3】——SystemServer诞生
欢迎转载.转载请注明:http://blog.csdn.net/zhgxhuaa 在ZygoteInit的main()方法中做了几件大事.当中一件便是启动Systemserver进程.代码例如以下: ...
- AndroidAnnotations说明—AndroidAnnotations它是如何工作的?
AndroidAnnotations它的工作原理很easy,它使用标准java注塑加工工具,自己主动加她一个额外的步骤生成源代码编译. 源代码是什么?每个增强的类.比方每个用@EAct ...
- Spring MVC 基础
Spring MVC 基础 1.Web MVC基础 MVC的本质是表现层模式,我们以视图模型为中心,将视图和控制器分离出来.就如同分层模式一样,我们以业务逻辑为中心,把表现层和数据访问层代码分离出来是 ...
- 乐在其中设计模式(C#) - 提供者模式(Provider Pattern)
原文:乐在其中设计模式(C#) - 提供者模式(Provider Pattern) [索引页][源码下载] 乐在其中设计模式(C#) - 提供者模式(Provider Pattern) 作者:weba ...
- partial 的好处
1.可以将一个类中的属 性, 方法分类来写 2.方法了可以写在多个类中, 这样可以对方法进行分类 由于项目上使用了代码生成工具, 自定义的一些按钮事件默认是不生成的,得自己定义,如果把定义的代码写 ...
- TI C66x DSP 系统events及其应用 - 5.8(ISTP)
中断服务表指针ISTP(Interrupt Service Table Pointer)位置寄存器用于定位的中断服务例程,那ISTP去哪里找要运行的程序,ISTP(当中的ISTB字段)就是指向IST表 ...
- Android - 用Fragments实现动态UI - 创建灵活的UI
当设计程序来支持各种不一样的屏幕尺寸时,可以在不同的布局中重用fragment来根据可用的屏幕大小来优化用户体验. 例如,在手机上可能使用一个fragment来使用单窗口用户体验比较合适.但是,你可能 ...