数据库

本类阅读TOP10

·SQL语句导入导出大全
·SQL Server日期计算
·SQL语句导入导出大全
·SQL to Excel 的应用
·Oracle中password file的作用及说明
·MS SQLServer OLEDB分布式事务无法启动的一般解决方案
·sqlserver2000数据库置疑的解决方法
·一个比较实用的大数据量分页存储过程
·如何在正运行 SQL Server 7.0 的服务器之间传输登录和密码
·SQL中两台服务器间使用连接服务器

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
ORACLE与SQL之间的数据迁移

作者:未知 来源:月光软件站 加入时间:2005-2-28 月光软件站

高级数据迁移

       很多时间,要在异构数据库之间进行数据迁移或抽取,如果在SQL中提取ORACLE的数据,可以通过ODBCOLEDB等多种方式,要从ORACLE提取SQL中的数据,大都是通过透明网关来实现的。

       在异构数据抽取过程中,最好采用SQL92标准的语法编写SQL代码,同时要注意不同数据库之间数据类型的转换关系,如ORACLE的日期类型用DATESQLDatetime等。

 

关于ORACLE的透明网关配置

       ORACLE安装时(9i),将TRANSPARENT GATEWAY FOR MSSQL选中,在ORACLE主目录\BIN中,有个tg4msql.exe程序,它是透明网关程序啦,同时在主目录中还有tgrmsql的一个目录,ORACLE_HOME\tg4msql\admin目录中的inittg4msql.ora就是需要进行配置才能在ORACLE中连接SQL

2.1 tg4msql

1 如何配置透明网关呢?打开inittg4msql.ora:

#

# HS init parameters

# xzh代表SQL服务名,pubs代表要访问的SQL数据库

#

HS_FDS_CONNECT_INFO="SERVER=xzh;DATABASE=pubs"

HS_FDS_TRACE_LEVEL=OFF

HS_FDS_RECOVERY_ACCOUNT=RECOVER

HS_FDS_RECOVERY_PWD=RECOVER

2 监听的配置oracle_home\network\admin\Listiner.ora

LISTENER =

  (DESCRIPTION_LIST =

    (DESCRIPTION =

      (ADDRESS_LIST =

        (ADDRESS = (PROTOCOL = TCP)(HOST = xzh)(PORT = 1521))

      )

      (ADDRESS_LIST =

        (ADDRESS = (PROTOCOL = TCP)(HOST = xzh)(PORT = 1527))

      )

    )

  )

SID_LIST_LISTENER =

  (SID_LIST =

    (SID_DESC =

      (GLOBAL_DBNAME = xzh.world)

      (ORACLE_HOME = D:\oracle\ora92)

      (SID_NAME = xzh)

    )

    (SID_DESC =

       (GLOBAL_DBNAME = tg4msql)

       (PROGRAM = tg4msql)

       (SID_NAME = tg4msql)

       (ORACLE_HOME = D:\oracle\ora92)

    )

  )

       加亮代码是要在监听文件中新加部分,GLOBAL_DBNAMESID_NAME可以任意,PROGRM必须指向tg4msql如图2.1所示。

3 本地服务文件的配置oracle_home\network\admin\TnsNames.ora

XZH =

  (DESCRIPTION =

    (ADDRESS_LIST =

      (ADDRESS = (PROTOCOL = TCP)(HOST = xzh)(PORT = 1521))

    )

    (CONNECT_DATA =

      (SERVER = DEDICATED)

      (SERVICE_NAME = xzh.world)

    )

  )

 

TG4MSQL =

  (DESCRIPTION =

    (ADDRESS_LIST =

      (ADDRESS = (PROTOCOL = TCP)(HOST = xzh)(PORT = 1527))

    )

    (CONNECT_DATA =

      (SID = tg4msql)

    )

    (HS = OK)

  )

       使用SQL的本地服务名为TG4MSQL,可以任意写,SID必须是Listiner.ora中指定的那个SID_NAMEPORT也必须是监听中指定的PORT,主机等都要符合一致。 到此为止,我们把透明网关大致已经配置好啦,如果要访问SQL,还要使用数据库链才方便。

