框架的主要内容就是创建一个父类Form,实现基本逻辑。使用时,这些逻辑就无需用户实现。用户只需按照规则,设计好界面即可。
界面如下:
界面分为两大部分,查询定位和数据维护
查询定位将根据前面的数据库设计原则,默认对数据库中的 name 字段进行查询,查询方式采用模糊方式。
数据维护分为三部分,数据输入和显示区域,控制按钮区域以及信息显示区域。注意,所有的数据项,都要在标题下面的GroupBox中。
为了显示的灵活性,从用 splitPanel进行分割。
分解思路, 数据的维护包括展示和保存两步骤,关键点就是将数据库表字段和界面元素映射起来,这样就可以利用代码对其进行控制。
查询内容是一个结果集,可以利用C#的DataGridView进行存贮和展示,鼠标点击数据时,可以获得这一行的内容,包括每个column 的名字,利用这个名字可以和界面上的元素建立联系。
主表普通项:1NF 范畴的数据中的简单数据类型,数字,字符和日期型数据,可以和C#控件类型直接映射
引用项:3NF 范畴的数据,一般是主表记录一个外键,或许有冗余信息,而其他有关数据再引用表中,为了界面内容明确清晰,有时候需要将引用表内容显示出来。
例如:
有下面两张表
主表是:
引用表是(民族表)
注意stdents 中的
ethnic_pk 外键,引用 ethnic 的主键
ethnic_name 冗余内容,为 ethnic 中 name
我们的要求的是:
界面上显示 ethnic_name 并且可以更新主表中的 ethnic_name 和 ethnic_pk,
界面上辅助显示 ethnic 中的 abrev 和location等等, 不需要更新到主表中。
因此必须要想办法区分这两种数据。
主表名称:采用固定的成员变量记录主表名称,感觉我们前面的约定,其主键也是确定的,即PK。
主键值:采用固定的成员变量记录主键值
其余字段
字符型:采用 TextBox 或者是MaskedTextBox
其中枚举数据 可以使用 ComboBox,例如录入 性别,星期 这种简单的且固定的属性;
数字型:NumericUpDown
日期型:DateTimePicker
由于要输入引用表的主键,因此要有类似comboBox之类的行为,但是引用主键的值如果暴露给用户,是很突兀和奇怪的,因此要隐藏记录这个值,显示具有意义的文字,例如上例中的民族名称或者简称。
采用 DataGridView 完成这一功能,显示文字信息,而主键内容进行隐藏。同时增加相关信息的修改功能,例如其余信息的相应变化。
为了操作一致性,实现一个控件,另DataGridView 为其一个成员变量,新控件增加Text 属性,从而使DataGridView 的赋值和取值操作和普通控件一致,这样后台处理过程就比较简单了。
为了实现冗余数据和引用表数据的区分,利用Panel容器分别作为这些项的容器,在tag中标明他们的属性。
为了不影响VS的正常开发流程,不打算增加新的控件,利用现有的控件完场这些规则的定义,这样减少开发使用中的学习成本。
采用简单字符进行内容的标定,不准备采用功能更加强大的Json格式。
tag中的内容包括:约束属性(非空,唯一性),提示信息,实体属性(表和字段名)
根据上述约定和命名规则,可以完成数据表内容和界面元素的映射,为了操作方便,需要将符合上述要求的界面元素记录到集合中,这样方便后续处理。
增加:需要的功能,清空界面,设置默认值(简版不支持)
删除:删除当前数据记录
修改:设置修改标记,并且将界面元素设置为可以修改的状态
保存:根据时增加还是修改属性,生成insert 或者update 语句
退出:退市时当期系统。
提供状态过程的信息,包括数据有效性判断,保存数据成功与否的提示。
为了完成上述功能,需要实现一个工具包类,采用静态函数,这样方便使用。
功能包括:
1、字段名称提取功能,可以有多个,从控件名称中,从tag中等等
2、控件遍历和判断
3、有效性检查
下面将进入代码阶段
MaraSun 2023-02-03 BJFWDQ
ps:
昌平线南段明天试运行,本人出行将更加方便,地铁站只有300米左右的距离。是记。