深入SqlServer2008 数据库同步的两种方式(Sql JOB)的分析介绍

1、SQL JOB的方式

sp_addlinkedsrvlogin [ @rmtsrvname = ] 'rmtsrvname'
[ ,[ @useself = ] 'useself' ]
[,[ @locallogin = ] 'locallogin' ]

[ ,[ @rmtuser = ] 'rmtuser' ]
[ ,[ @rmtpassword = ] 'rmtpassword' ]

@rmtsrvname =] 'rmtsrvname'

rmtsrvname 的数据类型为 sysname,没有默认设置。

@useself =] 'useself'

useself 的数据类型为 varchar(8),默认设置为 TRUE。true 值指定 SQL Server 验证的登录使用其自己的凭据以连接到 rmtsrvname,而忽略 rmtuserrmtpassword 参数。false 值指定 rmtuserrmtpassword 参数用来连接到特定 localloginrmtsrvname。如果 rmtuserrmtpassword 也设置为 NULL,则连接链接服务器不需使用任何登录或密码。对于 Windows NT 身份验证登录而言,useself true 则无效,除非 Microsoft Windows NT® 环境支持安全帐户委托,并且,提供程序支持 Windows 身份验证(此时不再需要创建值为 true 的映射,不过创建仍然有效)。

@locallogin =] 'locallogin'

locallogin 的数据类型为 sysname,默认设置为 NULL。NULL 值指定此条目将应用于所有连接到 rmtsrvname 的本地登录。如果值不为 NULL,则 locallogin 可以是一个 SQL Server 登录或 Windows NT 用户。必须授予 Windows NT 用户直接访问 SQL Server 或通过其作为已授予访问权限的组的成员来访问 SQL Server 的权限。

@rmtuser =] 'rmtuser'

useself 为 false 时,用来连接 rmtsrvname 的用户名,rmtuser 的数据类型为 sysname,默认设置为 NULL。

@rmtpassword =] 'rmtpassword'

rmtuser 相关的密码。rmtpassword 的数据类型为 sysname,默认设置为 NULL。

sp_addlinkedsrvlogin 来指定本地服务器登录链接服务器的登录凭据。

sp_addlinkedserver 自动创建。默认映射说明连接到链接服务器代表的登录时,SQL Server 使用本地登录的用户凭据(等同于将链接服务器的 @useself 设置为 true 时执行 sp_addlinkedsrvlogin)。使用 sp_addlinkedsrvlogin 只可以更改特定的本地服务器的默认映射或添加新映射。若要删除默认映射或任何其它映射,请使用 sp_droplinkedsrvlogin

sp_addlinkedsrvlogin 创建一个预设的登录映射。

sp_dropserver [ @server = ] 'server'
, [ @droplogins = ] { 'droplogins' | NULL} ]

@server =] 'server'

server 的数据类型为 sysname,没有默认值。server 必须已经存在。

@droplogins =] 'droplogins' | NULL

droplogins,那么对于 server,那些相关的远程及链接服务器登录也将被删除。@droplogins 的数据类型为 char(10),带有默认值 NULL。

sp_dropserver 时,会导致一条错误信息,该消息说明:在删除远程或链接服务器之前,必须先删除相关的登录。当删除服务器时,为了删除服务器的所有远程及链接服务器登录,请使用 droplogins 参数。

sp_dropserver。

sysadmin 或 setupadmin 固定服务器角色的成员才可以执行 sp_dropserver

sp_addlinkedserver 创建链接的服务器之后,此服务器就可以执行分布式查询。如果链接服务器定义为 Microsoft® SQL Server™,则可执行远程存储过程。

sp_addlinkedserver [ @server = ] 'server'
[ ,[ @srvproduct = ] 'product_name' ]

[ ,[ @provider = ] 'provider_name' ]
[ ,[ @datasrc = ] 'data_source' ]
[ ,[ @location = ] 'location' ]
[ ,[ @provstr = ] 'provider_string' ]
[ ,[ @catalog = ] 'catalog' ]

@server = ] 'server'

server 的数据类型为 sysname,没有默认设置。

server 可以为 servername\instancename。此链接的服务器可能会被引用为下面示例的数据源:

SELECT *FROM [servername\instancename.]pubs.dbo.authors. 

data_source,则服务器为该实例的实际名称。

@srvproduct = ] 'product_name'

product_name 的数据类型为 nvarchar(128),默认设置为 NULL。如果是 SQL Server,则不需要指定 provider_namedata_sourcelocationprovider_string 以及目录。

@provider = ] 'provider_name'

provider_name 对于安装在当前计算机上指定的 OLE DB 提供程序必须是唯一的。provider_name 的数据类型为nvarchar(128),默认设置为 NULL。OLE DB 提供程序应该用给定的 PROGID 在注册表中注册。

@datasrc = ] 'data_source'

data_source 的数据类型为 nvarchar(4000),默认设置为 NULL。data_source 被当作 DBPROP_INIT_DATASOURCE 属性传递以便初始化 OLE DB 提供程序。

