使用 链接服务器执行SELECT、UPDATE、INSERT 或 DELETE 及其它命令
https://blog.csdn.net/zhou279818998/article/details/80691544
当在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;---表名一定要用大写
本文来自博客园,作者:CelonY,转载请注明原文链接:https://www.cnblogs.com/CelonY/p/15891532.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?