配置SQL SERVER 2005 分布式水平分片
2009-10-08 00:00:00 来源:WEB开发网首先要做的是安装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:
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(30) NOT NULL,
32 SaleDate DATETIME,
33 SalePrice MONEY,
34 Region VARCHAR(5) NOT 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 SELECT, INSERT, UPDATE, DELETE, VIEW 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
- ››SQL Server 2008 R2 下如何清理数据库日志文件
- ››sqlite 存取中文的解决方法
- ››SQL2005、2008、2000 清空删除日志
- ››SQL Server 2005和SQL Server 2000数据的相互导入...
- ››sql server 2008 在安装了活动目录以后无法启动服...
- ››sqlserver 每30分自动生成一次
- ››sqlite 数据库 对 BOOL型 数据的插入处理正确用法...
- ››sql server自动生成批量执行SQL脚本的批处理
- ››sql server 2008亿万数据性能优化
- ››SQL Server 2008清空数据库日志方法
- ››sqlserver安装和简单的使用
- ››SQL Sever 2008 R2 数据库管理
更多精彩
赞助商链接