使用 链接服务器执行SELECT、UPDATE、INSERT 或 DELETE 及其它命令

当在SQL SERVER中建立好链接服务器之后,我们可以使用下面的方法对远程的数据库进行相关的操作。

假设链接服务器的名称为 Orcl

 

SELECT:

    指明要选择的列的过虑条件,可以传入到openquery方法中,也可以在选出之后过滤。

   

    select * from openquery(Orcl,'select * from dept');

    select * from openquery(Orcl,'select * from dept where deptno > 10');

    select * from openquery(Orcl,'select * from dept') where deptno > 10; 


 

    也可以使用下面的方法来检查数据。

   

    select * from ORCL..SCOTT.DEPT; ---表名一定要用大写,不然会出现表找不到的错误。

    select * from ORCL..SCOTT.DEPT where deptno > 10;


 

UPDATE

    指明要更新的行,过滤条件可以传入到openquery参数中,也可以在选出后添加过滤条件。

  

    update openQuery(orcl,'select * from dept where deptno = 10') set dname = 'New Name';

    update openQuery(orcl,'select * from dept') set dname = 'New Name2' where deptno = 10;


 

    同上,也可以使用下面的方法来更新数据

   

    update ORCL..SCOTT.DEPT set loc = 'NEW YORK' where deptno=10;---表名一定要用大写


 

INSERT

    指明要插入的列,只要指出要插入的列即可,不需要选出数据。

   

    insert into openquery(orcl,'select deptno,dname,Loc from dept where 1=0') values (50,'newDept','loc');

    insert into openquery(orcl,'select deptno,dname from dept where 1=0') values (60,'newDept');


 

    同上,也可以使用下面的方法来插入数据

   

    insert into ORCL..SCOTT.DEPT values(50,'dname','loc')


    对Oracle10g测试发现,如果列数与待插入表的列数不一致时,会报错,所以必须与原表的列数一致才行。

 

DELETE

    指明过滤条件,过滤条件可以作为openquery的参数传入,也可以在openquery之外使用。

  

    delete from openquery(orcl,'select deptno from dept where deptno=60');

    delete from openquery(orcl,'select deptno from dept') where deptno=50;


    同上,也可以使用下面的方法来删除数据

 

  delete from ORCL..SCOTT.DEPT where deptno=60;---表名一定要用大写




原文:http://blog.csdn.net/lenoval/article/details/4272610

  • 5
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值