温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

oracle中怎么通过调用java程序连sqlserver2005

发布时间:2021-08-03 16:43:55 来源:亿速云 阅读:126 作者:Leah 栏目:数据库

这期内容当中小编将会给大家带来有关oracle中怎么通过调用java程序连sqlserver2005,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

1、在oracle的sys-sysdba下登陆

写一个java source程序链接sqlserver2005:

create or replace and compile java source named test as
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
public class excutesql1
{
    public static String entry(String str1,String str2) {

       String driverName = "com.microsoft.sqlserver.jdbc.SQLServerDriver";
       // 加载jdbc驱动
    String a = "0";
       String dbURL = "jdbc:sqlserver://localhost:1433;DatabaseName=wb"; // 链接数据库服务和驱动sample
       String userName = "sa"; // 用户名
       String userPwd = "giap"; // 密码
       Connection dbConn;

       try {
      a = "1";
           Class.forName(driverName);
           dbConn = DriverManager.getConnection(dbURL, userName, userPwd);
           String sql = "insert into ry_jbxx (RYBH,XM) values ('" + str1
                  + "','" + str2 + "')";
           PreparedStatement pstmt = dbConn.prepareStatement(sql);
           pstmt.addBatch();
           pstmt.executeBatch();
      a = "2";
       } catch (Exception e) {
           e.printStackTrace();
      a = "error";
          
       }
    return a;
    }
}

(注:java程序可以用loadjava的方式load到oracle中,也可以利用plsql写java source)

2、在oracle的sys-sysdba下登陆

用loadjava将sqlserver2005驱动load到oracle,在dos下执行:

loadjava -u sys/giap@zhxtdb -r -v   sqljdbc.jar

测试链接是否成功:

写一个函数:

create or replace function insert2(a varchar2, b varchar2) return varchar2 as
 language java name 'excutesql1.entry(java.lang.String,java.lang.String) return java.long.String';

测试链接!~

(注:一定要在sysdba下执行)

Sqlserver2005测试数据库:

CREATE TABLE [dbo].[msg](

    [tel] [varchar](50) NOT NULL,

    [msg] [varchar](50) NULL

)

3、测试成功后在普通用户(giapzhxt)下建表:

create table MSG
(
  TEL VARCHAR2(20),
  MSG VARCHAR2(200)
)
tablespace GIAPDATA
  pctfree 10
  initrans 1
  maxtrans 255
  storage
  (
    initial 64K
    minextents 1
    maxextents unlimited
  );

4、在oracle的sys-sysdba下登陆

New一个存储过程

create or replace procedure insertsqlserver2005(a varchar2, b varchar2) as
  language java name 'excutesql1.entry(java.lang.String,java.lang.String)';

在sys-sysdba下登陆new一个普通用户(giapzhxt)下表的触发器来执行存储过程:

create or replace trigger tri_zhxt_msg
  after insert on giapzhxt.msg 
  for each row
begin
  insertsqlserver2005(:new.tel,:new.msg);
end tri_zhxt_msg;

上述就是小编为大家分享的oracle中怎么通过调用java程序连sqlserver2005了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI