一个优秀的程序猿就是要尽可能降低自己的代码量。我们日常的工作或者学习中都有可能遇到多个窗口结构类似,或者大同小异的情况,这时候假设在每一个窗口都写一遍代码,或者纯粹的复制粘贴就太水了。想要偷懒的时候正是我们发现和创造的机会,我们的祖先也是这么过来的。

我在做机房收费系统个人重构版的时候,就遇到了基本数据维护、查看上机状态、上机信息统计和操作员工作记录四个窗口都组要用到组合查询并且窗口结构一致。

四个窗口中除了字段名不一致,其它的内容都一样,这样的情况下我们用窗口的继承最合适了。在父窗口中写好公共的部分,不一致的地方能够写一个虚方法,然后让子类重写父类的虚方法。这样我们仅仅须要一个U层,一个B层,一个接口,一个抽象工厂,一个D层然后子类重写虚方法就能够实现四个窗口各自的功能了。

U层主要推断一下控件是否为空,给实体參数和B层方法传值传值,以及定义转换数据库字段的虚方法和获取表名的虚方法,这些虚方法在不同的子类中被重写以实现不同功能。

'*************************************************
'作者:邵鸿鑫
'小组:
'说明:组合查询模板
'创建日期:2014.7.9
'版本:
'**********************************************/
Public Class frmGroupQueryPublic thisgroupquery As New Entity.GroupQueryEnpty '定义一个实体參数Private Sub Button1_Click_1(sender As Object, e As EventArgs) Handles btnQuery.Click'第一行组合关系为空If cmbRelation1.Text = "" Then'推断第一行控件内容是否为空If cmbField1.Text = "" ThenMsgBox("请输入字段名")ElseIf cmbOperation1.Text = "" ThenMsgBox("请输入操作符")ElseIf txtContent1.Text = "" ThenMsgBox("请输入要查询的内容")End IfEnd If' 当第一个组合关系不为空时  If cmbRelation1.Text <> "" ThenIf cmbField1.Text = "" ThenMsgBox("请输入字段名")ElseIf cmbOperation1.Text = "" ThenMsgBox("请输入操作符")ElseIf txtContent1.Text = "" ThenMsgBox("请输入要查询的内容")ElseIf cmbField2.Text = "" ThenMsgBox("请输入字段名")ElseIf cmbOperation2.Text = "" ThenMsgBox("请输入操作符")ElseIf txtContent2.Text = "" ThenMsgBox("请输入要查询的内容")End IfEnd If' 当第二个组合关系不为空时  If cmbRelation2.Text <> "" ThenIf cmbField1.Text = "" ThenMsgBox("请输入字段名")ElseIf cmbOperation1.Text = "" ThenMsgBox("请输入操作符")ElseIf txtContent1.Text = "" ThenMsgBox("请输入要查询的内容")ElseIf cmbField2.Text = "" ThenMsgBox("请输入字段名")ElseIf cmbOperation2.Text = "" ThenMsgBox("请输入操作符")ElseIf txtContent2.Text = "" ThenMsgBox("请输入要查询的内容")ElseIf cmbField3.Text = "" ThenMsgBox("请输入字段名")ElseIf cmbOperation3.Text = "" ThenMsgBox("请输入操作符")ElseIf txtContent3.Text = "" ThenMsgBox("请输入要查询的内容")End IfEnd If'给实体层传參Dim thisgroupquery As New Entity.GroupQueryEnptythisgroupquery.cmbField1_text = GetDBName(cmbField1.Text.Trim())thisgroupquery.cmbField2_text = GetDBName(cmbField2.Text.Trim())thisgroupquery.cmbField3_text = GetDBName(cmbField3.Text.Trim())thisgroupquery.cmbOperation1_text = cmbOperation1.Text.Trim()thisgroupquery.cmbOperation2_text = cmbOperation2.Text.Trim()thisgroupquery.cmbOperation3_text = cmbOperation3.Text.Trim()thisgroupquery.txtContent1_text = txtContent1.Text.Trim()thisgroupquery.txtContent2_text = txtContent2.Text.Trim()thisgroupquery.txtContent3_text = txtContent3.Text.Trim()thisgroupquery.cmbRelation1_text = GetDBName(cmbRelation1.Text.Trim())thisgroupquery.cmbRelation2_text = GetDBName(cmbRelation2.Text.Trim())thisgroupquery.GetTable = GetTable()'给B层GroupQuery方法传递參数Dim db As New BLL.GroupQueryBLLIf db.GroupQuery(thisgroupquery) Is Nothing ThenMsgBox("没有记录,请又一次设置查询条件", vbOKOnly, vbExclamation)DataGridView1.DataSource = NothingElseDataGridView1.DataSource = db.GroupQuery(thisgroupquery)End IfEnd Sub' 定义虚函数GetDBName,获取不同数据库的字段名  Protected Overridable Function GetDBName(ByVal control As String) As StringReturn ""End Function' 定义虚函数GetDBName,获取不同数据库的表名  Protected Overridable Function GetTable() As StringReturn ""End FunctionPrivate Sub Button2_Click_1(sender As Object, e As EventArgs) Handles btnExit.ClickMe.Hide()End Sub'组合关系一不为空后,显示第二行查询条件Private Sub cmbRelation1_SelectedIndexChanged(sender As Object, e As EventArgs) Handles cmbRelation1.SelectedIndexChangedcmbField2.Enabled = TruecmbOperation2.Enabled = TruecmbRelation2.Enabled = TruetxtContent2.Enabled = TrueEnd Sub'组合关系二不为空后,显示第三行查询条件Private Sub cmbRelation2_SelectedIndexChanged(sender As Object, e As EventArgs) Handles cmbRelation2.SelectedIndexChangedcmbField3.Enabled = TruecmbOperation3.Enabled = TruetxtContent3.Enabled = TrueEnd Sub
End Class

