还剩13页未读,继续阅读
本资源只提供10页预览,全部文档请下载后查看!喜欢就下载吧,查找使用更方便
文本内容:
学生学号实验课成绩武汉理工大学学生实验报告书____________软件工程.实验课程名称计算机科学与技术学院开课学院指导顾志华老师姓名学生穆忙涛姓名学生专业计算机0705班级2010学年第二学期2009—Global.h#ifndef_GLOBAL_H/*please insure_GLOBAL_H unique*/#define_GLOBAL_H/*avoid quotationiterativly*/extern intLOGIN;//LOGIN为表示登陆,为表示未登陆extern intUSER;//USER表示用户类型,表示ADMIN,表示GUEST#endif声明了两个环境变量,LOGIN和USERGuest.h〃注册用户int Register_guestMYSQL*lpmysql,char*cardnum;〃登陆系统int Login_guestMYSQL*lpmysql,char*cardnum;//计数器加一int Increase_guestMYSQL*lpmysql,int guest_table;//存款int DepositMYSQL*lpmysql,char*cardnum;〃取款int DrawMYSQL*lpmsql,char*cardnum;//挂失int LossMYSQL*lpmysql,char*cardnum;〃注销int CloseMYSQL*lpmsql,char*cardnum;//转账int TranferMYSQL*lpmysql,char*cardnum;//获得当前的记录总数int GetCurrentNumMYSQL*lpmysql,int guest_table;声明了guest.c的函数,这些函数都是通过用扇输入操作数据库Mian.cmysql_init mysql;if!mysql_real_connectmysql;localhost\nroot\U23456\nbank\3306,NULL,0{//bank为你所创建的数据库,为端口号,可自行设定printf”数据库连接失败\nreturn FALSE;}elseprintf”数据库连接成功\n用来连接数据库的语句6测试和结果说明数居一忝左立就算创建萨一文成功忝力创建一功创建一功功库力创建记成功表成成用柏功表召功录记添成表录加成成表功录记笔济录成■户出■
1.初始化数据库
2.注册用户请遨举用户类型:、管理负I请输入您的账号密码<不多于10个字符>性别<x为男,y为女)如果你还没有哌号,请输入来新建一个客户账户newuudd23s.
1.111ttnnsuudd0oggaaeemmgwgssttinin.11Mogogi123456x您的账号是00001请选爱您的操作薮类脚型节请却请输入账・如果你有号请输入来新建一个客户账户nevi入请输珈成者陆您清选建弘存取装账户一款蜃如选至您富存成
3.用户登录操作
1.2,3-200121,B-3-
4.5,1100034156S.
4.数据库变化Guest表mysql select*from guest;I g_id!guest_nun!password!g_nane!g_sex■reg_date Imoney!debt!i0;00000i NULL;guest i NULL!NULL i4!NULL i!1i00001!123456i motto!x!2010-05-05084240!110i011!2!00002i245610!ning iy!2010-05-05084437!0;011!3i00003i12315i andyi x!2010-05-05084500!0!011!4i00004i suni lilongi x!2010-05-05084522;0!0115rows in set
0.00secGuest_log表:nysql select*from guest_log;---------------------------d卜----------------------------------------------------------------------------------------------4卜卜---------------------------------------d卜------------------------------.--------------------------------------------------------------------log.id11log_time1g_id11notion11entry!remark0NULL12NULL NULL I NULL12010-05-0508:42:401resiger NULL;NULL22010-05-0508:44:372resiger NULL!NULL32010-05-0508:45:003resiger NULLI NULL42010-05-0508:45:224resiger NULL!NULL52010-05-0508:45:381Login NULL!NULL62010-05-0508:47:441Login NULL!NULL72010-05-0508:54:461Login NULL!NULL82010-05-0508:54:501deposit50\NULL92010-05-0508:55:221draw20NULL102010-05-0509:01:111Login NULL!NULL112010-05-0509:14:281Login NULL!NULL2010-05-0509:14:35deposit100!NULL12---------□1b-------a卜卜卜------------------------------♦---------------------------------------13rows inset
0.00sec7实验的体会这次实验,通过软件工程的方法分析设计了简易银行卡管理系统,在此期间,不仅在技术上实践了数据库编程,更重要的是学会以一种严格的方法去管理软件开发的理念,模块化的编程思想以及高内聚低耦合的编程要点,不仅在系统分析时使系统的设计变得简单,在编码时,代码的设计、调试都变得十分清晰通过软件工程这门课,我学会了更好的编写代码、简易银行卡管理系统的开发1题目简易银行卡管理系统2功能描述分析、设计并实现一个银行卡管理系统,系统中有两类用户,普通用户和管理员用户,普通用户可以对自己的信息管理,而管理员用户则对所有的用户都可以进行管理对于普通用户,需要实现以下功能1开户2存款3取款4挂失⑸消户6转帐7查询操作历史对于管理员账户,需要实现的功能是1创建用户2删除用户3查看用户信息4更改用户信息要实现对用户账户的管理,就要用数据库保存用户的信息,登录时通过对用户账户和用户密码的验证,使用户获得相应的权限登陆后,用户可以根据提示选择相应的操作,以实现对账户的管理操作对账户的管理实际上是对用户信息数据的操作,数据的信息保存在数据库中,所以用户的操作实际上是对数据库的操作可以将用户的操作映射成以下的数据库操作普通用户操作开户向数据库中添加一条新纪录存款、取款、挂失修改数据库中的某些字段值销户删除一条记录查询操作历史对数据库的查询管理员操作创建用户添加一条记录删除用户删除一条记录查询用户信息查询数据库更改用户信息修改记录字段值3数据定义系统有两种用户,并且要保存用户的账户信息以及操作记录,所以用四个表来存储所有的信息,分别为guest,guest Jog,admin,adminjogoguest用来存储普通客户的账户信息guestJog用来保存用户的操作记录,以便于查询操作历史admin是管理员表,记录管理员的账户信息adminjog用来记录管理员操作的历史,以防管理员的错误操作普通用户的操作仅能涉及guest,guestjog两个表,而管理员可是管理所有的表各个表的定义如下guest字段名数据类型作用guest_id int客户的唯一标识符,逐渐guest_num char5用户登录的银行卡号,统一使用5位password varcharlO登录密码,不大于10位,可变长g_name varcharlO客户相关信息,客户姓名,g_sex charl客户性别,X表示男,y表示女账户注册时间reg_date datatime当前用户金额money IntDebtchar1用户账户状态,0正常,1挂失,2注销guest_Iog:字段名数据类型作用log_id int操作记录id,唯一标识一个操作事件事件发生的时间log_time datetimeg_id Int发生操作事件的用户idmotion varchar20所执行的操作类型操作涉及的金额entity int对操作的备注remark text管理员账户表和普通客户表的内容很类似,所以简化了一些,并且管理员账户没有账户金额等字段,所以相对较小admin:字段名数据类型作用管理员唯一的标志符admin_id Int管理员登录用户名admin_logName varcharlO登录密码password varcharlO性别,为男,为女sex char1x y注册日期reg_data datatimeadmin_log:字段名数据类型作用log_id int操作记录id,唯一标识一个操作事件事件发生的时间log_time datetimeadmin」oginN ameVarchar10执行操作的管理员账户名motion varchar20所执行的操作类型guest_num Char10操作涉及到的用户操作涉及的金额entity int对操作的备注remark text以上是四个表的数据定义,在此基础上,通过对数据库的操作,实现对用户信息的操作4总体设计和各模块接口说明系统总体可以分为三个模块:
1.Main主调用模块
2.Guest管理模块
3.Admin管理模块这单个模块的简单关系为Main模块是程序的入口,用户通过Main的操作,引导用户进入Guest模块或Admin模块,直到用户退出⑴Main模块Main模块是程序的入口,程序的初始化都在此模块,包括数据库的连接,数据库的初始化,全局变量的初始化等该模块定义了两个出口,即Guest和Admin,用户在该模块选择入口,已决定想要进行的操作,直到退出Main模块的数据库连接,将应用程序同DBMS连接起来,以使应用程序能够对数据库进行操作Main模块的数据库初始化,包括创建表,对表中数据的初始操作使应用程序在执行时可以获得必要的信息全局变量的初始化,包括登录状态、当前用户名等信息,使应用程序可以在操作时可以得到相应的环境变量Main模块提供了两个出口,分别指向Guest和Admin数据库链接数据库初始化全局变量初始化输入用户类//模块模块Guest Admin的盒形图MainGuest模块2Guest模块包含了对普通用户的所有操作,开户、存款、取款、挂失、消户、转帐和查询操作历史根据选择,执行不同的操作,每一个操作都是对数据库的操作guest guestjog盒形图(包括对数据库的操作)GuestAdmin模块3Admin模块的内容同Guest模块的内容类似,不过Admin模块的操作涉及到更多的数据表,admin和admin_logo5程序设计的说明程序设计包括两个部分的设计数据库设计和功能设计⑴数据库设计本程序采用MySQL数据库,为实现以上数据库设计,使用如下语句创建数据库〃创建guest表char guest[]=create tableguest\g_id INTAguest_num CHAR5,\password VARCHAR10Ag_name VARCHAR10,\⑴g_sex CHAR,reg_date DATETIME,\money SMALLINTAdebtCHAR1,\PRIMARY KEYg_id,guest_num\H;〃创建guest」og表char guest_log[]=create tableguest_log\logjd INTAlog_time DATETIMEAgjdINTAmotion VARCHAR20,\entry SMALLINTAremark TEXT,\PRIMARY KEYlog_id\;”〃仓ll建admin表char admin[]=ncreate tableadmin\admin_id1NT,\adminJoginName VARCHAR10,\password VARCHAR10,\sex CHAR1Areg_date DATETIME,\PRIMARY KEYadmin_id\;//仓II建admin」og表char admin_log[]=create tableadmin_log\logjd INT,\adminJoginName VARCHAR10,\log_time DATETIME,\motion VARCHAR20,\user_num CHAR5,\entry SMALLINTAremarkTEXT,PRIMARY KEYlog_id\H;在MySQL查看新建表,用describe tablename;结果如下:表guestinysql describeguest;!Field!Type iNull!Key!Default!Extra i!g_id!intll!NOPRI0!i!guestjum!char5!NO!PRI!NULL!ii password!uarchar10i¥ES!!NULL!;g_nane!uarchar10!VES!!NULL;i!g_sex!chard!VESI NULL!i!reg_date!datetine!VES!NULL!i!money!sinallint6!¥ES!!NULL\i!debt!chard!YES!NULL!i8rows inset
0.09sec表guestjog:nysql describeguest_log;―-+----------------------------------1Field1Type1Null1Key1Defaulta11i Extra_■—▲一一才一・・T-一Tlog_id1intll1NO1PRI101a1a11log_tine Jdatetime1YES1J NULL1g_id1intll aiYES11NULL1a111motion1uarchar20aiYES11NULL ai111entry1snallint6a YES11NULL aa1a11renark1text ii YES11NULL iia1a-+-------------+-6rovis inset
0.03sec表admin:nysql describeadnin;,_■_______________■_______■______■__________■________r▼V VvrExtra i1f1i adnin.id!intll!NOPRI!0;NULL!i adnin_loginNane iuarchar10i VES1ai passwordi varchar10i YESNULL!ai!sex;charl!VES NULL i aaiaNULLi reg_date idatetime iVES ai■-------------------------------・-----------------------・----------1I_____________________1L__________________________-A-______________________1i--------------------------------■-----------------------■-----------■---------■----------------■------------r5rows inset
0.02sec表admin_log:nysql describeadnin_log;+----------------------------------------------------------------------------------+-------------------------------------------------------------+-----------------------------+-------------------------+-------------------------------------------+----------------------------------4!Field!Type!Null Keyi Default1111Extra;1L____■--------------------------------------------------------------------------------------------------------■------------------------------------------------------------------------------------■------------------------------------1______________________1______________________1V V VV-P!log_id!intll!NO PRI!0i adin in_lo gin Namevarchar10i YES!NULLi l_tine!datetime!YES!NULL!motion iuarchar20!YES!NULLuser_nun!char5!YES!NULLentrysnallint6YES!NULLi renarki textYES!NULLr rowsinset
0.03sec为了给每一个新注册的用户分配号码,并且给每一条新的记录分配唯一的id值,因此需要一个计数的变量用来存储,表中记录的总量,所以在创建表的时候,初始添加一条记录,用来充当计数器的作用,添加记录的语句如下char first_record_guest[]=ninsert into\guestg_id,guest_num\,value0A!00000\nH;char first_record_guest」og[]=insert into\guest Joglog_id,g_id\value0,0n;char first_record_admin[]=insert into\adminadmin_id,admin」oginName\valueO,\nadmin\nH;char first_record_admin_log[]=insert into\admin_loglog_id,admin_loginName\valueO,\Hadmin\nn;-+-log_id11log_tine11g_id11notion11entry11remark一.一■A.一T0一NULL0NULL NULLNULL1111111111-+一mysql select*from guest.log;IAdmin:1row inset
0.00secnysql select*from admin;+------+-------------------+-----------+------------------+---------------------+!adnin_id!adnin_loginName!password!sex!reg_date;i0;admin iNULL!NULL!NULL!+------------------+-------------------------------+------------------+-----------+------------------+Admin_log:mysql select*from adnin_log;!log_id!adn in_lo gin Name!log_tine imotion Iuser_nun!entry;remark!0i adniniNULL!NULL!NULLiNULLINULL1row inset
0.03sec
(2)代码设计总共代码有10个文件,头文件有admin.h、common.h global.h guest.h stdafx.h.c文件有admin.CNcommon.c global.c guest.c main.c Stdafx.h,文件包含着整个工程所需要的资源文件global.h global.c中声明并定义了全局变量common.h,common.c中定义了常用的函数admin.h admin.c实现了所有Admin模块的操作guest.h guest.c实现了所有Guest模块的操作main.c实现了Main模块的内容。
个人认证
优秀文档
获得点赞 0