oracle调用java程序连sqlserver2005

php中文网
发布: 2016-06-07 15:51:23
原创
1271人浏览过

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

oracle调用java程序连sqlserver2005

1、在oraclesys-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的方式loadoracle中,也可以利用plsqljava source

 

 

 

2oraclesys-sysdba下登陆

loadjavasqlserver2005驱动loadoracle,在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
  );

4oraclesys-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表中写数据!~

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
相关标签:
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号