数据库系统原理课程设计平面设计公司业务管理系统.doc
《数据库系统原理课程设计平面设计公司业务管理系统.doc》由会员分享,可在线阅读,更多相关《数据库系统原理课程设计平面设计公司业务管理系统.doc(29页珍藏版)》请在咨信网上搜索。
数据库系统原理课程设计平面设计公司业务管理系统 <数据库系统原理>课程设计报告 -----平面设计公司业务管理系统 姓 名: 学 号: 指导教师: 起始时间: 截止时间: 目录 概述 2 第一章 需求分析 3 §1.1信息要求 3 第二章 结构设计 4 §2.1概念结构设计 4 §2.2逻辑结构设计 6 第三章 主要模块设计及代码 7 §3.1数据库连接模块 7 §3.2认证登录模块 9 §3.3查询显示模块 9 §3.4添加,修改,删除模块 12 第四章 总结 14 第五章 参考文献 15 概述 编写目的 本报告作为软件使用的重要指南,能够方便用户使用。同时,也是一份重要的技术文档,方便开发人员继续完善各项功能,更新软件。为了更好地管理平面设计公司的各项工作,撰写此文档。 项目背景 订单管理是每所公司或工厂必须面正确工作,大量的订单管理给企业带来了沉重的负担。传统人手方式管理文件档案,已经无法满足当前业务量的正常需求。这种管理方式存在许多缺点:效率低,保密性差,另外随着进货数量的增加,这必然增加了订单管理者的工作量和劳动强度。同时,将产生大量的文件和数据,这给订单信息的查找,更新和维护都带来了不少困难。管理机制已经不能适应时代发展的需求,其管理方法将浪费人力物力。随着科技的不断提高,计算机科学与技术日渐成熟,这种传统的手工管理模式必然被以计算机为物质基础的信息管理方式所取代。 软件定义 图形化界面:人性化的界面,方便了员工的使用,对操作员技术要求不高。 数据存取:系统地保存数据,能够加快数据处理,提高工作量。能够同时进行多人对数据的操作,保证数据存取不出错。 开发环境 在Windows XP SP3 操作系统下,使用Visual C++进行开发。数据存取使用SQL Server 平台。 第一章 需求分析 §1.1信息要求 经过软件,能够查看,添加,保存,修改,删除各种业务信息。如登录账户的信息,员工的信息,客户的信息,订单信息,送货单信息,历史单信息。 §1.2处理要求 软件要灵活实现各种管理功能间的切换,减少麻烦的操作。对于数据的修改,保证不会出错,确保数据的正确性。在必要的地方,给予一定的提示,以防止误操作导致的数据异常。 图 1.1 功能模块图 §1.3安全性与完整性要求 登录安全:采用用户名,密码方式登录系统。不同职工具有的使用权限不同,管理员拥有最高权限。其它员工根据职务需要规定所需权限。 完整性要求:对于一些必须的信息,不能留空值。如编号,名称,日期等信息 第二章 结构设计 §2.1概念结构设计 账户ID 职工编号 登录账户 用户名 密码 员工 职工编号 员工姓名 性别 月薪 职位 各实体E-R图: 图2.3 稿件 稿件编号 长度宽度 规格 色数 客户名称 输出机型 页数 单价 小计 稿件名称 图 2.2图2.1 历史单 送货单编号 编号 送货单 编号 订单编号 送货日期 图 2.4 客户 客户名称 公司地址 联系人 邮箱 传真 联系人电话 客户编号 联系业务员 图 2.5 订单 订单编号 业务员 客户名 设计员 下单日期 送货员 图 2.6 账户 职工 历史单 客户 订单 送货单 稿件 拥有 决定 制定 联系 生成 生成 §2.2逻辑结构设计 图2.7 实体联系图 图2.7 数据关系表 第三章 主要模块设计及代码 §3.1数据库连接模块 为连接模块独自建立一个类,方便每次访问数据库时能够调用。类命名为ADOConn。采用ADO技术实现程序与数据库的连接。 用#import语句来引用支持ADO的组件类型库(*.tlb),其中类型库能够作为可执行程序(DLL、EXE等)的一部分被定位在其自身程序中的附属资源里,如:被定位在msado15.dll的附属资源中,只需要直接用#import引用它既可。直接在Stdafx.h文件中加入下面语句来实现: #import "c:\programfiles\commonfiles\system\ado\msado15.dll" no_namespace rename ("EOF", "adoEOF") //实际上两行代码是在同一行显示,由于排版原因,分行显示// 以下为ADOConn类里重要成员函数的代码: //////////////////////////////////////////////////////////////////////////// //函数名称:ADOConn //功能:初始化COM环境 ///////////////////////////////////////////////////////////////////////////// void C ADOConn::ADOConn() { ::CoInitialize(NULL); try { pConn.CreateInstance("ADODB.Connection"); // 创立Connection对象 //设置字符连接字符串,必须是BSTR型或者_bstr_t类型 _bstr_t strConnect="Provider=SQLOLEDB.1;Integrated Security=SSPI;Persist Security Info=False;User ID=sa;Initial Catalog=DsnCompany;Data Source=BEN-PC;"; //连接数据库的代码语句 pConn->Open(strConnect,"","",adConnectUnspecified); } catch(_com_error e) //捕捉异常信息 { AfxMessageBox(e.ErrorMessage()); } } //////////////////////////////////////////////////////////////////////////// //名称:OpenRecordset //功能:打开记录集 ///////////////////////////////////////////////////////////////////////////// _RecordsetPtr& CDataSource::OpenRecordset(CString sql) { ASSERT(!sql.IsEmpty()); //判断是否为空集 try { pRs.CreateInstance("ADODB.Recordset"); // 创立Recordset对象 pRs->Open(_bstr_t(sql),_variant_t(pConn,true),adOpenStatic,adLockOptimistic,adCmdText); } catch(_com_error e) { AfxMessageBox(e.ErrorMessage()); } return pRs; } void CADOConn::FreeData() //释放空间 { if(pConn) { pConn->Close(); pRs.Release(); pConn.Release(); CoUninitialize(); } } §3.2认证登录模块 void CGraphicDsnDlg::OnOK() //确定按钮事件 { // TODO: Add extra validation here UpdateData(); CMainMngDlg dlg; CString sql="select * from LogUser where UserName="+m_strUsername+" and PassWord='"+m_strPassword+"' "; a.pRs=a.OpenRecordset(sql);//将记录加入到记录集 int n=a.pRs->RecordCount; //计算符合条目 if (n>0) { CDialog::OnOK(); //登陆成功 dlg.DoModal(); } else { ::AfxMessageBox("用户名或密码不正确!"); //登陆失败 return; } } §3.3查询显示模块 BOOL CTickets::OnInitDialog() //订单管理类初始化函数 { CDialog::OnInitDialog(); // TODO: Add extra initialization here cn.ADOConn(); //连接数据库 Display(); //设置列表框控件的扩展风格 //整行选择/有表格线/表头/单击激活 DWORD dwExStyle=LVS_EX_FULLROWSELECT|LVS_EX_GRIDLINES|LVS_EX_HEADERDRAGDROP|LVS_EX_ONECLICKACTIVATE; //报表风格/单行选择/高亮显示选择行 m_List.ModifyStyle(0,LVS_REPORT|LVS_SINGLESEL|LVS_SHOWSELALWAYS); m_List.SetExtendedStyle(dwExStyle); //设置列表框控件的颜色 // m_List.SetTextColor(RGB(200,200,0)); // m_List.SetBkColor(RGB(240,247,233)); //初始化列表,插入11列 m_ListDoc.InsertColumn(0,"",LVCFMT_CENTER,0,0); m_ListDoc.InsertColumn(1,"稿件名称",LVCFMT_CENTER,120,0); m_ListDoc.InsertColumn(2,"长度*宽度",LVCFMT_CENTER,90,0); m_ListDoc.InsertColumn(3,"规格",LVCFMT_CENTER,65,0); m_ListDoc.InsertColumn(4,"色数",LVCFMT_CENTER,65,0); m_ListDoc.InsertColumn(5,"规格",LVCFMT_CENTER,65,0); m_ListDoc.InsertColumn(7,"输出机型",LVCFMT_CENTER,90,0); m_ListDoc.InsertColumn(8,"页数",LVCFMT_CENTER,65,0); m_ListDoc.InsertColumn(9,"单价",LVCFMT_CENTER,70,0); m_ListDoc.InsertColumn(10,"小计",LVCFMT_CENTER,80,0); m_ListDoc.InsertColumn(11,"客户名称",LVCFMT_CENTER,137,0); return TRUE; // return TRUE unless you set the focus to a control // EXCEPTION: OCX Property Pages should return FALSE return TRUE; // return TRUE unless you set the focus to a control // EXCEPTION: OCX Property Pages should return FALSE } void CTicketsMngDlg::Show() //输出单据信息到列表控件框 { CString DocName; int index=m_oddno.GetCurSel(); if (index==CB_ERR) { AfxMessageBox(_T("出错!")); return; } m_oddno.GetLBText(index,coursename); CString s="select * from Documents where DocName='"+DocName+"'"; a.pRs=a.OpenRecordset(s); //把数据加到记录集 UpdateData(); CString sql="select * from Documents where CustomerName='"+CustomerName+"'"; a.pRs=a.OpenRecordset(sql); //打开数据到记录集 _variant_t DocNo,DocName,Length,Format,Color,OutputMacMac,Pagess,Price,,CustomerName; //定义列表名变量 int i=0; a.pRs=a.OpenRecordset(s); int nIndex=m_List.GetItemCount(); LV_ITEM lvItem; lvItem.mask=LVIF_TEXT; lvItem.iItem=nIndex; lvItem.iSubItem=0; //第nIndex行 lvItem.pszText=(char*)(LPCTSTR)DocName1; //第一列参数 for (a.pRs->MoveFirst();!a.pRs->adoEOF;a.pRs->MoveNext()) { m_List.InsertItem(&lvItem); DocName=a.pRs->GetCollect("DocName"); //取数据 Length=a.pRs->GetCollect("Length"); Format=a.pRs->GetCollect("Format"); Color=a.pRs->GetCollect("Color"); Pages=a.pRs->GetCollect("Pages"); Price=a.pRs->GetCollect("Price"); Subtotal=a.pRs->GetCollect("Subtotal"); Color=a.pRs->GetCollect("Color"); design=a.pRs->GetCollect("design"); CustomerName=a.pRs->GetCollect("CustomerName"); OutputMac=a.pRs->GetCollect("OutputMac"); DocName.ChangeType(VT_BSTR); //改变类型 Length.ChangeType(VT_BSTR); Format.ChangeType(VT_BSTR); Color.ChangeType(VT_BSTR); Pages.ChangeType(VT_BSTR); Price.ChangeType(VT_BSTR); Subtotal.ChangeType(VT_BSTR); Color.ChangeType(VT_BSTR); CustomerName.ChangeType(VT_BSTR); OutputMac.ChangeType(VT_BSTR); DocName=DocName.bstrVal; //调用bstrval Length=Length.bstrVal; Format=Format.bstrVal; Color=Color.bstrVal; OutputMac1=OutputMac.bstrVal; Pages=Pages.bstrVal; Price=Price.bstrVal; Color=Color.bstrVal; CustomerName=CustomerName.bstrVal; } } §3.4添加,修改,删除模块: // 打开修改订单 void CTicketsManDlg::OnItemmanButton() { // TODO: Add your control notification handler code here UpdateData(TRUE); if (m_Adodc.GetRecordset().GetEof()) { MessageBox("请选择要修改的订单"); return; } // 设置ListItemManDlg对话框中的变量 CListItemManDlg dlg; dlg.cRegId = m_Datagrid.GetItem(0); // 打开ListItemManDlg对话框 if (dlg.DoModal() == IDOK) RefreshData(); else RefreshData(); } //删除订单 void CTicketsManDlg::OnDelButton() { // TODO: Add your control notification handler code here UpdateData(TRUE); if (m_Adodc.GetRecordset().GetEof()) { MessageBox("请选择要删除的订单!"); return; } if (MessageBox("是否删除当前记录?","请确认", MB_YESNO + MB_ICONQUESTION) == IDYES) { CTickets reg; reg.SqlDelete(m_Datagrid.GetItem(0)); RefreshData(); } } 第四章 总结 经过本次设计,初步掌握了经过Visual C++ 中的MFC功能实现程序的开发。Visual C++提供了大量的控件功能,方便初学者设计程序。阅读了大量的C++编程的相关书籍,对这次设计起到了很大的帮助。特别是C++语言不熟悉的地方,经过阅读,加深了理解。对于面向对象编程有了更深切的理解。模块化的代码,增加了程序的可移植性。 熟悉了程序经过API来与SQL数据库连接的代码。多种数据库连接技术各有各的优缺点。对于初学者,ADO技术相对简单一点,因为查询语句是能够直接经过函数使用的。这对于熟悉数据库操作的人是很方便的。 在本次试验中,也遇到了各种各样的问题: 由于MFC编程是经过控件的方法生成类代码,因此一个类添加完后,不能继续对其重命名,相关的变量,函数名的改变,将很容易使程序出错。导致编译无法经过,排解问题比较困难。 因此,无论是对数据库的设计,还是程序的设计,都需要先做全局考虑以减少不必要的出错。 在这一点看了,需求分析就显得很重要。它直接明确了设计的目标,要求,使得设计进度大大加快。 由于个人经验跟技术的不足,在开发的过程中遇到困难是很正常的。鉴于此原因,必须要对某些问题进行讨论,或请教别人。有时,请教别人的效率很高的,如果自己苦苦地看书,也不一定能完全解决问题。要勇于提问,积极交流,才能做出好的程序。 第五章 参考文献 <程序设计基础—C++> <数据库系统概论> <Visual C++ 权威剖析> <Visual C++ 数据库通用模块> <Visual C++ SQLServer应用实例>- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据库 系统 原理 课程设计 平面设计 公司 业务 管理
咨信网温馨提示:
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【w****g】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【w****g】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【w****g】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【w****g】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
关于本文