2024年4月11日发(作者:)
在Java中调用存储过程是怎样的
在Java中调用存储过程是怎样的
本文阐述了怎么使用DBMS存储过程。我阐述了使用存储过程的基本的和高级特性,
比如返回ResultSet。本文假设你对DBMS和JDBC已经非常熟悉,也假设你能够毫无障
碍地阅读其它语言写成的代码(即不是Java的语言),但是,并不要求你有任何存储过程的
编程经历。
存储过程是指保存在数据库并在数据库端执行的程序。你可以使用特殊的语法在Java
类中调用存储过程。在调用时,存储过程的名称及指定的参数通过JDBC连接发送给
DBMS,执行存储过程并通过连接(如果有)返回结果。
使用存储过程拥有和使用基于EJB或CORBA这样的应用服务器一样的好处。区别是
存储过程可以从很多流行的DBMS中免费使用,而应用服务器大都非常昂贵。这并不只
是许可证费用的问题。使用应用服务器所需要花费的管理、编写代码的费用,以及客户程
序所增加的复杂性,都可以通过DBMS中的存储过程所整个地替代。
你可以使用Java,Python,Perl或C编写存储过程,但是通常使用你的DBMS所指
定的特定语言。Oracle使用PL/SQL,PostgreSQL使用pl/pgsql,DB2使用Procedural
SQL。这些语言都非常相似。在它们之间移植存储过程并不比在Sun的EJB规范不同实现
版本之间移植Session Bean困难。并且,存储过程是为嵌入SQL所设计,这使得它们比
Java或C等语言更加友好地方式表达数据库的机制。
因为存储过程运行在DBMS自身,这可以帮助减少应用程序中的等待时间。不是在
Java代码中执行4个或5个SQL语句,而只需要在服务器端执行1个存储过程。网络上
的数据往返次数的减少可以戏剧性地优化性能。
使用存储过程
简单的老的JDBC通过CallableStatement类支持存储过程的调用。该类实际上是
PreparedStatement的一个子类。假设我们有一个poets数据库。数据库中有一个设置
诗人逝世年龄的存储过程。下面是对老酒鬼Dylan Thomas(old soak Dylan Thomas,
不指定是否有关典故、文化,请批评指正。译注)进行调用的详细代码:
try{
int age = 39;
String poetName = "dylan thomas";
CallableStatement proc = eCall("{ call set_death_age(?, ?) }");
ing(1, poetName);
(2, age);
e();
}catch (SQLException e){ // ....}


发布评论