Welcome 微信登录

首页 / 数据库 / MySQL / 为Sybase ASA创建外部存储过程(Java示例)

衡量一个DBMS的功能是否强大,外部存储过程是否很方便创建和使用,是一个重要特征。ASA数据库,很早就开始支持使用C, CLR(.NET)以及java等编程语言来创建存储过程。下面介绍一个简单的示例,来创建一个基于Java 的ASA存储过程, 数据库(ASA11.0或以上版本), 该示例很简单,输入主机名,返回对应的IP地址,如果不能解析,返回"".先编写一个java类,大致内容如下:
import java.net.InetAddress;
import java.net.UnknownHostException;
public class SUPProcUtils
{
 
    public static String getIPOfHost(String host)
    {
        String resolvedIP = "";
        try
        {
            resolvedIP = InetAddress. getByName(host).getHostAddress();
        }
        catch (UnknownHostException e)
        {
        }
        return resolvedIP;
     
    }
 
    public static void main(String[] args)
    {
        System. out.println(getIPOfHost( "www.linuxidc.com"));
    }
}
然后连接目标数据库,执行下述SQL语句:
1. 指定jvm位置
alter external environment java location "C:\shared\jdk1.6.0_31_x86\bin\java.exe"; // 这个主要是指定JVM的位置。2. 安装java classinstall java new from file "C:\Users\workspace\test\bin\SUPProcUtils.class";3. 创建存储过程(函数)
create function getIPOfHost(IN hostname CHAR(128)) returns VARCHAR(128)
external name "SUPProcUtils.getIPOfHost(Ljava/lang/String;)Ljava/lang/String;"
language JAVA;
这里边主要要注意的是参数类型以及返回值班类型,可以使用javap -c <class>得到原型说明。4.示例查询:
select getIPOfHost("xxx.xxx.com");
返回:
100.172.102.173总体来说,还是非常简单的。
至于ASA的C存储过程的创建,步骤稍麻烦些,代码写起来也稍费时间些,但是C存储过程是最高效的,因为它的执行不需要单独的JVM或者CLR运行时环境。Sybase ASE15.x中启用跟踪SQL语句的方法Oracle直接路径加载--append的深度解析相关资讯      Sybase  Sybase ASA  Sybase存储过程 
  • Sybase ASE1252(X) for RHEL5.4   (05/04/2013 08:16:58)
  • sybase的SQL多表联合查询调优  (04/25/2013 07:52:02)
  • Sybase Adaptive Server   (01/11/2013 08:43:12)
  • sybase的SQL去掉字段中的/x0a(换行  (04/25/2013 07:54:09)
  • Sybase ASE15.x中启用跟踪SQL语句  (02/07/2013 08:21:24)
  • SCC 3.2.7 for Sybase ASE15.x安装  (11/20/2012 11:34:29)
本文评论 查看全部评论 (0)
表情: 姓名: 字数

版权所有©石家庄振强科技有限公司2024 冀ICP备08103738号-5 网站地图