Linux中国 Linux中国门户站!
设为主页 设为主页
收藏本站 收藏本站
 
当前位置 :首页 ->数据库应用 ->SQL Server ->正文

SQLSERVER中,数据库同步的实现

来源:Linuxdby.com 作者:Webmaster 时间:2007-06-03 点击: [收藏] [投稿]

    [复制] -> 右键选择 [禁用发布] -> [欢迎使用禁用发布和分发向导]
     -> [下一步] -> [禁用发布] -> [要在"@servername"上禁用发布]
     -> [下一步] -> [完成禁用发布和分发向导] -> [完成]
  我们也可以用T-SQL命令来完成复制中发布及订阅的创建和删除, 选中已经设好的发布和订阅, 按属标右键
  可以[生成SQL脚本]。(这里就不详细讲了, 后面推荐的网站内有比较详细的内容)
  当你试图删除或者变更一个table时,出现以下错误
  Server: Msg 3724, Level 16, State 2, Line 1
  Cannot drop the table 'object_name' because it is being used for replication.
比较典型的情况是该table曾经用于复制,但是后来又删除了复制
  处理办法:
   select * from sysobjects where replinfo >'0'
   sp_configure 'allow updates', 1
   go
   reconfigure with override
   go
   begin transaction
   update sysobjects set replinfo = '0' where replinfo >'0'
   commit transaction
   go
   rollback transaction
   go
   sp_configure 'allow updates', 0
   go
   reconfigure with override
   go
Sql server双机数据库同步实验步骤
第一步测试网络连接
?1.实验环境(因人而异)
  服务器:
  机器名称:CHENPENG
  操作系统:Windows XP-sp2
  数据库版本:SQL 2000 Server 企业版
  客户端
  机器名称:PHOENIX
  操作系统:Windows XP-sp2
  数据库版本:SQL 2000 Server企业版
(注:实验中的两机在一个局域网中!)
2.测试网络
2.1 将SQL 2000升级为SP4(sp3以上即可)
2.2 测试步骤:
2.2.1关闭双方防火墙
2.2.2在命令提示符中运行命令netstat -a -n,在结果列表里检查是否有类似 tcp 0.0.0.0 1433 listening 的项。
2.2.3运行命令 telnet 用户名(或IP) 1433 测试对方端口是否畅通
第二步连接客户端
1.建用户帐号
  在服务器端建立域用户帐号(名称为客户端机器名)
  ?? 右击我的电脑->管理->本地用户和组->用户->右击选“新用户”
这里新建的用户名为:PHOENIX(应为客房端机器名) 密码:a(这里要设个密码,若为空可能连不上)
2.重新启动服务器MSSQLServer
  我的电脑->控制面版->管理工具->服务->MSSQLServer 服务->右击,“停止”
  在登录属性页中更改为:域用户帐号PHOENIX
用户 .\ phoenix
密码:a
->再启动服务

3.注册客户端
SQL企业管理器->SQL Server组->右键->新建SQL注册->下一步->可用的服务器中选”PHOENIX”添加->下一步->管理员给我分配的……->下一步->登录名:sa;密码:空->下一步….下一步->完成
4.安装分发服务器
4.1配置分发服务器
工具->复制->配置发布、订阅服务器和分发->下一步 (所有的均采用默认配? 置)……->完成
?
  4.2配置发布服务器
4.2.1工具->复制->创建和管理发布->选择要发布的数据库(pubs)->创建发布  ->下一步(pubs) ->下一步->合并发布->下一步->选择要发布的内容(要发布的表,存储过程等)->下一步(所有的均采用默认配置)……>完成
4.2.2成功后会返回刚才的窗口:选中刚才发布的名称,点”强制新订阅” ->下一步->选”PHOENIX”,下一步->下一步->选"连续地...",下一步->下一步....->完成
至此,全部的操作步骤就完成了!可以在两机之间同步选定的表等。
在SQL Server 2000里设置和使用数据库复制之前,应先检查相关的几台SQL Server服务器下面几点是否满足:
    1、MSSQLserver和Sqlserveragent服务是否是以域用户身份启动并运行的(.\administrator用户也是可以的)
        如果登录用的是本地系统帐户local,将不具备网络功能,会产生以下错误:
        进程未能连接到Distributor '@Server name'
      (如果您的服务器已经用了SQL Server全文检索服务, 请不要修改MSSQLserver和Sqlserveragent服务的local启动。
       会照成全文检索服务不能用。请换另外一台机器来做SQL Server 2000里复制中的分发服务器。)   
      修改服务启动的登录用户,需要重新启动MSSQLserver和Sqlserveragent服务才能生效。   
    2、检查相关的几台SQL Server服务器是否改过名称(需要srvid=0的本地机器上srvname和datasource一样)
       在查询分析器里执行:
         use master
         select srvid,srvname,datasource from sysservers   
        
       如果没有srvid=0或者srvid=0(也就是本机器)但srvname和datasource不一样, 需要按如下方法修改:
        
         USE master
        GO
        -- 设置两个变量
        DECLARE @serverproperty_servername  varchar(100),
                @servername    varchar(100)
        -- 取得Windows NT 服务器和与指定的 SQL Server 实例关联的实例信息

 如果您对本文有任何疑问或者建议,请到讨论区发表您的意见: >> 论坛入口 <<



上一篇:一些SQL Server的应用实例   下一篇:SQL SERVER 和EXCEL的数据导入导出

文章评论】 【收藏本文】 【推荐好友】 【打印本文】 【我要投稿】 【论坛讨论
更多相关文章
Power by linux-cn.com 粤ICP备05006655号