a_s09
保罗马尔蒂尼
采纳率25%
2015-01-07 14:55

SQL2008下通过链接服务器远程访问ORACLE的数据兼任问题

已采纳

方式1,直接使用MS的MSDAORA驱动:

 EXEC sp_addlinkedserver
@server='ODS',--链接服务器名称
@srvproduct='Oracle',--固定
@provider='MSDAORA',--固定
@datasrc='ODSDB_WT'

方式2,使用ORACLE带的驱动,Oracle Provider for OLE DB
进行查询:

 select top 10 * from ODS..EDM_BASE.T03_NOACCOUNTJOUR_CTS
select top 10 * from ODS2..EDM_BASE.T03_NOACCOUNTJOUR_CTS

第一条使用方式1的查询正常,
第2条报错
消息 9803,级别 16,状态 1,第 2 行
数据不适用于类型 "numeric"。

不知有无什么方法能使用ORCLE驱动解决此类数据兼容问题?

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享
  • 邀请回答

1条回答

  • save4me save4me 6年前

    Oracle不支持Top,可以使用RowNum,比如

     SELECT *
     FROM (
        SELECT * from ODS..EDM_BASE.T03_NOACCOUNTJOUR_CTS) T
    WHERE rownum <= 10
    ORDER BY rownum;
    

    如果需要,可以在子句中按照需要的字段和方式先排好序,再通过RowNum取前几条记录

    点赞 1 评论 复制链接分享

相关推荐