如何在SQL SERVER跨服务器查询数据库

如何在SQL SERVER跨服务器查询数据库,第1张

--创建链接服务器

exec sp_addlinkedserver 'ITSV ', ' ', 'SQLOLEDB ', '远程服务器名或ip地址 '

exec sp_addlinkedsrvlogin 'ITSV ', 'false ',null, '用户名 ', '密码 '

--查询示例

select from ITSV数据库名dbo表名

--导入示例

select into 表 from ITSV数据库名dbo表名

--以后不再使用时删除链接服务器

exec sp_dropserver 'ITSV ', 'droplogins '

--连接远程/局域网数据(openrowset/openquery/opendatasource)

--1、openrowset

--查询示例

select from openrowset( 'SQLOLEDB ', 'sql服务器名 '; '用户名 '; '密码 ',数据库名dbo表名)

--生成本地表

select into 表 from openrowset( 'SQLOLEDB ', 'sql服务器名 '; '用户名 '; '密码 ',数据库名dbo表名)

--把本地表导入远程表

insert openrowset( 'SQLOLEDB ', 'sql服务器名 '; '用户名 '; '密码 ',数据库名dbo表名)

select from 本地表

--更新本地表

update b

set b列A=a列A

from openrowset( 'SQLOLEDB ', 'sql服务器名 '; '用户名 '; '密码 ',数据库名dbo表名)as a inner join 本地表 b

on acolumn1=bcolumn1

--openquery用法需要创建一个连接

--首先创建一个连接创建链接服务器

exec sp_addlinkedserver 'ITSV ', ' ', 'SQLOLEDB ', '远程服务器名或ip地址 '

--查询

select

FROM openquery(ITSV, 'SELECT FROM 数据库dbo表名 ')

--把本地表导入远程表

insert openquery(ITSV, 'SELECT FROM 数据库dbo表名 ')

select from 本地表

--更新本地表

update b

set b列B=a列B

FROM openquery(ITSV, 'SELECT FROM 数据库dbo表名 ') as a

inner join 本地表 b on a列A=b列A

--3、opendatasource/openrowset

SELECT

FROM opendatasource( 'SQLOLEDB ', 'Data Source=ip/ServerName;User ID=登陆名;Password=密码 ' )testdboroy_ta

--把本地表导入远程表

insert opendatasource( 'SQLOLEDB ', 'Data Source=ip/ServerName;User ID=登陆名;Password=密码 ')数据库dbo表名

select from 本地表

用事物实现,具体比较麻烦。你可以用临时表来实现,首先从A数据库中查到数据放到某一个临时表1中,再从B数据库中查到数据放到某一个临时表2中,然后再进行第二次查询。中间注意事物的回滚,否则如果某个数据库连接错误就会导致数据不对。

如果你不明白什么是数据库的事务,你就去查一下,不是很难得。

SQL如何将一个数据库中查到的结果加入到另一个数据库?

语句形式为:insert into 资料库名框架名表名(列名) select (列名) from 资料库名框架名表名 where 条件。

类似这样写就行了:

insert into MyEmpdbotjdjb(yybh)

select yybh

from MyCmddbotjdjb where djrq='2009-10-15' and yybh = '11'

select a,c INTO Table2 from Table1。

SQL全称是“结构化查询语言(Structured Query Language)”,最早的是IBM的圣约瑟研究实验室为其关系资料库管理系统SYSTEM R开发的一种查询语言,它的前身是SQUARE语言。SQL语言结构简洁,功能强大,简单易学,所以自从IBM公司1981年推出以来,SQL语言,得到了广泛的应用。如今无论是像Oracle ,Sybase,Informix,SQL server这些大型的资料库管理系统,还是像Visual Foxporo,PowerBuilder这些微机上常用的资料库开发系统,都支援SQL语言作为查询语言。

如何将 一个数据库同步到另一个数据库

1直接方法,将需要的查询的资料赋值到excel中。相应调整,然后再赋值到目标表中(对于资料量不大的情况下较快)

2最好两资料库拥有相同的登入名和密码不然比较麻烦

insert into 目标资料库dbo目标表名(栏位1栏位n)

select 段1栏位n from 源资料库dbo源表名 或 select 段1栏位n into 目标资料库dbo目标表名 from 源资料库dbo源表名

3这样的插入注意表字段的长度和约束条件,若原表中栏位长,就得将目标表中的栏位相应加长

如何将一个sql档案汇入到mysql资料库中的一个数据库里

D:\> mysql -uroot -ppassword

Wele to the MySQL monitor Commands end with ; or \g

Your MySQL connection id is 18508

Server version: 5122-rc Source distribution

Type 'help;' or '\h' for help Type '\c' to clear the buffer

mysql> use db

Database changed

mysql> source D:\filesql

