1 后台sp伪代码(T-sql):
if exists (select * from sysobjects where name = 'someProcedoreName' and type = 'P')
drop proc someProcedoreName
go
create proc dbo.someProcedoreName
@param1 int,
@param2 varchar(7),
@param_out int output
AS
declare
... some varivles...
... some statements...
......
select @param_out = 0
......
2 在sql advantage客户端测试sp:
declare @rr int
exec someProcedoreName 920, '04/2009', @rr output
如果是一个没有带输出参数的sp, 用someProcedoreName param1, param2..就可以了,
但是我发现如果带输出参数,则要在前面加exec. 在这里耗了好久。
3 前端java代码:
public class TestSybaseProcedure {
public static void main(String[] args)throws Exception{
Class.forName("com.sybase.jdbc2.jdbc.SybDriver");
Connection cnn = DriverManager.getConnection("jdbc:sybase:Tds:db_url:port", "username", "password");
int status=-1;
CallableStatement cs = cnn.prepareCall("{ call someProcedoreName ?,?,? }");
cs.setInt(1, 920);
cs.setString(2, "04/2009");
cs.registerOutParameter(3, java.sql.Types.INTEGER);
cs.execute();
status = cs.getInt(3);
System.out.println(status);
}
}
分享到:
相关推荐
总结,Java调用Oracle存储过程涉及的关键点包括:JDBC连接,CallableStatement,输入/输出参数的设定,以及结果集的处理。理解这些知识点,能够帮助开发者有效地实现数据库操作,提升应用性能。
以下是如何使用Java调用Sysbase存储过程的示例: ```java CallableStatement cs = conn.prepareCall("{call myProcedure(?, ?)}"); cs.setInt(1, inputParam1); cs.registerOutParameter(2, java.sql.Types.VARCHAR...
- **创建Java存储过程**:首先需要编写Java类并编译成.class文件,然后通过SQL语句将这些文件加载到数据库中,最后定义存储过程的输入输出参数。 - **调用Java存储过程**:与传统的T-SQL存储过程类似,只需要使用...
此存储过程接受两个输入参数`num1`和`num2`,并计算它们的和,结果通过输出参数`result`返回。 ##### 调用存储过程 在Java中调用Oracle存储过程的方法如下: ```java CallableStatement cs = conn.prepareCall("{ ...
3. **设置输出参数**:如果存储过程需要返回结果,则需要定义输出参数。 4. **调用 `CREATE PROCEDURE` 命令**:使用 SQL 语法创建存储过程。 例如,创建一个名为 `GetSalesReport` 的存储过程,该过程接收一个日期...
- **存储过程与函数**:利用存储过程和函数封装复杂的业务逻辑,减少网络传输量。 - **分区策略**:对于大型表,可以采用分区技术来分割数据,从而加速查询响应时间。 - **缓存机制**:利用缓存技术缓存频繁访问的...
动态INCLUDE用jsp:include动作实现 它总是会检查所含文件中的变化,适合用于包含动态页面,并且可以带参数。 静态INCLUDE用include伪码实现,定不会检查所含文件的变化,适用于包含静态页面...
- **从存储过程调用中下载结果集**:MobiLink 支持通过存储过程来获取数据,这为高级应用提供了灵活性。 - **从自引用表上载数据**:对于自引用表来说,同步时需要特别注意数据的一致性和完整性。 - **MobiLink ...
动态INCLUDE用jsp:include动作实现 它总是会检查所含文件中的变化,适合用于包含动态页面,并且可以带参数。 静态INCLUDE用include伪码实现,定不会检查所含文件的变化,适用于包含静态页面...
### 软件工程师Java方向面试题解析 #### 1. 避免死锁的方法有哪些? 死锁是指两个或两个以上的进程在执行过程中,由于竞争资源或者彼此通信而造成的一种相互等待的现象,若无外力作用,它们都将无法推进下去。避免...
项目中的"Sybase"可能指的是Sybase数据库管理系统,这表明项目可能使用了Sybase作为其后端存储系统。Sybase是一个高性能、企业级的数据库解决方案,常用于处理大量数据和高并发的场景。 这个项目的源代码可能包含了...
### JDBC连接数据库应用详解 ... - 获取输出参数:`int result = cstmt.getInt(2);` 以上介绍了如何通过JDBC连接并操作数据库的基本流程。理解这些概念对于开发基于Java的应用程序来说是非常重要的。
开放的数据库物理结构文件格式(XML标准格式),并提供了外部调用数据库结构源程序 (包含C#/Delphi/JAVA三个版本)。 <br>11,支持多语言。 可根据需要增加新的语言包。 <br>website: ...
- SQLDA是数据描述区,用于在SQL语句和宿主语言之间传递数据,包括输入参数、输出结果以及游标操作中的列信息。 ### 第二节 SYBASE SQL SERVER嵌入式SQL语言 2.1 **一个嵌入SQL语言的简单例子** - 示例程序通常...
- 用于在宿主语言和SQL之间传递数据的结构,支持输入和输出参数以及结果集。 ### 第二节 SYBASE SQL SERVER 嵌入式 SQL 语言 1. **一个嵌入 SQL 语言的简单例子** ``` EXEC SQL CONNECT TO mydb USER myuser ...
14. 在 Java 程序 `Test.java` 的示例中,`main` 方法的参数数组 `args` 包含三个元素,但第二个元素 `args[1]` 的长度是 2,所以输出是 `3 2`。 15. C 语言程序中,字符数组 `p` 和字符串常量 `q` 的大小不同,`...
静态初始化器不带任何参数,并且不能直接调用。 ### 2. SQL(结构化查询语言) SQL是一种专门用于处理关系数据库的标准语言。它可以用来执行各种数据库操作,如查询、更新、删除等。SQL被广泛应用于各种类型的...
- **函数调用:** `fun`函数接收数组及其下标范围作为参数。 **答案解析:** 正确的答案是**12344**。经过`fun`函数的处理后,数组`a`的第4个元素被复制到第5个位置,其余元素不变,因此输出结果为12344。 ### 21....
- 栈是一种后进先出(LIFO)的数据结构,非常适合用来处理递归调用中的参数传递和返回地址的保存。 #### 12. 不同数制间的加法运算 - **知识点概述**:掌握不同数制下数值的加法运算方法。 - **详细解释**: - 本...