`
songtianbao
  • 浏览: 28396 次
  • 性别: Icon_minigender_1
  • 来自: 南京
文章分类
社区版块
存档分类
最新评论

sql server 中跨数据库操作

阅读更多

首先以dba用户执行以下两句脚本,(注意只有dba用户有权限执行以下脚本)
execsp_addlinkedserver你的数据库连接名字,'','SQLOLEDB',你的数据库url及端口

execsp_addlinkedsrvlogin你的数据库连接名字,'false',null,数据库用户名,数据库用户密码

来创建一个数据库连接对象,用来连接另一个数据库,然后在执行跨数据库操作时只需要在你要操作的表前加上你的数据库连接名字.dbo.表明

例如:我有个库叫billing,有多个库叫subscription1,subscription2,subscription3.........,billing库中有个表叫SuspendRecord,subscrption库中有个表叫ActivePlan
然后我要将subscription1库中ActivePlan的phoneNumber收集到billing库的SuspendRecord表中,可以执行如下语句:
insertintoSuspendRecordphoneNumber
selectphoneNumberfrom你的数据库连接名字.subscription1的库名.dbo.ActivePlan

注:创建数据库连接的语句只能被执行一次,如果数据库中存在聪明的连接对象,则再次创建同名的连接对象数据库就会报错,所以创建前需要检查是否存在同名的连接对象,方法如下
selectnamefromsys.serverswherename=数据库连接名称

建议:数据库连接名称生成规则:数据库连接地址+数据库名称+用户名+密码的hashCode作为连接名称,这样用户修改数据库用户名、密码等信息将不会对程序造成影响

yutian0761 原创

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics