ACCESS-如何多数据库查询(跨库查询)

测试通过:
ACCESS
select * from F:\MYk.mdb.tablename
说明:1.查询语句2.来原于哪(没有密码是个路径)3.查询的表名

=======================================
我有两个数据库 
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_200702.dbo.content_table b,content_table a where b.filetitle=a.filetitle"

Oracle跨库查询

首先创建数据库链接:
CREATE PUBLIC DATABASE LINK 数据链名称 CONNECT TO 登陆用户名 IDENTIFIED BY 密码 USING ‘(DESCRIPTION =
     (ADDRESS_LIST =
       (ADDRESS = (PROTOCOL = TCP)(HOST = 对方Oracle服务器的IP地址)(PORT = 端口号))
     )
     (CONNECT_DATA =
(SERVICE_NAME = 对方Oracle服务器服务名)
     )
   )‘

其中 数据链名称 为添加到本地Oracle数据库控制台(Oracle Enterprise Manager Console)树节点的服务名

要查询对方数据库的表TableName语句如下:

SELECT 字段名 FROM [email protected]数据链名称;

由于业务逻辑的多样性 
经常得在sql server中查询不同数据库中数据 
这就产生了分布式查询的需求 
现我将开发中遇到的几种查询总结如下:

1.access版本

--建立连接服务器 
EXEC sp_addlinkedserver 
--要创建的链接服务器名称 
‘ai‘, 
--产品名称 
‘access‘, 
--OLE DB 字符 
‘Microsoft.Jet.OLEDB.4.0‘, 
--数据源 
--格式: 
-- 盘符:\路径\文件名 
-- \\网络名\共享名\文件名 (网络版本) 
‘d:\testdb\db.mdb‘ 
GO

--创建链接服务器上远程登录之间的映射 
--链接服务器默认设置为用登陆的上下文进行 
--现在我们修改为连接链接服务器不需使用任何登录或密码 
exec sp_addlinkedsrvlogin ‘ai‘,‘false‘ 
go

--查询数据 
select * from ai...mytable 
go

2.excel版本

--建立连接服务器 
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

--查询数据 
select * from ai_ex...sheet3$ 
go

3.ms sql版本

--建立连接服务器 
EXEC sp_addlinkedserver 
--要创建的链接服务器名称 
‘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

--创建链接服务器上远程登录之间的映射 
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, 
--Oracle服务器的登陆用户名 
‘F02M185‘, 
--Oracle服务器的登陆密码 
‘f02m185185‘ 
go

--查询数据 
--格式:LinkServer..Oracle用户名.表名 
--注意用大写,因为在Oracle的数据字典中为大写 
select * from o..F02M185.AI 
go

时间: 2024-07-30 09:04:24

ACCESS-如何多数据库查询(跨库查询)的相关文章

django中使用多个数据库,跨库查询

一.settings配置多个数据库 DATABASES = { 'default': { # 'ENGINE': 'django.db.backends.mysql', 'ENGINE': 'common_framework.utils.mysql', 'NAME': 'choice', 'USER': 'ad_user', 'PASSWORD': 'ad_pass', 'HOST': '127.0.0.1', 'PORT': '3306', 'SIZE': '10', }, 'platform

用游标循环读取数据库名称,逐个打开数据库实现跨库查询

DECLARE @SQL VARCHAR(MAX) DECLARE test_cursor CURSOR SCROLL FOR SELECT PFDB_No from dbo.PFDBInfoTable OPEN test_cursor DECLARE @PFDBNo nchar(11) FETCH NEXT FROM test_cursor INTO @PFDBNo WHILE @@FETCH_STATUS=0 BEGIN PRINT @PFDBNo SET @SQL='SELECT * FR

Access数据库跨库查询及记录集区分

医疗设备软件一般都是单机软件,如果是Windows平台,常会选择Access数据库存储结构化数据,因为他轻量,便于部署.然而随着医疗信息化的发展,医生希望对多台单机设备的数据进行管理,采用网络数据库当然可以解决这个问题,但软件部署会变得比较麻烦,所以如果Access数据能支持跨库查询,那就完美了,可喜的是Access从2007版就已经支持该功能了,且查询速度还非常快. Access数据库跨库查询可使用"in 字句",语法如下,可参见微软帮助手册:https://support.offi

数据库跨库查询

由于微服务技术发展迅猛,在我们的架构中,每个微服务都会相应的对接一个数据库,各个数据库之间有关联的表(比如用户表.业务表等)会互相同步数据,其他的数据操作各自独立(如日志表.操作表等),这么设计是基于性能考虑降低数据库容量及尽最大努力避免性能遭遇瓶颈.这么设计对于container来说确实是极友好的,在日常运维中,比如每月/季度的数据汇总就难受了,身为DBA,处理跨表查询应该是小case,然而在hibernate跨表查询中,虽然麻烦但还是啃一下还是可以解决的.然而最近接到的需求却是要,跨!库!联

Oracle 跨库 查询 复制表数据

在目前绝大部分数据库有分布式查询的需要.下面简单的介绍如何在oracle中配置实现跨库访问. 比如现在有2个数据库服务器,安装了2个数据库.数据库server A和B.现在来实现在A库中访问B的数据库. 第一步.配置A服务器端的tnsnames.ora文件(TNSNAMES.ORA Network Configuration File),该文件存放的位置为: $ORACLE_HOME/network/admin/tnsnames.ora 需要在该文件中增加对B库的配置项,格式如下 ZBCDB3

SQLServer跨库查询--分布式查询

出处:http://www.cnblogs.com/doosmile/archive/2012/03/16/2400646.html --用openrowset连接远程SQL或插入数据 --如果只是临时访问,可以直接用openrowset --查询示例 select * from openrowset('SQLOLEDB' ,'sql服务器名';'用户名';'密码' ,数据库名.dbo.表名) 在跨库查询时需要启用Ad Hoc Distributed Queries启用Ad Hoc Distri

分库分表的几种常见玩法及如何解决跨库查询等问题

在谈论数据库架构和数据库优化的时候,我们经常会听到"分库分表"."分片"."Sharding"-这样的关键词.让人感到高兴的是,这些朋友所服务的公司业务量正在(或者即将面临)高速增长,技术方面也面临着一些挑战.让人感到担忧的是,他们系统真的就需要"分库分表"了吗?"分库分表"有那么容易实践吗?为此,笔者整理了分库分表中可能遇到的一些问题,并结合以往经验介绍了对应的解决思路和建议. 垂直分表 垂直分表在日常开

SqlServer跨库查询

由于业务的拆分,数据库拆分为两种作用: 汇总数据库(Master,头节点数据库), 子节点数据库(Compute Node,计算子节点数据库) 这样,就设计到子节点访问头节点数据库中的某张汇总表,这种表的记录一般在几,到几十万行左右,目前适合做跨库查询. 跨库查询目前分为两种: 通过sp_addlinkedserver建立链接服务器 没有链接服务器时,可以使用openrowset或者opendatasource函数 在部署时,需要在SQLSERVER外围应用配置器中启用OpenRowSet和Op

SQLServer跨库查询--分布式查询[转载]

--用openrowset连接远程SQL或插入数据 --如果只是临时访问,可以直接用openrowset --查询示例 select * from openrowset('SQLOLEDB' ,'sql服务器名';'用户名';'密码' ,数据库名.dbo.表名) --导入示例 select * into 表 from openrowset('SQLOLEDB' ,'sql服务器名';'用户名';'密码' ,数据库名.dbo.表名) --创建链接服务器 exec sp_addlinkedserve