servername\instancename 的形式指定 data_source,它可以用来连接到运行于特定计算机上的 SQL Server 的特定实例上。servername 是运行 SQL Server 的计算机名称,instancename 是用户将被连接到的特定 SQL Server 实例的名称。

@location = ] 'location'

location 的数据类型为 nvarchar(4000),默认设置为 NULL。location 作为 DBPROP_INIT_LOCATION 属性传递以便初始化 OLE DB 提供程序。

@provstr = ] 'provider_string'

provider_string 的数据类型为 nvarchar(4000),默认设置为 NULL。Provstr 作为 DBPROP_INIT_PROVIDERSTRING 属性传递以便初始化 OLE DB 提供程序。

servername\instancename 来指定实例,以指定特定的 SQL Server 实例。servername 是 SQL Server 在其上运行的计算机名称,instancename 是用户连接到的特定的 SQL Server 实例名称。

@catalog = ] 'catalog'

catalog 的数据类型为sysname,默认设置为 NULL。catalog 作为 DBPROP_INIT_CATALOG 属性传递以便初始化 OLE DB 提供程序。

sp_addlinkedserver 返回此消息:

Procedure 'sp_addlinkedserver' expects parameter '@server',which was not supplied.

sp_addlinkedserver 返回此消息:

Server added.
用法示例:
EXEC sp_addlinkedserver 'DBLink',' ','SQLOLEDB',"10.0.222.12"


sp_addlinkedsrvlogin [ @rmtsrvname = ] 'rmtsrvname'
[ ,[ @useself = ] 'useself' ]
[,[ @locallogin = ] 'locallogin' ]

[ ,[ @rmtuser = ] 'rmtuser' ]
[ ,[ @rmtpassword = ] 'rmtpassword' ]

@rmtsrvname =] 'rmtsrvname'

rmtsrvname 的数据类型为 sysname,没有默认设置。

@useself =] 'useself'

useself 的数据类型为 varchar(8),默认设置为 TRUE。true 值指定 SQL Server 验证的登录使用其自己的凭据以连接到

rmtsrvname,而忽略 rmtuserrmtpassword 参数。false 值指定 rmtuserrmtpassword 参数用来连接到特定 localloginrmtsrvname

rmtuser 和 rmtpassword 也设置为 NULL,则连接链接服务器不需使用任何登录或密码。对于 Windows NT 身份验证登录而言,useself true 则无效,

true 的映射,不过创建仍然有效)。

@locallogin =] 'locallogin'

locallogin 的数据类型为 sysname,默认设置为 NULL。NULL 值指定此条目将应用于所有连接到 rmtsrvname 的本地登录。如果值不为 NULL,

locallogin 可以是一个 SQL Server 登录或 Windows NT 用户。必须授予 Windows NT 用户直接访问 SQL Server 或通过其作为已授予访问权限的组的成员来访问

@rmtuser =] 'rmtuser'

useself 为 false 时,用来连接 rmtsrvname 的用户名,rmtuser 的数据类型为 sysname,默认设置为 NULL。

@rmtpassword =] 'rmtpassword'

rmtuser 相关的密码。rmtpassword 的数据类型为 sysname,默认设置为 NULL。

sp_addlinkedsrvlogin 来指定本地服

sp_addlinkedserver 自动创建。默认映射说明连接到链接服务器代表的登录时,SQL Server

@useself 设置为 true 时执行 sp_addlinkedsrvlogin)。使用 sp_addlinkedsrvlogin 只可以更改特定的本地服务器

sp_droplinkedsrvlogin。

sp_addlinkedsrvlogin 创建一个预设的登录映射。





sp_addlinkedsrvlogin 定义)的链接服务器执行身份验证后,远程数据库中单独对象的权限由链接服务器决定,

sp_addlinkedsrvlogin。

sysadmin 和 securityadmin 固定服务器角色的成员才可以执行 sp_addlinkedsrvlogin



,下面正式介绍SQL JOB的开发。直接用步骤介绍了。
a)新建作业。如下图:

a、 新建作业。如下图:

b、 点击【新建作业】对话框的【常规】选项卡,填写 SQL JOB的名称。如下图

c、 点击【新建作业】对话框的【步骤】选项卡,填写 步骤名称。




d、 进行作业的第一个步骤------建立数据库连接操作。如下图:


e、 进行作业的第下一个步骤。如下图:

e、设置作业执行计划

f、点击确定,完成SQL JOB的开发。

g、完成后作业下面就多了刚开发的作业。如下:


h、作业制作完成后,可以立即让它执行。如果不让它执行,它也会在按照制定频率执行。测试作业:





相关文章

本篇内容主要讲解“sqlalchemy的常用数据类型怎么使用”,感...
今天小编给大家分享一下sqlServer实现分页查询的方式有哪些的...
这篇文章主要介绍“sqlmap之osshell怎么使用”,在日常操作中...
本篇内容介绍了“SQL注入的知识点有哪些”的有关知识,在实际...
1. mssql权限sa权限:数据库操作,文件管理,命令执行,注册...
sql执行计划如何查看?在SPL庞大的数据中我们不知道如何查看...