B层写法跟曾经分层写法一样,引用工厂和接口返回查询到的表。

<span style="font-family:KaiTi_GB2312;font-size:18px;">'*************************************************
'作者:邵鸿鑫
'小组:
'说明:组合查询B层
'创建日期:2014.7.17
'版本:
'**********************************************/
Imports IDAL
Imports Entity
Public Class GroupQueryBLLPublic Function GroupQuery(ByVal queries As Entity.GroupQueryEnpty) As DataTableDim factory As New Factory.GroupQueryFactoryDim igroupquery As IGroupQuery = factory.GroupQueryDim table = igroupquery.GroupQuery(queries)'检查D层返回的数据表中是否有数据If table.Rows.Count = 0 ThenReturn NothingElseReturn tableEnd IfEnd Function
End Class</span>

D层实现接口,调用存储过程实现对数据库的訪问。

<span style="font-family:KaiTi_GB2312;font-size:18px;">'*************************************************
'作者:邵鸿鑫
'小组:
'说明:组合查询D层
'创建日期:2014.7.17
'版本:
'**********************************************/
Imports System.Data.SqlClient
Imports IDAL
Public Class SqlserverGroupQueryDAL : Implements IGroupQueryFunction GroupQuery(ByVal queries As Entity.GroupQueryEnpty) As DataTable Implements IGroupQuery.GroupQueryDim strSQL As String = "PROC_GroupQuery" '调用存储过程Dim prams As SqlParameter() = {New SqlParameter("@cmbField1", queries.cmbField1_text),New SqlParameter("@cmbField2", queries.cmbField2_text),New SqlParameter("@cmbField3", queries.cmbField3_text),New SqlParameter("@cmbOperation1", queries.cmbOperation1_text),New SqlParameter("@cmbOperation2", queries.cmbOperation2_text),New SqlParameter("@cmbOperation3", queries.cmbOperation3_text),New SqlParameter("@txtContent1", queries.txtContent1_text),New SqlParameter("@txtContent2", queries.txtContent2_text),New SqlParameter("@txtContent3", queries.txtContent3_text),New SqlParameter("@cmbRelation1", queries.cmbRelation1_text),New SqlParameter("@cmbRelation2", queries.cmbRelation2_text),New SqlParameter("@tableName", queries.GetTable)} '设置參数Dim helper As New SqlHelperDim table As New DataTabletable = helper.GetDataTable(strSQL, CommandType.StoredProcedure, prams)Return tableEnd Function
End Class</span>

存储过程