4 SQL中创建登录帐号xzh口令xzh,使用可以访问PUBS数据库。

CREATE  DATABASE  LINK sql CONNECT TO xzh IDENTIFIED BY xzh

USING ‘TG4MSQL’

这里的USING ‘TG4MSQL’tnsnames.ora中配置好的本地服务名,sql是我们以后要引用的数据库链名。

SQL>SELECT * FROM sales@sql

如果有数据返回,表示我们访问SQL数据库的通道已经建成,请大胆使用吧,但对远程异构数据库不充许进行DDL操作。

SQL>CREATE TABLE all_users@tg4msql FRIN all_users;

                      *

ERROR 位于第 1 :

ORA-02021: 不允许对远程数据库进行 DDL 操作

 

SQL访问ORACLE的方法

1 通过行集函数OPENDATASOURCE

       OPENDATASOURCE ( provider_name, init_string )

    SELECT  *

FROM OPENDATASOURCE(

         'MSDAORA',

         'Data Source=xzh.oracle;User ID=POS;Password=POS')..POS.A0325

       MSDAORAOLEDB FOR ORACLE的驱动,初始化字符串指定本地服务名、用户名、口令。然后引用表中数据时要以服务器..用户名.表名。注意一定是四部分组成,用户名与表名一定要大写。

       SELECT * INTO PUBS.DBO.A0325 FROM

OPENDATASOURCE(

         'MSDAORA',

         'Data Source=xzh.oracle;User ID=POS;Password=POS' )..POS.A0325

     --ORACLEPOS模式的A0325导入SQLPUBS数据库。

 2 通过SQL的链接服务器引用ORACLE的数据

   --查看已经存在的链接服务器

   SELECTFROM SYSSERVERS

   --添加链接服务器到SQL

   EXEC SP_ADDLINKEDSERVER

   @server = 'ORCL',                    --ORCLSQL中链接服务器名称

   @srvproduct = 'Oracle',        --Oracle        固定的            

   @provider = 'MSDAORA',             --MSDAORA   固定的

   @datasrc = 'xzh.oracle'                 --DataSrc      本地服务名

  

   EXEC SP_DROPSERVER ‘ORCL’       --删除链接服务器

  

       在这里声明一下,如果现在就访问ORACLE肯定不能,因为没有提供登录ORACLE的用户名/口令

       EXEC SP_ADDLINKEDSRVLOGIN 'ORCL', false, 'sa', 'POS', 'POS'

SaSQL本地登录帐号,POS/POSORACLE的登录帐号,但这句话对我们要达到的目的没有帮助。

SELECT * FROM ORCL..POS.A0325

还是四部分组成,注意事项同上,为什么不行呢,本人一直在寻找解决办法,最后发现通过SQL语句没法解决,只有打开SQL的企业管理器。

2.2 配置ORACLE的远程帐号

2.3设置远程登录帐号

SELECT * FROM ORCL..POS.A0325   --这次终于OK

SELECT * FROM OPENQUERY(ORCL, 'SELECT * FROM POS.A0325')

3 使用SQLOPENROWSET函数

SELECT a.*

FROM OPENROWSET('MSDAORA',

   'xzh.oracle';'POS';'POS', POS.A0325) AS a ORDER BY a.ID

 

有些地方要用别名才能引用,请大家注意。

 

4使用ODBC的方式

SELECT A.*

FROM OPENROWSET('MSDASQL','ORCL_ODBC';'POS';'POS',

   POS.A0325) AS  A

ORDER BY A.ID

 

ORCL_ODBCORACLEODBC数据源,创建ODBC不用我说吧,以上所有代码在SQL QUERY ANALYZE 中通过。

 

总结

       关于SQL访问ORACLE有四种方式,其中通过ODBC与链接服务器的方式做起来难度较大,对手新手会麻烦一些,使用OLE DB FOR ORACL驱动时,有OPENDATASOURCEOPENROWSET函数可以使用,都很方便,笔记喜欢使用后者,交待一下,在数据存取方面,这四种方面效率相当。

 




相关文章

相关软件