版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、,第 15 章 数据库应用系统开发实例剖析,本章重点剖析了数据库应用系统的一个主要模块,综合运用了前面各章所学习的浏览与更新数据的方法。,【知识技能目标】 (1)掌握对数据源中的数据进行模糊查询与精确查询的方法。 (2)掌握利用工具栏中的按钮移动记录位置的方法。 (3)掌握在独立窗体中新增和修改数据的方法。,(4)掌握在本窗体中删除数据记录的方法。 (5)掌握数据验证的方法。 (6)掌握定义复合SQL语句的方法。,【本章学习导航】 本章所剖析的功能模块将记录导航按钮,新增、修改与删除等按钮集中分布在窗口工具栏,使得界面更加整齐、美观。另外,该功能模块对数据的新增与修改在一个独立的窗口中完成。,
2、【实例15-1】 1设计任务 设计两个窗体,一个窗体主要用于浏览与删除数据,另一个窗体主要用于新增与修改数据,其运行效果如图15-1所示,该窗体具有以下功能。,图15-1学生数据管理初始界面,(1)浏览“学生信息”表中的全部数据(如图15-1所示),一个班的数据(如图15-2所示),一个学生的数据(如图15-3所示)。 (2)新增学生数据。,图15-2浏览一个班的学生数据,图15-3浏览一个学生的数据,先单击工具栏中的【新增】按钮,打开如图15-4所示的新增数据窗体,“学号”文本框设置为初始值,在各个TextBox控件和ComboBox控件中输入学生数据,然后单击【保存】按钮保存新增的学生数据
3、。,图15-4新增学生数据,第一条新增的学生记录保存完成后,该窗体中的【新增记录】按钮变为可用状态,单击该【新增记录】按钮可以继续新增记录。如果新增的学生数据不需要保存,可以单击【取消】按钮取消新增的数据。单击【退出】按钮,关闭本窗体返回父窗体。,(3)修改学生数据。 先在DataGrid控件中选取所需修改的学生数据,然后单击工具栏中的【修改】按钮,打开如图15-5所示的修改数据窗体,修改学生数据窗体中显示了对应记录的数据。,图15-5修改学生数据,接下来输入或选取新数据,修改完成后单击【保存】按钮。如果所修改的学生数据不需要保存,可以单击【取消】按钮取消所修改的数据。单击【退出】按钮,关闭本
4、窗体返回父窗体。,(4)删除学生数据。 先在DataGrid控件中选取所需删除的学生数据,然后单击工具栏中的【删除】按钮即可删除所选取的记录。,2设计过程 (1)新建一个项目Chapter15_1。 (2)“学生数据管理”窗体设计。,在“学生数据管理”窗体中添加工具栏、Label控件、TextBox控件、DataGrid控件和ImageList控件,窗体及控件的设计外观如图15-6所示。窗体及控件的主要属性设置如表15-1所示,其余的属性保留其默认值。,图15-6学生管理窗体的设计状态,(3)编写“学生数据管理”窗体的程序代码,实现其功能。,将第13章中自定义的数据访问类SqlDbClass.
5、vb添加到项目Chapter15_1中,新建模块文件“Module1.vb”,该模块文件只有两行代码,如代码15-1-1所示。Module1.vb文件的功能是建立自定义数据访问类SqlDbClass的对象,isAdd用于区分“新增数据”和“修改数据”。,窗体级对象变量的定义如代码15-1-2所示。 窗体Load事件过程的程序代码如代码15-1-3所示。,其主要功能是:从“班级”数据表中提取数据作为ComboBox1的数据源,并将ComboBox1的SelectedIndex属性值设置为-1,从而触发ComboBox1的SelectedIndexChanged事件,执行SelectedIndex
6、Changed事件处理程序。,工具栏ToolBar1的ButtonClick事件过程的程序代码如代码15-1-4所示。 控件DataGrid1的CurrentCellChanged事件过程的程序代码如代码15-1-5所示。,自定义过程LoadData的程序代码如代码15-1-6所示,该过程主要用于根据不同的查询条件提取所需的数据。,自定义过程ShowAdd的程序代码如代码15-1-7所示,该过程的作用是给公有变量isAdd赋值“True”,调用新增记录的窗体。,自定义过程ShowEdit的程序代码如代码15-1-8所示,该过程的作用是将DataGrid控件中当前所选取的行的“学号”传递给窗体f
7、rmStudentInfo的变量RecordNum,同时给公有变量isAdd赋值“False”,调用修改记录的窗体。,自定义过程DeleteData的程序代码如代码15-1-9所示,该过程的作用是删除DataGrid控件中当前所选取的行。,ComboBox1控件的SelectedIndexChanged事件过程、TextChanged事件过程与TextBox1控件、TextBox2控件的TextChanged事件过程的程序代码相同,其作用是调用自定义过程LoadData。,DataGrid1控件的DoubleClick事件过程的程序代码为:ShowEdit( ),其作用是调用修改数据的窗体。,
8、(4)设计新增学生数据或修改学生数据的窗体。 新增、修改学生数据采用同一个窗体,窗体及控件的设计外观如图15-7所示。,图15-7新增或修改学生数据窗体,(5)编写“新增或修改学生数 据”窗体的程序代码,实现其功能。,在定义类的代码之前引入命名空间,其代码为:Imports System.Data.SqlClient。,窗体级对象变量的定义如代码15-1-10所示,其中变量RecordNum用于保存窗体frmStudentManage中的DataGrid控件当前选取行的“学号”。,窗体frmStudentInfo的Load事件过程的程序代码如代码15-1-11所示,根据isAdd的值判断是新增
9、数据还是修改数据,从而为数据适配器设置不同的命令,第08行调用【新增记录】按钮的Click事件过程。,【新增记录】按钮的Click事件过程的程序代码如代码15-1-12所示。 【保存】按钮的Click事件过程的程序代码如代码15-1-13所示。 【取消】按钮的Click事件过程的程序代码如下。,sqlDs.Tables(0).Rows(bmData.Position).RejectChanges() 自定义过程SetComm的程序代码如代码15-1-14所示,该过程的作用是设置数据适配器的InsertCommand属性和UpdateCommand属性。,自定义过程ClearTxt的程序代码如代
10、码15-1-15所示。 自定义过程DataBind的程序代码如代码15-1-16所示。,3代码分析 代码15-1-16中的第29行至第40行建立了一个临时表,该临时表中添加了2个字段和2条记录,用于为控件ComboBox1提供数据源。,第41行将控件cboSex的DataSource属性设置为该临时表,同时设置了DisplayMember和ValueMember属性。,4知识要点说明 项目Chapter15_1中包含了两个窗体: frmStudentManage和frmStudentInfo,1个自定义类:SqlDbClass.vb,1个自定义的模块文件:Module1.vb。,该项目主要实现了以下功能。 (1)模糊查询 可以查询数据表中的全部数据或部分数据。 (2)新增、修改和删除数据,【课堂实践】 打开光盘中文件夹【ClassroomPractise15_1】中的解决方案文件【Classroom Practise15_1.sln】,打开该解决方案中的窗体【frmUsers.vb】,切换到代码窗体,为自定义过程InsertRecord()和UpdateRe
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 3弯钩教学设计小学书法苏少版三年级下册-苏少版
- 2025-2026学年安全教案怎么瘦小
- 14.足球射门 教学设计-七年级上学期体育与健康
- 交易系统风控制度
- 人才培训教育制度
- 企业不重视内部审计制度
- 企业廉洁教育培训制度
- 优化各部门绩效考核制度
- 供应绩效考核制度
- 保密审计管理制度
- 钢琴简谱乐理知识课件
- DB41∕T 2816-2025 建设项目节约集约用地综合论证技术指南
- 2025四川成都新都投资集团有限公司招聘党建文书岗等岗位13人笔试参考题库附带答案详解(3卷)
- 大学生英语四级核心1500词
- 2025年招银理财笔试题库及答案
- 萌宠乐园招商方案
- 产后抑郁症典型案例分析与心理干预报告
- 压力性损伤的健康宣教
- 电梯钢丝绳更替作业方案
- 初创科技企业股权激励方案解析
- 校园周边安全风险隐患排查台账
评论
0/150
提交评论