orcale和mysql跨库查询_ORACLE跨数据库查询的⽅法我有两个数据库
A、B
然后我要将两个数据库的两张表组合作为⼀张表C显⽰
判断条件是
A数据库的aa表中字段a和B数据库的bb表中字段b相等
并且A数据库的aa表中字段a或B数据库的bb表中字段b等于某个值
⽰例:
sql="select b.filetitle as t1 ,a.publishtime as t2 from opendatasource('sqloledb' ,'data source =192.168.0.2;UID=sa; pwd=123456' ).f_FS_DB_site_yaoban_t_table b,content_table a where b.filetitle=a.filetitle"
⾸先创建数据库链接:
CREATE PUBLIC DATABASE LINK 数据链名称 CONNECT TO 登陆⽤户名 IDENTIFIED BY 密码 USIN
G '(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 对⽅Oracle服务器的IP地址)(PORT = 端⼝号))
)
(CONNECT_DATA =
(SERVICE_NAME = 对⽅Oracle服务器服务名)
)
)'
其中 数据链名称 为添加到本地Oracle数据库控制台(Oracle Enterprise Manager Console)树节点的服务名
要查询对⽅数据库的表TableName语句如下:
SELECT 字段名 FROM TableName@数据链名称;
由于业务逻辑的多样性
经常得在sql server中查询不同数据库中数据
这就产⽣了分布式查询的需求
现我将开发中遇到的⼏种查询总结如下:
1.access版本
--建⽴连接服务器
EXEC sp_addlinkedserver
--要创建的链接服务器名称
'ai',
--产品名称
'access',
-
-OLE DB 字符
'Microsoft.Jet.OLEDB.4.0',
--数据源
--格式:
-- 盘符:\路径\⽂件名
school bag-- \\⽹络名\共享名\⽂件名 (⽹络版本)
'd:\testdb\db.mdb'
GO
--创建链接服务器上远程登录之间的映射
--链接服务器默认设置为⽤登陆的上下⽂进⾏
--现在我们修改为连接链接服务器不需使⽤任何登录或密码exec sp_addlinkedsrvlogin 'ai','false'
go
--查询数据
select * able
go
--建⽴连接服务器
EXEC sp_addlinkedserver
--要创建的链接服务器名称
'ai_ex',
--产品名称
'ex',
-
-OLE DB 字符
'Microsoft.Jet.OLEDB.4.0',
--数据源
--格式:
-- 盘符:\路径\⽂件名
-- \\⽹络名\共享名\⽂件名 (⽹络版本)
'd:\testdb\mybook.xls' ,
null,
--OLE DB 提供程序特定的连接字符串
'Excel 5.0'
GO
-
---创建链接服务器上远程登录之间的映射
--链接服务器默认设置为⽤登陆的上下⽂进⾏
--现在我们修改为连接链接服务器不需使⽤任何登录或密码exec sp_addlinkedsrvlogin 'ai_ex','false'
go
jqueryui是什么--查询数据
select * from sheet3$
go
3.ms sql版本
--建⽴连接服务器
EXEC sp_addlinkedserver
--要创建的链接服务器名称mysql语句转oracle
'ai_mssql',
--产品名称
'ms',
--OLE DB 字符
'SQLOLEDB',
--数据源
'218.204.111.111,3342'
GO
--创建链接服务器上远程登录之间的映射
EXEC sp_addlinkedsrvlogin
'ai_mssql',
'false',
NULL,
--远程服务器的登陆⽤户名
'zhangzhe',
--远程服务器的登陆密码
'fish2231'
go
--查询数据
select * from ai_mssql.pubs.dbo.jobs
go
--还有⼀个更简单的办法
-
-这种⽅式在链接服务器建⽴后,它是默认开放RPC的
--建⽴连接服务器
EXEC sp_addlinkedserver
--要创建的链接服务器名称
--这⾥就⽤数据源作名称
'218.204.111.111,3342',
'SQL Server'
GO
scratch编程教程第一集--创建链接服务器上远程登录之间的映射
EXEC sp_addlinkedsrvlogin
'218.204.111.111,3342',
'false',
NULL,
--远程服务器的登陆⽤户名
'zhangzhe',
--远程服务器的登陆密码
'fish2231'
go
--查询数据
select * from [218.204.253.131,3342].pubs.dbo.jobs go
4.Oracle版本
--建⽴连接服务器
EXEC sp_addlinkedserver
--要创建的链接服务器名称
'o',
--产品名称
'Oracle',
--OLE DB 字符
'MSDAORA',
--数据源
'acc'
GO
--创建链接服务器上远程登录之间的映射
EXEC sp_addlinkedsrvlogin
'o',
金光布袋戏入坑顺序'false',
NULL,
python买哪本书--Oracle服务器的登陆⽤户名
'F02M185',
--Oracle服务器的登陆密码
'f02m185185'
go
--查询数据
--格式:LinkServer..Oracle⽤户名.表名
-
-注意⽤⼤写,因为在Oracle的数据字典中为⼤写select * from o..F02M185.AI
go
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论