基于Sql Server 2008的分布式数据库的实践(四)
原文 基于Sql Server 2008的分布式数据库的实践(四)
数据库设计
1.E-R图

2.数据库创建
Win 7
|
1
|
create database V3 |
Win 2003
|
1
|
create database V3 |
3.数据表设计
Win7 创建数据表student_7
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
create table student_7( sid int not null, sex nvarchar(1) not null, sname varchar(20) not null, school varchar(20) not null, scount varchar(20) not null, spwd varchar(20) not null, constraint pk_student_7 primary key(sid,sex), constraint uq_student_7_scount unique(scount), constraint chk_student_7_sex check(sex='1') ) |
Check(sex=1)指明存放sex=1的数据,即女生。
Win2003 创建数据表student_2003
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
create table student_2003( sid int not null, sex nvarchar(1) not null, sname varchar(20) not null, school varchar(20) not null, scount varchar(20) not null, spwd varchar(20) not null, constraint pk_student_2003 primary key(sid,sex), constraint uq_student_2003_scount unique(scount), constraint chk_student_2003_sex check(sex='0') ) |
Check(sex=0)指明存放sex=0的数据,即男生。
Win7 创建视图V3_student
|
1
2
3
4
5
|
create view V3_student asselect * from student_7 union allselect * from [192.168.116.130].[V3].[dbo].[student_2003] |
Win2003 创建视图V3_student
|
1
2
3
4
5
|
create view V3_student asselect * from student_2003 union allselect * from [192.168.233.1].[V3].[dbo].[student_7] |
student水平分片数据表已经建立,现在可以在任何位置,只要访问本地V3_student分布式分区视图,就实现了所有分布式数据库的操作。此时,对数据库的全局操作和局部操作就如同操作本地集中式数据库一样。
-----------------------------------------------------------------------------------------------------------------
Win7创建数据表teacher
|
1
2
3
4
5
6
7
8
9
10
11
12
|
create table teacher( tid int not null, tname varchar(20) not null,tage int not null,tsex int not null, tcount varchar(20) not null, tpwd varchar(20) not null,tsuper int not null, primary key(tid), unique(tcount)) |
Win2003创建数据表teacher
|
1
2
3
4
5
6
7
8
|
create table teacher( tid int not null,nowage int not null,tel char(20) not null,address varchar(80) not null, primary key(tid)) |
Win7 创建存储过程V3_teacher
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
create proc V3_teacher(@tid int,@tname varchar(20),@tage int,@tsex int,@tcount varchar(20),@tpwd varchar(20),@super int,@nowage int ,@tel char(20) ,@address varchar(80)) asset XACT_ABORT onBEGIN DISTRIBUTED TRANSACTIONinsert into teacher values(@tid,@tname,@tage,@tsex,@tcount,@tpwd,@super); insert into [192.168.116.130].[V3].[dbo].[teacher] values(@tid,@nowage,@tel,@address); COMMIT TRANSACTION |
采用存储过程实现垂直分片。此时插入数据之后,将分别插入到不同地址上的SQL Server的teacher的数据表里面。
-----------------------------------------------------------------------------------------------------------------
Win7创建数据表class
|
1
2
3
4
5
6
7
8
9
|
create table class( cid int not null, sid int not null,tid int not null,cname varchar(20) not null, score int not null, primary key(cid,sid)) |
本地数据表。
-----------------------------------------------------------------------------------------------------------------
Win 7:

Win2003:

4.程序代码测试
水平分片测试



垂直分片测试




