配置SQL SERVER 2005 分布式水平分片

首先要做的是安装sql server 2005 开发版或专业版,可以用两台机器,也可以在一台机器上装两个sql server instance(实例),我这里是采用的两台机器进行的,机器名分别为RENHU和CHINA-E931FACA9,在RENHU上装了sql server instance A,在CHINA-E931FACA9上装了B。安装的时候注意开启sql server和windows混合验证。

确保两台机器,通过机器名能够ping 通(在CHINA-E931FACA9上能ping通RENHU,在RENHU上能ping通CHINA-E931FACA9),否则修改host文件,确保两台机器能够ping通。

运行sql server Configureation Manager,使TCP/IP enable,如下图:

两台机器都要能要做,然后重启Sql server、Sql server Browser服务(这两个服务一定要起来),然后关闭防火墙,或设置防火墙例外。

然后试着用一台机器去连另外一台机器的sql server(用sql server manage studio),例如我这里用RENHU这台机器连CHINA-E931FACA9\B,如果能连成功,则说明一切ok,如图:


配置ok,就要进行分布式配置了,代码如下:
Server RENHU:
ContractedBlock.gif ExpandedBlockStart.gif Code
 1-- 建立数据库,设置数据的选项
 2CREATE DATABASE SalesDB;
 3EXECUTE sp_serveroption @server='RENHU\A',@optname='lazy schema validation',@optvalue='true'
 4CREATE LOGIN xqls WITH Password = 'wisdom317'
 5
 6GO
 7
 8-- 建立用户
 9USE SalesDB
10CREATE USER xqls FROM LOGIN xqls
11
12GO
13
14-- 连接到B
15EXECUTE sp_addlinkedserver 'CHINA-E931FACA9\B''SQL Server'
16EXEC sp_addlinkedsrvlogin 'CHINA-E931FACA9\B','false',NULL,'xqls','wisdom317'
17
18GO
19
20-- 创建表结构
21IF OBJECT_ID('SalesHistory','U'> 0      
22
23DROP TABLE SalesHistory
24
25GO
26
27CREATE TABLE SalesHistory
28
29(            
30      SaleID INT PRIMARY KEY,            
31      Product VARCHAR(30NOT NULL,             
32      SaleDate DATETIME,             
33      SalePrice MONEY
34      Region VARCHAR(5NOT NULL
35      CONSTRAINT chk_Region CHECK (SaleID <20000)
36
37)
38
39GO
40
41-- 添加测试数据
42DECLARE @i SMALLINT@Region VARCHAR(5)
43
44SET @i = 1
45
46SET @Region = 'West'
47
48
49
50WHILE (@i <=6000)
51
52BEGIN            
53      INSERT INTO SalesHistory         
54      (SaleID, Product, SaleDate, SalePrice, Region)            
55      VALUES      
56
57(@i'Computer'DATEADD(mm, @i'3/11/1919'), DATEPART(ms, GETDATE()) + (@i + 57), @Region )
58      SET @i = @i + 1
59      INSERT INTO SalesHistory            
60      (SaleID, Product, SaleDate, SalePrice, Region)
61      VALUES      
62       (@i'BigScreen'DATEADD(mm, @i'3/11/1927'), DATEPART(ms, GETDATE()) + (@i + 13), @Region)            
63      SET @i = @i + 1
64      INSERT INTO SalesHistory            
65      (SaleID, Product, SaleDate, SalePrice, Region)    
66      VALUES      
67      (@i'PoolTable'DATEADD(mm, @i'3/11/1908'), DATEPART(ms, GETDATE()) + (@i + 29), @Region )            
68      SET @i = @i + 1
69
70END
71
72GO
73
74-- 分配权限
75GRANT SELECTINSERTUPDATEDELETEVIEW DEFINITION ON SalesHistory TO xqls 
76
77GO
78
79-- 建立视图
80CREATE VIEW dpv_SalesHistory
81
82AS
83      SELECT 
84            SaleID, Product, Region, SaleDate, SalePrice
85      FROM SalesDB.dbo.SalesHistory
86      UNION ALL
87      SELECT 
88            SaleID, Product, Region, SaleDate, SalePrice
89      FROM [CHINA-E931FACA9\B].SalesDB.dbo.SalesHistory
90
91GO
92
93-- 测试视图
94select * from dpv_SalesHistory

Server CHINA-E931FACA9:

ContractedBlock.gif ExpandedBlockStart.gif Code
 1CREATE DATABASE SalesDB;
 2EXECUTE sp_serveroption @server='CHINA-E931FACA9\B',@optname='lazy schema validation',@optvalue='true'
 3CREATE LOGIN xqls WITH Password = 'wisdom317'
 4
 5GO
 6
 7USE SalesDB
 8CREATE USER xqls FROM LOGIN xqls
 9
10GO
11
12-- 连接到A
13EXECUTE sp_addlinkedserver 'RENHU\A''SQL Server'
14EXEC sp_addlinkedsrvlogin 'RENHU\A','false',NULL,'xqls','wisdom317'
15
16GO
17
18--  创建表结构
19IF OBJECT_ID('SalesHistory','U'> 0      
20
21DROP TABLE SalesHistory
22
23GO
24
25CREATE TABLE SalesHistory
26
27(            
28      SaleID INT PRIMARY KEY,            
29      Product VARCHAR(30NOT NULL,             
30      SaleDate DATETIME,             
31      SalePrice MONEY
32      Region VARCHAR(5NOT NULL
33      CONSTRAINT chk_Region CHECK (SaleID >=20000)
34
35)
36
37GO
38
39
40-- 添加测试数据
41DECLARE @i SMALLINT@Region VARCHAR(5)
42
43SET @i = 20000
44
45SET @Region = 'East'
46
47
48
49WHILE (@i <=26000)
50
51BEGIN            
52      INSERT INTO SalesHistory         
53      (SaleID, Product, SaleDate, SalePrice, Region)            
54      VALUES      
55      (@i'Computer'DATEADD(mm, @i'3/11/1919'), DATEPART(ms, GETDATE()) + (@i + 57), @Region )
56      SET @i = @i + 1
57      INSERT INTO SalesHistory            
58      (SaleID, Product, SaleDate, SalePrice, Region)
59      VALUES      
60      (@i'BigScreen'DATEADD(mm, @i'3/11/1927'), DATEPART(ms, GETDATE()) + (@i + 13), @Region)            
61      SET @i = @i + 1
62      INSERT INTO SalesHistory            
63      (SaleID, Product, SaleDate, SalePrice, Region)    
64      VALUES      
65       (@i'PoolTable'DATEADD(mm, @i'3/11/1908'), DATEPART(ms, GETDATE()) + (@i + 29), @Region )            
66      SET @i = @i + 1
67
68END
69
70-- 分配用户权限
71GRANT SELECTINSERTUPDATEDELETEVIEW DEFINITION ON SalesHistory TO xqls
72
73GO
74
75-- 建立视图
76CREATE VIEW dpv_SalesHistory
77
78AS
79      SELECT 
80            SaleID, Product, Region, SaleDate, SalePrice
81      FROM SalesDB.dbo.SalesHistory
82      UNION ALL
83      SELECT 
84            SaleID, Product, Region, SaleDate, SalePrice
85      FROM [RENHU\A].SalesDB.dbo.SalesHistory
86
87GO
88
89-- 测试视图
90select * from dpv_SalesHistory
具体参考: http://www.builder.com.cn/2007/0406/385486.shtml
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值