怎样将一个数据库中的储存过程复制到另一个数据库中

如果你是想把储存过程这些程式搬到另外一个数据库的话,那就直接把这些储存过程另存为SQL文字,然后在另外一个数据库重新建立就是了。

如果你的意思是保持两个资料库资料的同步和一致,就可以考虑配置两个资料库之间的资料同步的一些方案,例如资料库复制、资料库资料档案的磁碟映象等等技术方案,如果对高可用性HA要求非常高的系统,也可以考虑使用商业资料库系统的丛集Cluster方案。

SQL中如何将一个数据库中的所有的表结构复制到另一个数据库中? 用资料库指令码实现,请问指令码怎么写?

insert 表

select from OPENDATASOURCE( 'SQLOLEDB', 'Data Source=ServerName;User ID=MyUID;Password=MyPass' )资料库dbo表

可以将一个数据库表新增到另一个数据库中吗?为什么?

结构一样的话

insert into 资料库AdboTableA

select from 资料库BdboTableA

另外:

nsert into DDD(栏位1,栏位2,栏位3 )

(

select 栏位1,栏位2,栏位3 from AAA,BBB,CCC

)

插入的栏位和查询的栏位数量型别一致

由于你的夸库查询插入

所以在表名前加 库名使用者名称

insert into B使用者DDD(栏位1,栏位2,栏位3 )

(

select 栏位1,栏位2,栏位3 from A使用者AAA,A使用者BBB,A使用者CCC

)

如果是sqlserver资料库,可以在查询分析器左边选单看到表使用者名称,

如果你是在A库下 *** 作,可以省去A库表的库名使用者名称,同理B库表也一样

VFP 将一个数据库表移动到另外一个数据库中

OPEN DATABASE dbcFileName1 &&开启原资料库

REMOVE TABLE TableName && 从原资料库中移去表

DATABASES ALL &&关闭原资料库

OPEN DATABASE dbcFileName2 &&开启新资料库

ADD TABLE TableName && 新增表到新资料库

aess将一个数据库汇入到另一个数据库时怎么合并相同的表

不考虑资料合并时

select A栏位1,A栏位2from A into B

A是来源表,B是目标表。

同一个检视结构插入到另一个数据库中查询相应资料 sql

如果在同一个伺服器中的不同资料库,可以跨资料库建检视。

比如有两个资料库A 和B B资料库中有个表TA

那么可以在A资料库中建个检视,取自B资料库中表TA中的资料

use A

go

creat view B_TA as

select from BTA

go

这样就在A资料库中建一个检视B_TA 资料取自B资料库中TA表

C#怎样实现从资料库中把资料传到另一个数据库中

比较复杂啊

在按钮里先载入另一个数据库然后UPdate,繁琐了!

oracle 10g的DBMS_XPLAN包中display_cursor函数不同于display函数,display_cursor用于显示SQL语句的真实的执行计划,在大多数情况下,

显示真实的执行计划有助于更好的分析SQL语句的全过程,尤其是运行此SQL语句实时的I/O开销。通过对比预估的I/O与真实的I/O开销来判断

SQL语句所存在问题,如缺少统计信息,SQL语句执行的次数,根据实际中间结果集的大小来选择合适的连接方式等。本文仅仅讲述

display_cursor函数的使用。

一、display_cursor函数用法

1、display_cursor函数语法

DBMS_XPLANDISPLAY_CURSOR(

sql_id IN VARCHAR2 DEFAULT NULL,

cursor_child_no IN NUMBER DEFAULT NULL,

format IN VARCHAR2 DEFAULT 'TYPICAL');

2、display_cursor函数参数描述

sql_id

指定位于库缓存执行计划中SQL语句的父游标。默认值为null。当使用默认值时当前会话的最后一条SQL语句的执行计划将被返回

可以通过查询V$SQL 或V$SQLAREA的SQL_ID列来获得SQL语句的SQL_ID。

cursor_child_no

指定父游标下子游标的序号。即指定被返回执行计划的SQL语句的子游标。默认值为0。如果为null,则sql_id所指父游标下所有子游标

的执行计划都将被返回。

format

控制SQL语句执行计划的输出部分,即哪些可以显示哪些不显示。使用与display函数的format参数与修饰符在这里同样适用。

除此之外当在开启statistics_level=all时或使用gather_plan_statistics提示可以获得执行计划中实时的统计信息

有关详细的format格式描述请参考:dbms_xplan之display函数的使用 中format参数的描述

下面给出启用统计信息时format新增的修饰符

iostats 控制I/O统计的显示

last 默认,显示所有执行计算过的统计。如果指定该值,则只显示最后一次执行的统计信息

memstats 控制pga相关统计的显示

allstats 此为iostats memstats的快捷方式,即allstats包含了iostats和memstats

