版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、嵌入式linux应用与开发课程大作业题目:学生信息管理系统专业:姓名:学号:成绩:2015年 7 月任务书大作业6:学生信息管理系统(单人独立完成)功能需求:本系统用于对学生信息的管理,要求必须对数据库进行操作,建立至少三个数据表,并提供“登陆验证界面”、“添加学生信息”、“查询某个学生信息”、“统计目前学生人数”、“删除某个学生信息”、“退出”等功能,界面设计美观,布局合理,并下载移植到arm2440s嵌入式开发板上。具体功能要求:1、 学生信息查询功能1) 按姓名查询 2) 按学号名查询 2、 学生信息修改与删除3、 学生信息添加功能4、 统计当前学生人数5、 登录验证功能提示:系统可采用
2、qt界面+mysql数据库实现摘要本设计是嵌入式linux应用程序开发的典型例程,采用qt-creater编写的基于数据库支持的学生信息管理系统,移植到armtq2440开发板运行。贯通了嵌入式应用程序开发的全过程。此系统实现了数据库的数据表的查询、插入、删除、更新操作。系统的编译采用了常用的linux操作系统、qt-creater -opensource-5.4.2、arm-linux-gcc-4.3.3交叉编译器。采用超级终端securecrt工具将编译好的工程可执行文件移植到开发。本系统在嵌入式的应用前景广大,各学校拥有这样的便携式信息系统,可以随时随地的对学生信息进行查询,便于对学生的
3、管理。关键字:嵌入式linux应用程序开发 学生信息管理系统 armtq2440 qtcreater目录1 设计题目的内容、任务及具体要求12 总体设计思路22.1 开发环境22.1.1 编写语言22.1.2 开发环境22.1.3 运行环境22.2 系统详细设计22.2.1 系统数据结构设计22.2.2 系统界面设计33 功能模块的具体设计63.1 登陆验证模块设计63.2 查询学生信息模块设计73.3 学生信息修改和删除模块设计93.4 添加学生信息模块设计143.5 统计目前学生人数模块设计164 功能模块的调试及测试17总结20致谢21参考资料221 设计题目的内容、任务及具体要求本课程
4、是嵌入式linux应用程序开发,所以在本次课程中我们应该熟悉掌握应用程序开发的具体流程,所以本次课题选择用qt5.4.2编写一个简易的基于数据库操作的学生信息管理系统,由于qt5版本支持数据库,所以就不用再用其他的数据库开发软件了,免除了数据库的连接及移植操作。系统任务:本系统主要用于对学生信息的管理,提供“登陆验证界面”、“添加学生信息”、“查询某个学生信息”、“统计目前学生人数”、“删除某个学生信息”、“退出”等功能,界面设计美观,布局合理,并下载移植到arm2440s嵌入式开发板上。具体功能要求:1、学生信息查询功能1) 按姓名查询 2) 按学号名查询 2、学生信息修改与删除3、学生信息
5、添加功能4、统计当前学生人数5、登录验证功能2 总体设计思路2.1 开发环境2.1.1 编写语言本设计使用基于c+的图形用户界面软件qt软件编写。qt应用程序框架由奇趣科技公司开发(现属诺基亚公司),是一种基于c+语言的面向用户的图形界面语言,可以构建出工业级的跨平台应用程序。在源代码不经任何修改的情况下,程序即可流畅的运行于windows、linux/unix、mac os x和嵌入式linux上,“一次编写,随处编译”,具有较强的可移植性。2.1.2 开发环境本设计在linux操作系统下,使用qt-creator-win-opensource-5.4.2程序编写。2.1.3 运行环境在li
6、nux下安装arm-linux-gcc-4.3.3交叉编译器,通过qmake、make操作生成arm开发板可执行的文件。然后将此文件移植到开发板运行即可。本设计采用的是armtq2440开发板。2.2 系统详细设计2.2.1 系统数据结构设计本系统通过qsqldatabase定义了一个qsqlite类型的数据库。在数据库中创建了两个数据表user、student,分别存储用户登录信息和学生具体信息。table user(id int primary key, password varchar)table student(id int primary key,name varchar,sex v
7、archar,ageint,course varchar)2.2.2 系统界面设计本系统根据功能共设计了6个界面,分别有用户登录界面、功能菜单界面、信息查询功能界面、信息修改与删除功能界面、信息添加功能界面、学生信息统计功能界面。各界面具体设计如图所示:图 2.1 用户登录界面图 2.2 功能菜单界面图 2.3 信息查询功能界面图 2.4 信息修改与删除功能界面图 2.5 信息添加功能界面图 2.6 信息统计功能界面各界面中使用到的控件有lable、line edit、group box、push button、check box等。界面form统一大小400x270。背景颜色为紫色。3 功能
8、模块的具体设计3.1 登陆验证模块设计操作说明:输入正确的用户信息,点击“登录”按钮就会跳转到下一个菜单界面,并且关闭登录界面。如果输入的信息不正确,如图3.1所示,会提示错误。如果点击“退出”按钮,就会关闭界面,退出系统。图 3.1 用户登录界面本模块主要实现用户登录验证功能。通过数据库查询操作,将line text输入的数据与user表中的数据进行比较。然后做出相应的操作。具体程序设计如下:voidinit_interface:on_pb_enter_clicked()qstringid=ui-lineedit_userid-text();qstringpassword=ui-lineed
9、it_password-text();qsqlqueryquery;query.exec(select*fromuser);while(query.next()inttmp1=id.toint();qstringtmp2=password;intr1=query.value(0).toint();qstringr2=query.value(1).tostring();intx=qstring:compare(tmp2,r2,qt:caseinsensitive);if(tmp1=r1&x=0)this-close();menu*m=newmenu();m-show();elseui-label
10、_error-settext(qstring:fromutf8(用户名或密码错误!);3.2 查询学生信息模块设计操作说明:本模块提供学号查询以及姓名查询两种查询方式,如果勾选学号查询,然后输入学号,如果有此相关信息,便会显示出这个学生的信息,如图3.2。姓名查询与学号查询操作一样,如图3.3。点击“返回上级”可返回菜单界面。点击“退出”可关闭界面,退出系统。图 3.2 学号查询图 3.3 姓名查询本模块主要实现数据库查询功能,通过条件查询显示出相关信息,具体程序设计如下:voidrefer:on_pb_selectok_clicked()if(flag=1)qstringname=ui-li
11、needit_refercondition-text();qsqlqueryquery;query.exec(qstring(selectid,name,sex,age,coursefromstudentwherename=%1).arg(name);while(query.next()intid=query.value(0).toint();qstringname=query.value(1).tostring();qstringsex=query.value(2).tostring();qstringage=query.value(3).tostring();qstringcourse=q
12、uery.value(4).tostring();/qdebug()idnamesexagelabel_stuid-settext(qstring(%1).arg(id);ui-label_stuname-settext(qstring(%1).arg(name);ui-label_stusex-settext(qstring(%1).arg(sex);ui-label_stuage-settext(qstring(%1).arg(age);ui-label_stuclass-settext(qstring(%1).arg(course);if(flag=2)qstringid=ui-line
13、edit_refercondition-text();qsqlqueryquery;query.exec(qstring(selectid,name,sex,age,coursefromstudentwhereid=%1).arg(id);while(query.next()intid=query.value(0).toint();qstringname=query.value(1).tostring();qstringsex=query.value(2).tostring();qstringage=query.value(3).tostring();qstringcourse=query.v
14、alue(4).tostring();/qdebug()idnamesexagelabel_stuid-settext(qstring(%1).arg(id);ui-label_stuname-settext(qstring(%1).arg(name);ui-label_stusex-settext(qstring(%1).arg(sex);ui-label_stuage-settext(qstring(%1).arg(age);ui-label_stuclass-settext(qstring(%1).arg(course);程序中定义了标志量flag,当姓名查询被勾选时,flag=1,当学
15、号查询被勾选时,flag=2。3.3 学生信息修改和删除模块设计操作说明:首先输入相关学号,然后点击“确认”,如果有相关信息,则显示,如果没有,则提示没有相关信息。如果显示了相关信息,点击“删除信息”,则会删除此条信息;如若需要修改,在文本框中修改信息后,点击“保存修改”,则会保存修改后的信息。点击“返回”可返回菜单界面。点击“退出”可关闭界面,退出系统。删除例子:输入学号“2012442201”,点击“确认”,结果如图3.4所示;然后点击“删除信息”,提示删除成功!,结果如图3.5。然后再点击确认查询“2012442201”这条相关信息,此时提示没有相关信息,如图3.6所示。图 3.4图 3
16、.5图 3.6信息修改例子:输入学号“2012442202”,点击“确认”,结果如图3.7,然后将年龄修改为“22”,专业班级修改为“计算机科学与技术1201”,点击“保存修改”,如图3.8,提示修改成功。然后再点击“确认”,结果显示如图3.9,信息已经被成功修改。图 3.7图 3.8图 3.9具体程序设计如下:voidmodifyanddelete:on_pb_referok_clicked()intflag=0;qstringid=ui-lineedit_referid-text();qsqlqueryquery;query.exec(qstring(selectid,name,sex,a
17、ge,coursefromstudentwhereid=%1).arg(id);while(query.next()flag=1;intid=query.value(0).toint();qstringname=query.value(1).tostring();qstringsex=query.value(2).tostring();qstringage=query.value(3).tostring();qstringcourse=query.value(4).tostring();/qdebug()idnamesexagelineedit_mdid-settext(qstring(%1)
18、.arg(id);ui-lineedit_mdname-settext(qstring(%1).arg(name);ui-lineedit_mdsex-settext(qstring(%1).arg(sex);ui-lineedit_mdage-settext(qstring(%1).arg(age);ui-lineedit_mdcourse-settext(qstring(%1).arg(course);ui-label_mdflag-clear();if(flag=0)ui-label_mdflag-settext(qstring:fromutf8(没有相关信息!);voidmodifya
19、nddelete:on_pb_modideledelete_clicked()qstringid=ui-lineedit_mdid-text();qsqlqueryquery;query.exec(qstring(deletefromstudentwhereid=%1).arg(id);ui-lineedit_mdid-clear();ui-lineedit_mdname-clear();ui-lineedit_mdsex-clear();ui-lineedit_mdage-clear();ui-lineedit_mdcourse-clear();ui-label_mdflag-settext
20、(qstring:fromutf8(删除成功!);voidmodifyanddelete:on_pb_modidelesave_clicked()qstringid1=ui-lineedit_referid-text();qstringid=ui-lineedit_mdid-text();qstringname=ui-lineedit_mdname-text();qstringsex=ui-lineedit_mdsex-text();qstringage=ui-lineedit_mdage-text();qstringcourse=ui-lineedit_mdcourse-text();qsq
21、lqueryquery;if(id.toint()!=id1.toint()query.exec(qstring(deletefromstudentwhereid=%1).arg(id1);query.prepare(insertintostudent(id,name,sex,age,course)values(:id,:name,:sex,:age,:course);intidvalue=id.toint();qstringnamevalue=name;qstringsexvalue=sex;qstringagevalue=age;qstringcoursevalue=course;quer
22、y.bindvalue(:id,idvalue);query.bindvalue(:name,namevalue);query.bindvalue(:sex,sexvalue);query.bindvalue(:age,agevalue);query.bindvalue(:course,coursevalue);query.exec();ui-lineedit_mdid-clear();ui-lineedit_mdname-clear();ui-lineedit_mdsex-clear();ui-lineedit_mdage-clear();ui-lineedit_mdcourse-clear
23、();elsequery.exec(qstring(updatestudentsetname=%1,sex=%2,age=%3,course=%4whereid=%5).arg(name).arg(sex).arg(age).arg(course).arg(id1);ui-lineedit_mdid-clear();ui-lineedit_mdname-clear();ui-lineedit_mdsex-clear();ui-lineedit_mdage-clear();ui-lineedit_mdcourse-clear();ui-label_mdflag-settext(qstring:f
24、romutf8(修改成功!);信息修改功能有两种情况,一是学号没有修改,只需用update更新数据;另一个是学号被修改,那么首先先删除原来学号的相关信息,然后再用insert插入一条新的数据。3.4 添加学生信息模块设计操作说明:本模块具体实现信息插入,在文本框中输入需要插入的数据,然后点击“添加”。图 3.10 添加成功具体程序设计:voidadd:on_pb_addok_clicked()qstringid=ui-lineedit_addid-text();qstringname=ui-lineedit_addname-text();qstringsex=ui-lineedit_addse
25、x-text();qstringage=ui-lineedit_addage-text();qstringcourse=ui-lineedit_addcourse-text();qsqlqueryquery;query.prepare(insertintostudent(id,name,sex,age,course)values(:id,:name,:sex,:age,:course);intidvalue=id.toint();qstringnamevalue=name;qstringsexvalue=sex;qstringagevalue=age;qstringcoursevalue=co
26、urse;query.bindvalue(:id,idvalue);query.bindvalue(:name,namevalue);query.bindvalue(:sex,sexvalue);query.bindvalue(:age,agevalue);query.bindvalue(:course,coursevalue);query.exec();ui-label_flag-settext(qstring:fromutf8(添加成功!);voidadd:on_pb_addokgoon_clicked()ui-lineedit_addid-clear();ui-lineedit_addn
27、ame-clear();ui-lineedit_addsex-clear();ui-lineedit_addage-clear();ui-lineedit_addcourse-clear();ui-label_flag-clear();3.5 统计目前学生人数模块设计本模块实现统计当前系统学生人数,点击”统计”即可显示具体人数。图 3.11 统计具体程序设计:voidcount:on_pb_countok_clicked()intcount=0;qstringm;qsqlqueryquery;query.exec(select*fromstudent);while(query.next()count+;/qdebug()label_count-settext(qstring(%1).arg(count);4 功能模块的
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 二零二五年度大数据技术在智能制造中的应用合同4篇
- 2025年度炊事员岗位技能提升聘用标准合同4篇
- 二零二五版旅游度假村建设项目贷款合同4篇
- 2025年度橱柜维修保养服务合作协议4篇
- 二零二五年数字营销推广合作协议样本3篇
- 2025年度区块链技术方木交易合同4篇
- 2025年度美甲店美容师团队招聘与管理服务合同4篇
- 2025年度交通事故车辆维修进度与赔偿协议8篇
- 2025至2030年中国健康套装漆数据监测研究报告
- 2025年出租车公司员工承包经营协议4篇
- 割接方案的要点、难点及采取的相应措施
- 2025年副护士长竞聘演讲稿(3篇)
- 2025至2031年中国台式燃气灶行业投资前景及策略咨询研究报告
- 原发性肾病综合征护理
- (一模)株洲市2025届高三教学质量统一检测 英语试卷
- 第三章第一节《多变的天气》说课稿2023-2024学年人教版地理七年级上册
- 2025年中国电科集团春季招聘高频重点提升(共500题)附带答案详解
- 2025年度建筑施工现场安全管理合同2篇
- 建筑垃圾回收利用标准方案
- 2024年考研英语一阅读理解80篇解析
- 样板间合作协议
评论
0/150
提交评论