转载请注明出处:http://www.cnblogs.com/yydcdut/p/3459836.html
基于Sql Server 2008的分布式数据库的实践(四)的更多相关文章
- 基于Sql Server 2008的分布式数据库的实践(五)
原文 基于Sql Server 2008的分布式数据库的实践(五) 程序设计 ------------------------------------------------------------- ...
- 基于Sql Server 2008的分布式数据库的实践(三)
原文 基于Sql Server 2008的分布式数据库的实践(三) 配置PHP 1.打开PHP配置文件,找到extension=php_mssql.dll,将前面的注释符号去掉 2.找到mssql.s ...
- 基于Sql Server 2008的分布式数据库的实践(二)
原文 基于Sql Server 2008的分布式数据库的实践(二) 从Win7连接Win2003的Sql Server 2008 1.新建链接服务器链接到Win2003的Sql Server 2008 ...
- 基于Sql Server 2008的分布式数据库的实践(一)
原文 基于Sql Server 2008的分布式数据库的实践(一) 配置Sql Server 2008(Win7) 1.打开SQL server2012,使用windows身份登录 2.登录后,右键选 ...
- 基于Sql Server 2008的分布式数据库的实践(终结)
学习.操作心得 以前在做网站程序的时候一直用的是MYSQL,但是网上搜到MYSQL不支持分布式操作,然后便开始查询MSSQL的分布式数据库的设计与操作,后来在网上找到了<基于SQL SERVER ...
- 基于Sql Server 2008的分布式数据库的实践
配置Sql Server 2008(Win7) 1.打开SQL server2012,使用windows身份登录 2.登录后,右键选择“属性”.左侧选择“安全性”,选中右侧的“SQL Server 和 ...
- 基于SQL Server 2008 Service Broker构建企业级消息系统
注:这篇文章是为InfoQ 中文站而写,文章的地址是:http://www.infoq.com/cn/articles/enterprisemessage-sqlserver-servicebroke ...
- SQL SERVER 2008 R2 还原数据库3154错误
1.SQL SERVER 2008 在还原数据库时,会报错. 提示错误:"备份集中的数据库备份与现有的 '***' 数据库不同.RESTORE DATABASE 正在异常终止. (Micro ...
- SQL Server 2008 R2 主从数据库同步
一.准备工作: 主数据库服务器: OS:Windows Server 2008 R2 DB: SQL Server 2008 R2 Hostname : CXMasterDB IP: 192.1 ...
随机推荐
- ssh无密登录
ssh登录一般两种方式: 1.密码登录 2.密钥验证无需密码 使用方式:1.生成密钥 2.将公钥追加到authorized_keys中,需要注意的是执行权限需为600,这里因而第一次添加使用的是> ...
- Wmic-linux
Description Windows Management Instrumentation Command-line (WMIC) uses Windows Management Instrumen ...
- 再探java基础——break和continue的用法
再探java基础——break和continue的用法 break break可用于循环和switch...case...语句中. 用于switch...case中: 执行完满足case条件的内容内后 ...
- HDU 1267 下沙的沙子有几粒?
题解:利用卡特兰数的几何意义,题目就可以转化为一个棋盘格,可以向下走或是向右走,但是不可以逾越对角线,就可以了. #include <cstdio> #include <iostre ...
- PhoneGap 3.0 安装
PhoneGap 3.0 已经出来有一段时间了.3.0 提供了使用Node.js 安装,使用命令行创建.编译.运行项目.也就是可以抛弃eclipse,完全使用命令.记事本开发phonegap 项目了 ...
- MongoDB初探系列之二:认识MongoDB提供的一些经常使用工具
在初探一中,我们已经能够顺利的将MongoDB在我们自己的机器上跑起来了. 可是在其bin文件夹以下另一些我们不熟知的工具.接下来,将介绍一下各个小工具的用途以及初探一中MongoDB在data文件夹 ...
- Android JNI入门第二篇——Java参数类型与本地参数类型对照
前面一篇通过简单的例子介绍了android中JNI的使用.这一篇从基础上了解一些Java参数类型与本地参数类型区别. 1) java中的返回值void和JNI中的void是完全对应的哦! ...
- objective-C学习笔记(二)类 class 和 结构 struct
Objective-C的类型 引用类型 类 class 指针 pointer 块 block 值类型 基础数值类型 结构 struct 枚举 enum 类型装饰 协议 protocol 类别 cate ...
- C3P0连接池参数解释
<!--acquireIncrement:链接用完了自动增量3个. --> <property name="acquireIncrement">3</ ...
- Jetty 8.1 安装 运行 部署
链接地址:http://blog.csdn.net/lego2816/article/details/42650545 Java + MySQL 从Jfinal开始,第一步先走完整个流程,主要是发布部 ...