run_stats_last 等同于iostats last。只能用于oracle 10g R1

run_stats_tot 等同于iostats。只能用于oracle 10g R1

抓一个最近一小时最消耗IO的SQL:

SELECT sql_id, COUNT()

FROM gv$active_session_history ash, gv$event_name evt

WHERE ashsample_time > SYSDATE - 1 / 24

AND ashsession_state = 'WAITING'

AND ashevent_id = evtevent_id

AND evtwait_class = 'User I/O'

GROUP BY sql_id

ORDER BY COUNT() DESC;

执行上面的SQL:

SQL> SELECT sql_id, COUNT()

FROM gv$active_session_history ash, gv$event_name evt

2 3 WHERE ashsample_time > SYSDATE - 1 / 24

4 AND ashsession_state = 'WAITING'

5 AND ashevent_id = evtevent_id

6 AND evtwait_class = 'User I/O'

7 GROUP BY sql_id

8 ORDER BY COUNT() DESC;

SQL_ID COUNT()

------------- ----------

g7fu6qba82m6b 668

63r47zyphdk06 526

9f5m4wd88nc1h 514

593p47drw5fhk 232

br91w16jzy4fu 120

4fvwyjpnh6tp7 78

gm0nrbfuj8kzr 70

2184k363hw4xd 68

gc4dajs7g5myy 46

8vrk9sfuwfdgq 42

ccpnb4dwdmq21 40

查看SQL的执行计划:

SELECT FROM TABLE(dbms_xplandisplay_cursor('g7fu6qba82m6b'));

在SQLPLUS中执行:

SQL> set pagesize 2000

SQL> SELECT FROM TABLE(dbms_xplandisplay_cursor('g7fu6qba82m6b'));

PLAN_TABLE_OUTPUT

------------------------------------------------------------------------------------------------------------------------

SQL_ID g7fu6qba82m6b, child number 0

-------------------------------------

UPDATE "CPDDS_PDATA""CDM_LEDGER" SET "CSTM_NAME" = :a1,"CSTM_NO" =

:a2,"PAPER_TYPE" = :a3,"PAPER_NO" = :a4,"CURR_TYPE" = :a5,"SVT_NO" =

:a6,"BAL_DIR" = :a7,"BAL" = :a8,"AVAL_BAL" = :a9,"NORM_FRATIO" =

:a10,"PK_BAL" = :a11,"DR_ACCU" = :a12,"CR_ACCU" = :a13,"LAST_TRAN_DATE" =

:a14,"LAST_TRAN_TIME" = :a15,"PRT_LINE_NUM" = :a16,"NOREG_PK_REC_NUM" =

:a17,"PK_NO" = :a18,"PWD" = :a19,"FLAG" = :a20,"FRZ_FLAG" =

:a21,"CARD_HOLD_FLAG" = :a22,"PK_HOLD_FLAG" = :a23,"BGN_INT_DATE" =

:a24,"OPEN_DATE" = :a25,"ACC_HOLD_FLAG" = :a26,"CLS_DATE" =

:a27,"OPEN_TLR" = :a28,"CLS_TLR" = :a29,"CLS_INT" = :a30,"OPEN_INST" =

:a31,"ADD_NUM" = :a32,"DAC" = :a33,"FRZ_TIMES1" = :a34,"FRZ_TIMES2" =

:a35,"HOST_SEQNO" = :a36,"D_UPDATE_DATE" = :a37 WHERE "ACC" = :b0

Plan hash value: 319441092

-----------------------------------------------------------------------------------

| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |

-----------------------------------------------------------------------------------

| 0 | UPDATE STATEMENT | | | | 3 (100)| |

| 1 | UPDATE | CDM_LEDGER | | | | |

| 2 | INDEX UNIQUE SCAN| I_CDM_LEDGER | 1 | 269 | 2 (0)| 00:00:01 |

-----------------------------------------------------------------------------------

Predicate Information (identified by operation id):

---------------------------------------------------

2 - access("ACC"=:B0)

29 rows selected

总结

1、与display函数不同,display_cursor显示的为真实的执行计划

2、对于format参数,使用与display函数的各个值,同样适用于display_cursor函数

3、当statistics_level为all或使用gather_plan_statistics提示可以获得执行时的统计信息

4、根据真实与预估的统计信息可以初步判断SQL效率低下的原因,如统计信息的准确性、主要的开销位于那些步骤等

以上就是关于如何在SQL SERVER跨服务器查询数据库全部的内容,包括:如何在SQL SERVER跨服务器查询数据库、sql数据库跨服务器查询,不同表,不同数据量的并列显示、SQL如何将一个数据库中查到的结果加入到另一个数据库等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/10197411.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-06
下一篇 2023-05-06

发表评论

登录后才能评论

评论列表(0条)

保存