<span style="font-family:KaiTi_GB2312;font-size:18px;">-- =============================================
-- Author:      邵鸿鑫
-- Create date: 20140719
-- Description: 组合查询
-- =============================================
ALTER PROCEDURE [dbo].[PROC_GroupQuery]-- Add the parameters for the stored procedure here@cmbField1 varchar(10),@cmbOperation1 varchar(10),@txtContent1 varchar(10),@cmbField2 varchar(10),@cmbOperation2 varchar(10),@txtContent2 varchar(10),@cmbField3 varchar(10),@cmbOperation3 varchar(10),@txtContent3 varchar(10),@cmbRelation1 varchar(10),@cmbRelation2 varchar(10),@tableName varchar(20)
ASdeclare @TempSql varchar(500)--暂时存放sql语句
BEGINSET @TempSql='SELECT * FROM '+@tableName +' WHERE ' +@cmbField1 +@cmbOperation1+char(39) + @txtContent1 + char(39)  if @cmbRelation1 != ''BEGIN  SET @TempSql=@TempSql+@cmbRelation1+CHAR(32)+@cmbField2 +@cmbOperation2+CHAR(39)+@txtContent2+CHAR(39)  if @cmbRelation2!= ''BEGIN  SET @TempSql=@TempSql+@cmbRelation2+CHAR(32)+@cmbField3+@cmbOperation3+CHAR(39)+@txtContent3+CHAR(39)  END  END
EXECUTE(@TempSql)
END</span>

抽象工厂应用配置文件,实现灵活更换数据库。

<span style="font-family:KaiTi_GB2312;font-size:18px;">'*************************************************
'作者:邵鸿鑫
'小组:
'说明:组合查询抽象工厂
'创建日期:2014.7.17
'版本:
'**********************************************/
Imports System.Reflection
Imports System.Configuration
Imports IDAL
Public Class GroupQueryFactoryPrivate Shared ReadOnly AssemblyName As String = "DAL" '声明程序集名称Private Shared ReadOnly db As String = ConfigurationManager.AppSettings("DB") '读取配置文件到dbPublic Function GroupQuery() As IGroupQueryDim className As String = AssemblyName + "." + db + "GroupQueryDAL"Dim igroupquery As IGroupQueryigroupquery = CType(Assembly.Load(AssemblyName).CreateInstance(className), IGroupQuery)Return igroupqueryEnd Function
End Class
</span>

子类代码以操作员工作记录为例,首先加入继承窗口

然后选择被继承的窗口

之后就是重写父类的虚方法

<span style="font-family:KaiTi_GB2312;font-size:18px;">'*************************************************
'作者:邵鸿鑫
'小组:
'说明:查询操作员工作记录U层
'创建日期:2014.7.18
'版本:
'**********************************************/
Public Class frmworklog'重写转换成数据库字段方法Protected Overrides Function GetDBName(ByVal control As String) As StringSelect Case (control)Case "教师"Return "userName"Case "上班日期"Return "loginTime"Case "上班时间"Return "loginTime"Case "下班日期"Return "offTime"Case "下班时间"Return "offTime"Case "机器号"Return "computer"Case "与"Return "and"Case "或"Return "or"Case ElseReturn ""End SelectEnd Function'重写获得表名方法Protected Overrides Function GetTable() As Stringthisgroupquery.GetTable = "Work_info"Return thisgroupquery.GetTableEnd FunctionPublic Sub frmworklog_load(sender As Object, e As EventArgs) Handles MyBase.Load'给字段赋初值cmbField1.Items.Add("教师")cmbField1.Items.Add("上班日期")cmbField1.Items.Add("上班时间")cmbField1.Items.Add("下班日期")cmbField1.Items.Add("下班时间")cmbField1.Items.Add("机器号")cmbField2.Items.Add("教师")cmbField2.Items.Add("上班日期")cmbField2.Items.Add("上班时间")cmbField2.Items.Add("下班日期")cmbField2.Items.Add("下班时间")cmbField2.Items.Add("机器号")cmbField3.Items.Add("教师")cmbField3.Items.Add("上班日期")cmbField3.Items.Add("上班时间")cmbField3.Items.Add("下班日期")cmbField3.Items.Add("下班时间")cmbField3.Items.Add("机器号")End Sub
End Class</span>

为了避免用户不按顺序组合查询条件,把第二行和第三行查询条件以及第二个组合关系设的属性置为不可用,仅仅有第一个组合关系不为空时第二行查询条件和第二个组合关系才干使用,同理第二个组合关系不为空时第三行组合条件才干使用。

言归正传这一切的一切都是为了降低我们的工作量,人类的进步事实上就是一次次为了“偷懒”而不断探索的过程。文章中有不足之处还请大神们批评指正,希望能对大家有所帮助。

