基于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 as select * from student_7 union all select * from [192.168.116.130].[V3].[dbo].[student_2003] |
Win2003 创建视图V3_student
1
2
3
4
5
|
create view V3_student as select * from student_2003 union all select * 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) ) as set XACT_ABORT on BEGIN DISTRIBUTED TRANSACTION insert 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 ...
随机推荐
- android application 的使用
参考http://oyeal.iteye.com/blog/941183 由于intent能够传送的对象类型非常有限 因此有些很多类都要用到的变量我们放在Application中 很像web中的s ...
- PROTEL99生成GERBER的操作说明
GBL BOTTOM LAYER(底层布线图)GBO BOTTOM OVERLAYER(底层丝印层)GBP BOTTOM PASTE LAYER(底层锡膏层)GBS BOTTOM SOLDER MAS ...
- JAVA 线程学习 - Thread了解
public class ThreadKnow { private TimeThread timeThread; private boolean flag; public ThreadKnow() { ...
- Libev学习笔记4
这一节首先分析Libev的定时器部分,然后分析signal部分. 对定时器的使用主要有两个函数: ev_timer_init (&timeout_watcher, timeout_cb, .) ...
- java实现冒泡排序,选择排序,插入排序,快速排序(简洁版)及性能测试
1.冒泡排序是排序里面最简单的了,但性能也最差,数量小的时候还可以,数量一多,是非常慢的. 它的时间复杂度是O(n*n),空间复杂度是O(1) 代码如下,很好理解. public void bubbl ...
- CRC32 vs Java.HashCode
找了容量为27万中文词库进行试验 CRC32 中冲突率 < 0.01% 而 Java.HashCode 有 4% hashCode 的速度 应该比 CRC 快 2-3 倍 CR ...
- jQuery 1.9+ ajaxStart事件无效,无法被触发的原因。
AJAX 事件需要绑定到document 在jQuery 1.9中, 全局的AJAX事件(ajaxStart, ajaxStop, ajaxSend, ajaxComplete, ajaxError, ...
- Java多线程之synchronized(五)
上篇介绍了用synchronized修饰static方式来实现“Class 锁”,今天要介绍另一种实现方式,synchronized(class)代码块,写法不一样但是作用是一样的.下面我附上一段代码 ...
- 关于RadUpload上传问题总结
最近在开发上传控件,使用RadUpload上传大附件 发现了几个小问题,总结后分享给大家: 1.IE6浏览器下文件的路径显示的是物理路径,需要进行转换 2.IIS7.0 配置时要选择经典模式 3.we ...
- Objects
Obeject Object Object representation and value representation Subobjects Polyomrphic objecets Alignm ...