第1章 系统总体结构
1.1 总体结构图
系统实现需要部署服务器端的远程对象(即一个DbServerLibrary.dll),服务器端要注册通道和该远程对象。客户端要实现一个本地查询的服务器,同时根据SQL解析的结果向各个服务器发送命令,并将结果显示在客户端界面,服务器端可以接受并显示相应的命令。
1.2 关键组件结构图
系统结构中关键的组件有远程对象,和本地服务器,实现的功能基本一致。下面以远程对象为例,说明组件的实现。远程对象在服务器端解决方案下的库文件中声明,通过服务器端进行注册,客户端通过TCP通道与服务器端远程对象通信,实现数据集的查询和传输。主要的数据成员有:SqlConnection(SQL Server数据库的连接对象)、 SqlCommand (SQL命令对象)、SqlDataAdapter(数据适配器,填充数据集)组件——DbServerLibrary。
第2 章 数据字典结构
因时间仓促,未实现数据字典,所有实验要求的SQL经过解析后,直接通过代码判断,向相应场地发送命令。
代码分为三部分:远程对象,服务器端代码和客户端代码。
其中:远程对象部署在各个服务器端,客户端除了实现查询命令的解析和传送外外,还有一个本地服务器,进行相应的本地查询。
远程对象代码:
using System;
using System.Runtime.Serialization;
using System.Data;
using System.Data.SqlClient;
using System.Windows.Forms;
namespace DbServerLibrary
{
[SerializableAttribute] //It is very important for Remoting Data
public class DbServer : MarshalByRefObject
{
private string connStr;
private string clientSql;
public SqlConnection sqlConn;
public SqlCommand sqlComm;
public SqlDataAdapter sqlAdapter;
public void GetClientSql(string sql)
{ if(clientSql != null)
{ clientSql = null;
} clientSql = sql;
MessageBox.Show(clientSql); }
public DbServer()
{ //LocalData Initialize
connStr = "Data Source = localhost;Initial Catalog=DDB;User ID=sa;Password=;";
sqlConn = new SqlConnection(connStr);
} public DataSet GetDataSet() // 执行select
{ DataSet ds = new DataSet();
if (sqlComm != null)
{ sqlComm = null;
}
if(sqlConn.State == ConnectionState.Closed)
{ sqlConn.Open();
} try
{ sqlComm = new SqlCommand();
sqlComm.Connection = sqlConn;
sqlComm.CommandText = clientSql;
sqlComm.CommandType = CommandType.Text;
sqlAdapter = new SqlDataAdapter();
sqlAdapter.SelectCommand = sqlComm;
sqlAdapter.Fill(ds);
}
catch(SqlException ex)
{
MessageBox.Show(ex.Message);
}
return ds;
} public int ExecuteSql() //执行insert和delete
{
int affectedNumber;
if (sqlComm != null)
{
sqlComm = null;
}
if(sqlConn.State == ConnectionState.Closed)
{
sqlConn.Open();
}
try
{
sqlComm = new SqlCommand();
sqlComm.Connection = sqlConn;
sqlComm.CommandType = CommandType.Text;
sqlComm.CommandText = clientSql;
affectedNumber = sqlComm.ExecuteNonQuery();
return affectedNumber;
}
catch(SqlException ex)
{
MessageBox.Show(ex.Message);
return 0;
}
}
}
}
服务器端代码:
private void frmSupplierServer_Load(object sender, System.EventArgs e)
{ TcpChannel chan = new TcpChannel(8888);
ChannelServices.RegisterChannel(chan);
//注册提供服务的远程对象 RemotingConfiguration.RegisterWellKnownServiceType(typeof(DbServerLibrary.DbServer),"DbServer",WellKnownObjectMode.Singleton);
}
客户端代码:
解析SQL:SqlParse.cs
namespace SupplierClient
{ public class SqlParse
{ //得到sql语句的类型
public string GetSqlType(string sqlText) //type of SQL statements
{
}
//得到select语句要查询的表名
public string GetSelectTableName(string sqlText)
{
}
//得到select语句中的where子句
public string GetWhereClause(string sqlText)
{
}
//得到查询条件中的字段名
public string GetSelectField(string sqlText)
{
}
//得到分片依据,返回Scity的值
public string GetSelectCityValue(string sqlText)
{
}
//设定select语句经解析后的格式
public ArrayList SetSelectList(string sqlText)
{
}
//如果没有分片信息,则向3个场地都发送命令
public ArrayList SendToAllSite(string sqlText)
{
}
//得到insert语句要查询的表名
public string GetInsertTableName(string sqlText)
{
} //根据插入的表和值,设定场地:INSERT INTO Supplier VALUES('no','name','city'),return city
public string GetInsertCityValue(string sqlText)
{
} //如果表名是Supplier,则根据city值设定向哪个场地发送命令
public ArrayList SetInsertSite(string sqlText)
{
}
//生成解析后的insert命令列表
public ArrayList SetInsertList(string sqlText)
{ }
本地服务器查询代码:LocalServer.cs
namespace SupplierClient
{
public class LocalServer
{ } //返回查询结果
public DataSet MakeDataSet(string sqlText)
{
} //执行插入和删除操作,并返回影响记录数
public int ExecuteSql(string sqlText)
{ }
| 共2页: 1 [2] 下一页 | ||
|
|
|||
| · C++是垃圾语言?! · 邮件服务器专题 · Exchange Server专题 · 软件插件 · Serv-U基础应用专题 · 负载均衡技术基础专题 · CRM项目实施指导 · ERP系统应用实施指导 |
· Windows服务器全面加固 · Windows发展史 · Cisco IOS · Windows注册表应用指南 · FreeBSD使用教程 · Windows活动目录服务应.. · Windows系统使用技巧 · Zope应用开发指南 |
||
|
|||
| · Java基础教程 · VPN技术 · SQL Server 2005全解 · ARP攻击防范与解决方案 · SOA 面向服务架构 · SQL Server 2005全解 · Java编程开发手册 · 三层交换技术专题 |
· SQL Server入门到精通 · Windows Server 2003企.. · Windows远程桌面应用 · C#技术开发指南 · VPN技术 · Solaris 10 配置管理 · C#技术开发指南 · Windows操作系统安装 |
||
|
|||
| · VPN技术 · ARP攻击防范与解决方案 · SQL Server 2005全解 · Java基础教程 · SQL Server入门到精通 · SQL Server 2005全解 · SOA 面向服务架构 · Java编程开发手册 |
· C#技术开发指南 · 三层交换技术专题 · C#技术开发指南 · Windows远程桌面应用 · Windows Server 2003企.. · 邮件服务器专题 · wimax技术与趋势 · Windows操作系统安装 |
||
| ·DB2 Viper快速入门 ·DB2 9数据库的镜像分割与.. |
·将XML应用程序从DB2 8.x.. ·DB2 9中的pureXML:如何.. |
| ·服务器中的“傻瓜机”在.. ·盖茨也喜欢登录Youtube看.. |
· · |
| ·将职业教育职业化 - 各IT.. ·思科交换机上实现MAC地址.. |
·关于51CTO合作出书中的职.. ·OSPF动态路由协议入门简介 |
| ·9月第3周回顾:微软和英.. ·9月第2周回顾:四核之战.. |
·9月第1周回顾:微软国际.. ·什么样的文章更容易被编.. |
| · NGN:下一代网络 · 网络访问中断大排查 · FTTx光纤接入 |
· 平凡黑客讲述精彩人生(.. · 平凡黑客讲述精彩人生(.. · 平凡黑客讲述精彩人生(.. |
| · C++是垃圾语言?! · 2007年IT界七大抄袭事件 · Java实用开发全集 |
· 解析Ajax开发框架 走进A.. · 基于Google Maps与Ajax.. · 基于Google Maps与Ajax.. |
| · Ubuntu 中文开源频道 · Solaris基础知识入门 · 微软正式发布英文版Wind.. |
· 服务器基础知识入门 · Rambus第二?看全缓冲内.. · 服务器节能对比测试:AM.. |
| · 甲骨文Oracle 11g正式发.. · Oracle数据库开发之PL/S.. · Oracle数据库开发基础教.. |
· 存储2006,一个并购的大.. · IDC宣布浪潮蝉联存储市.. · 双机热备技术 |