组合查询——怎样使用窗口的继承达到事半功倍?相关推荐

  1. .NET重构(四):窗体继承+模板方法,完美实现组合查询

    导读:在机房重构中,有好些个查询都是大同小异,最为显著的就是组合查询了.怎样给自己省事儿,相同的东西能不能重复利用,就成了一个现实的问题.第一遍做机房的时候,使用的更多的是:复制+粘贴.学习了设计模式 ...

  2. 继承窗体搭建组合查询模板方法的幸福之家

            窗外寒冬有了春的温暖,过了立春还在北国,总觉得已过春节,实际迟迟未到.         继承窗体做了组合查询与模板方法的红娘,搭建了幸福之间.期盼着春节列车红娘,只想做南方过客的&qu ...

  3. 组合查询(机房重构知识点总结)

    历经n多天.组合查询模板最终做完了,总结一下这几天的成果.和大家一起学习交流. 先看一下父窗口的关键代码: 父窗口代码: Public Class frmComboQueryProtected Ove ...

  4. SQL如何构建多条件组合查询,而且不降低效率

    我们知道,在一般的信息系统中,特别是主要信息表,如客户基本信息,工单受理主界面,用户会用到多条件组合查询. 我看过一些系统,有的人是采用将一个表的栏位给用户选择,然后用户可以针对某一栏位来下条件,但是 ...

  5. 《数据库系统原理及应用教程》(苗雪兰等,第五版) 实验五:数据库的组合查询和统计查询实验

    阅读前注意: 1. 本实验报告配套<数据库系统原理及应用教程>(苗雪兰等,第五版) 实验五:数据库的组合查询和统计查询实验(书上10.4节以及第六章部分内容),书本中采用Microsoft ...

  6. 蠡测机房重构之组合查询

    [写在前边的话] 在进行机房重构的过程中,设计组合查询的窗体,真的是学到了很多东西.以管窥豹,以蠡测海,所以想小小的总结一下,缅怀这一寸寸学习的时光. [设计模式之模板方法的运用] 模板方法模式--在 ...

  7. 数据库第四次试验:数据库的组合查询、统计查询及视图

    数据库第四次试验:数据库的组合查询.统计查询及视图 前言 一.实验目的 二.实验要求 三.实验原理.方法和手段 四.实验组织运行要求 五.实验条件 六.实验步骤 七.思考题 八.实验报告 九.其他说明 ...

  8. MySQL 学习笔记(4)— 组合查询、子查询、插入数据、更新/删除表数据、增加/删除表中的列以及重命名表

    1. 组合查询 1.表的加减法 表的加法,即求 product 和 product2 的并集,UNION 运算会除去重复的记录 SELECT product_id, product_name FROM ...

  9. 多条件组合查询+分页

    比较麻烦,把他记录下来. 前台UI: 实现的类代码: 程序代码 /// <summary>         /// 多条件组合查询         /// </summary> ...

最新文章

  1. LeetCode-笔记-112、路径总和
  2. 简明Python3教程 4.安装
  3. 直接导入用户信息到discuz ucenter.
  4. 注册表只改一个值 马上加快宽带上网速度
  5. Java23个设计模式的简明教程
  6. HTML5-Ajax文件上传(转)
  7. Win7 下安装ubuntu14.04双系统
  8. python 抓取 快代理-国内普通代理 IP
  9. oracle的order by排序优化,oracle order by 排序优化
  10. 利用Fiddler下载旧版本 iOS App
  11. C++练习题:分数化简
  12. 管理经济学【六】之 成本分析
  13. 学习笔记 | Orillusion-WebGPU小白入门(六)
  14. Ngrok的外网映射
  15. PCB设计软件-入门
  16. Html页面中直接显示pdf【一行代码实现】
  17. CAD中如何识别CAD标高范围?
  18. java网上报名系统源码_基于jsp的网上报名系统-JavaEE实现网上报名系统 - java项目源码...
  19. 基于javaweb+mysql的网上水果超市商城设计和实现(java+ssm+springboot+redis)
  20. 马云“退休”前,给我们留下的10句人生真言

热门文章

  1. 前端开发常见问题精选(五)
  2. 5G时代,会有什么奇葩事儿?
  3. Matlab绘图高级部分
  4. AngularJS表单验证
  5. 全球顶级专家为你解读:什么是真正的 DevOps?
  6. python操作符笔记
  7. 最新版本的Silverlight Tools For Silverlight 2 RTW正式版
  8. 我的IT历程,希望给大家点经验。
  9. 云计算如何帮助直播行业发展
  10. 如何避开项目管理陷阱?