Java如何实现对存储过程的调用
2017-09-26 23:05
489 查看
一:Java如何实现对存储过程的调用:
————–在SQL中执行:——————–
————在JAVA中调用:———————
JAVA可以调用 但是在JAVA程序却不能去显示该存储过程的结果 因为上面的存储
过程的参数类型int 传递方式是in(按值)方式
————————-带输出参数的—————-
——————-在查询分析器中执行————
————在JAVA中调用———————
2:返回varchar
—————-存储过程带游标—————-
————执行存储过程————–
————–JAVA调用——————
e7e3
——–
——————在JAVA中调用—————-
————-执行存储过程————————-
—————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(?)}"); //给存储过程的参数设置值, 将第一个参数的值设置成100 c.setInt(1, 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:删除数据的存储过程
——————存储过程——————e7e3
——–
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中创建存储过程 并直接调用
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 如何实现和调用 mysql存储过程
- Java如何实现对存储过程的调用
- 一:Java如何实现对存储过程的调用:
- 如何用JAVA调用存储过程
- 调用存储过程,java中通过bboss persistent实现数据库存储过程的调用(位置变量绑定)
- 如何实现 JDBC调用Oracle的存储过程
- oracle实现存储过程的分页并用java代码调用存储过程
- 如何实现在Oracle中应用存储过程调用MatLab函数(3)
- 在VC中如何实现对存储过程的循环调用?
- java下实现调用oracle的存储过程和函数
- Java实现mysql存储过程调用
- 在JAVA中实现数据库存储过程的统一调用
- JAVA如何调用mysql写的存储过程
- java下实现调用oracle的存储过程和函数
- java下实现调用oracle的存储过程和函数
- Java 调用存储过程中的集合,如何传参
- {传智播客} (学习笔记)--Java调用存储过程实现Oracle数据库分页
- 如何通过java程序调用oracle中的存储过程
- JAVA调用sqlserver存储过程的实现(返回多个结果集的实现)