有的时候,我们做项目时,需要在不同的数据库中进行交互,如果在程序中写多个数据库连接多有不便。突然想到同事小李说如果在sql中能查询不同数据库的内容就好了,于是上网查了一下,果然可以实现,不敢独享,整理结果如下:
当前数据库为testA,要查询数据库testB中的某个表内容,我们就可以采用如下方法。
第一种:select * from 表名 in 'testB的路径';
例如:select * from qybm in 'd:/accessdb/testB.mdb';
第二种:select * from [;database=testB的路径;pwd=密码].表名
如果没密码,可省略
例如:select * from [;database=d:/accessdb/testB.mdb].qybm;
如果是组合查询:
两个表都在testB数据库,可采用:
select * from qybm1,qybm2 in 'd:/accessdb/testB.mdb' where qybm1.qydm=qybm2.qydm;
查询哪个数据库写一个in 'd:/accessdb/testB.mdb'就可以,下面方式是错误的:
select * from qybm1 in 'd:/accessdb/testB.mdb',qybm2 in 'd:/accessdb/testB.mdb' where qybm1.qydm=qybm2.qydm;
也可以采用第二种方法:就是:
select * from [;database=d:/accessdb/testB.mdb].qybm1,[;database=d:/accessdb/testB.mdb].qybm2 where qybm1.qydm=qybm2.qydm;
如果表qybm1在testA数据库,表qybm2在testB数据库中,为了区分不同库,只能用第二种方法:
select * from [;database=d:/accessdb/testA.mdb].qybm1,[;database=d:/accessdb/testB.mdb].qybm2 where qybm1.qydm=qybm2.qydm;
当前库为testA的话,可省略成:
select * from qybm1,[;database=d:/accessdb/testB.mdb].qybm2 where qybm1.qydm=qybm2.qydm;
可以根据实际需要灵活运用,例如:
select * from qybm1,[;database=d:/accessdb/testB.mdb].qybm2 in 'd:/accessdb/testA.mdb where qybm1.qydm=qybm2.qydm;
下面写几种任意运用的示例:
insert into qybm1 select * from [;database=d:/accessdb/testB.mdb].qybm2;
insert into qybm1 select * from qybm2 in 'd:/accessdb/testB.mdb';
insert into qybm1 in 'd:/accessdb/testA.mdb' select * from qybm2 in 'd:/accessdb/testB.mdb';
insert into [;database=d:/accessdb/testA.mdb].qybm1 select * from qybm2 in 'd:/accessdb/testB.mdb';
结束语:
只要想到,就能做到。
oralce、mysql也有类似功能,有兴趣可以自己找一下。
by lcwlyl 20080723