CSDN论坛 > Delphi > 数据库相关

如何利用delphi开发b/s办公自动化应用程序 [问题点数:0分]

Bbs1
本版专家分:10
结帖率 100%
CSDN今日推荐
Bbs2
本版专家分:278
Bbs7
本版专家分:10576
Bbs2
本版专家分:419
匿名用户不能发表回复!
其他相关推荐
Delphi开发B.S数据库应用系统教程
第一部分Delphi 基础必读 第一章Delphi 快速入门 ⋯ (3) 一、选择 Delphi 的理由 (3) 二、安装 Delph& (3) 三、Delphi 的 IDE 环境 (4) 四、Delphi 的基本语法 (6) 五、设计简单的应用程序 (12) 第二章 Delphi 组件 (14) 一、常用的文本相关部件 (14) 二、按钮和检查框部件 (16) 三、分组、分界部件 (17) 四、图形、图像部件 (17) 五、关系图、文件列表部件 (18) 六、滚动部件 (19) 七、网格、表格部件 (19) 八、多媒体(MultiMedia)和 OLE 部件 (20) 九、非可视部件 (20) 第三章 Delphi 语句和程序结构 (24) 一、Delphi 的基本语句 (24) 二、Delphi 的程序结构 (29) 三、过程和函数 (31) 四、定义新的数据类型 (36) 五、Object Pascal 的库单元 Uni4 (39) 六、Delphi 的对象编程 (42) 第四章 Delphi 函数、命令和常用属性 (50) 第二部分数据库知识必备 第五章 SQL 基本知识 (61) 一、查询语句 (61) 二、修改语句 (67) 三、插入语句 (74) 四、删除表 (76) 五、删除表中数据 (77) 六、创建新表 ⋯ (77) 第六章 Delphi 数据组件及应用 (84) 一、数据组件 (84) 二、Delphi 数据通道 (86) 第三部分Delphi 开发B/S 应用系统 第七章 IntraWeb 基础 (91) 一、IntraWeb 简介 (91) 二、安装和卸载 IntraWe5 (91) 三、IntraWeb 开发模式 (92) 四、创建一个简单的应用程序 (93) 五、IntraWeb 应用系统的组成 (94) 第八章 B/S 开发平台构建 (97) 一、环境搭建 (97) 二、基础组件和基本方法 (97) 三、建立 B/S 应用工程 (98) 四、界面加工 (98) 五、报表预览与打印 (99) 第九章 IntraWeb 开发技巧 (100) 一、自动连接数据库 (100) 二、文件上传 (101) 三、文件下载 (101) 四、数据库图形字段和独立图形文件互转 (102) 五、查询结果集数据写入 EXCE? (102) 六、自动操纵 WORD 文档 (104) 七、表现已经制作好的 HTML 文件 (106) 八、根据数据库中内容动态生成 HTML 文件 (107) 九、基于继承的开发方法 (109) 十、树的建立和响应 (112) 十一、建立动态帮助系统 (116) 十二、协调系统结束程序 (118) 十三、播放 FLASH 文件 (119) 十四、IWDBGrid 的用法 (120) 十五、备份数据库 (124) 十六、恢复数据库 (126) 十七、用基于事物的编程技术实现系统初始化 (128) 十八、将数字转换成财务大写 (129) 十九、生成汉字助记码 (131) 第十章 Delphi 开发实用技巧集锦 (133) 一、Delphi 判断数据库某个表是否存在 (133) 二、生成一个新的数据表 (133) 三、根据日期直接取到年月日 (133) 四、字符串常用函数 (134) 五、将数据取整型(舍掉小数位置# (134) 六、将数据 D 保留 N 位小数(四舍五入# (134) 七、检查用户输入的字符型日期是否正确 (135) 八、DBGrid 中按回车移动到下一字段 (137) 九、Edit 框中只允许输入数字或小数点 (137) 十、去除 FastReport 打印的报表的注册标记 (137) 十一、调用外部文件 (137) 十二、判断光驱的盘符(方法一# (138) 十三、判断光驱的盘符(方法二# (139) 十四、检测本机是否安装 SQL Server200A (139) 十五、如何自动安装数据库 (140) 十六、取 Windows 的安装目录 (141) 十七、目录操作 (141) 十八、判断您的上网类型 (141) 十九、判断鼠标按键 (142) 二十、设置窗体最大显示 (142) 二十一、将 IP 地址转换成域名 (142) 二十二、解析服务器 IP 地址 (143) 第四部分B/S 应用实例 第十一章 页面设计 (147) 一、登陆页面设计 (147) 二、基础页面设计 (151) 三、主页面窗口设计 (159) 第十二章 公共信息管理 (163) 一、手机区域查询 (163) 二、IP 地址区域查询 (165) 三、万年历查询 (167) 四、行政区划与长途区号查询 (184) 五、常用电话管理 (187) 六、常用网址管理 (191) 七、规章制度管理 (196) 第十三章 个人办公管理 (201) 一、填写工作计划 (201) 二、待办事宜查询 (205) 三、个人私有电话及名片夹管理 (210) 四、更改个人密码 (215) 第十四章 公告管理 (218) 一、正向查询公告 (218) 二、反向查询公告 (220) 三、发布公告 (222) 四、历史公告查询 (223) 五、历史公告维护 (225) 六、在线公告维护 (227) 第十五章 内部电子邮件系统 (231) 一、撰写新邮件 (231) 二、设计邮件系统收件箱 (233) 三、设计邮件系统发件箱 (237) 四、设计邮件系统回收站 (239) 第十六章 收发文系统设计 (243) 一、收文查询 (243) 二、收文数据维护 (245) 三、发文查询 (250) 四、发文数据维护 (252) 第十七章 学习园地系统设计 (259) 一、定义学习园地栏目 (259) 二、学习资料装入 (263) 三、学习资料查询 (268) 第十八章 资产管理系统设计 (274) 一、固定资产管理 (274) 二、车辆管理 (279)
ArcGIS 实现B/S业务开发平台搭建
ArcGIS 实现B/S业务开发平台搭建一、架构图     参考: 理解arcgis server 10.1及其架构    https://blog.csdn.net/wiiwei/article/details/46430067二、ArcGIS Desktop 软件安装    OS :  Windows 10    SW :  ArcGIS Desktop 10.5    安装参考: ArcGI...
【web开发原理】B/S架构原理分析
Web的工作原理 1.工作过程:如下图所示描述了Web的工作原理。   (1) 用户打开计算机(客户机),启动浏览器程序,并在浏览器中指定一个URL(Uniform Resource Locator,统一资源定位器),浏览器便向该URL所指向的Web服务器发出请求。 (2) Web服务器接到浏览器的请求后,把URL转换成页面所在服务器上的文件路径名。 (3) 如果URL指向的是普通的
ERP之软件体系架构-深入理解B/S结构应用程序
随着学习的深入,和编程经验的丰富,对BS应用程序有一些认识。     在一些讨论软件技术的QQ群里,或一些社区、BBS中,经常会有一些初学者会犯一些认知性的错误。比如经常会有一些朋友提这样的一些问题:“我怎么在ASP中调用我写的这个JavaScript函数啊?”或者说“我怎么在JavaScript中调用我DAL层读取数据的方法啊?”     对于这些问题,说实话,我也犯过,
Delphi编写数据库程序要点
Delphi是著名的Borland公司开发的可视化软件开发工具。有这样一句话最为经典、贴切的描述了Delphi——“真正的程序员用C,聪明的程序员用Delphi”。很多人把Delphi称为是第四代编程语言,它具有简单、高效、功能强大等特点。和Visual C++比较,Delphi更简单、更易于学习掌握,而在功能上却毫不逊色;和Visual Basic相比,Delphi则功能更强大、更实用。可以说,
intraweb7.2.10 For D7
delphi开发B/S结构的可视控件
VS2010创建基于C/S的三层架构模型
在VS2010 环境下创建基于C/S架构的三层模型:   基础知识准备:      三层:UI、BLL、DAL 另加数据模型Model      Winform 作为UI界面。   1、 创建空的解决方案        新建-项目-其他项目类型-Visual Studio 解决方案-空白解决方案        取一个好听的名字。。。。确定~ 2、创建UI层       右键 解
数据库课程设计(基于B/S)
课程设计任务书 题目名称 数据库原理及设计课程设计 学生学院 经济管理学院 专业班级 06级电子商务5班 姓 名 麦少柠 学 号 3206005737 一、课程设计的内容 本课程设计要采用本课程中学习的数据库设计方法,运用其基本思路与主要图表工具完成"企业报刊订阅管理系统"数据库应用系统。完成信息需求分析与数据库的概念设计、逻辑设计、物理设计以及处理功能设计,用SQL Sever的数据库管理系统、JSP开发工具实现该系统,并运行、评价、改进之;在此基础上严格按课程设计教学大纲所附报告提纲撰写课程设计报告。通过本课程设计进一步弄懂数据库系统及其相关的基本概念,理解数据库系统的系统结构、主要特点,掌握数据库设计的原理、方法及其基本过程,初步具备数据库应用设计的能力,初步形成运用数据库应用系统解决管理决策中的实际问题的基本素质。 二、课程设计的要求与数据 要求学生结合所学管理知识,在借鉴课堂教学案例、了解家人或亲友所从事的业务及其流程的基础上,参考有关资料,选择自己了解的一项业务,运用课堂所学数据库系统与数据库设计知识,完成信息需求分析、数据库概念设计、逻辑设计、物理设计,实现完成该业务的数据库应用系统,并运行、评价改进之,最后要写出课程设计报告。 三、课程设计应完成的工作 要求学生按照《数据库应用课程设计》教学大纲完成一个数据库应用系统,并撰写相应的课程设计报告,主要内容包括: 概述:系统的基本任务,主要业务,开发目标 1. 需求分析 2. (数据库)概念(模型)设计 3. (数据库)逻辑(模型)设计 4. 数据库物理设计与数据库保护设计 5. 处理功能设计 6. 数据库应用系统的实现 7. 数据库应用系统运行 四、课程设计进程安排 序号 设计各阶段内容 地点 起止日期 五、应收集的资料及主要参考文献 [1] 王 珊、陈 虹编著,数据库系统原理教程,清华大学出版社,2003. [1] 金银秋主编,数据库原理与设计,科学出版社,2000. [2] 李建中 王珊,数据库系统原理,电子工业出版社,1998. [3] 李大友,数据库原理及应用(第二版),清华大学出版社,2000 发出任务书日期: 年 月 日 指导教师签名: 计划完成日期: 年 月 日 基层教学单位责任人签章: 主管院长签章: 目录 概述 …………………………………………………………………4 1. 需求分析…………………………………………………………4 1.1用户需求……………………………………………………………………4 1.2业务流程分析………………………………………………………………4 1.3信息需求分析………………………………………………………………5 1.4功能需求分析………………………………………………………………6 2. (数据库)概念(模型)设计…………………………………7 3. (数据库)逻辑(模型)设计…………………………………9 3.1 一般逻辑模型设计…………………………………………………………9 3.2 具体逻辑模型设计…………………………………………………………9 4. 数据库物理设计与数据库保护设计…………………………10 4.1设计索引……………………………………………………………………10 4.2 设计表间关系………………………………………………………………10 4.3完整性设计…………………………………………………………………10 5. 处理功能设计…………………………………………………11 6. 数据库应用系统的实现………………………………………11 7. 数据库应用系统运行…………………………………………11 7.1 写出系统操作使用的简要说明……………………………………………11 7.2 系统实施过程………………………………………………………………11 7.3系统使用结果………………………………………………………………22 7.4系统评价……………………………………………………………………31 企业报刊订阅管理系统 概述 随着社会不断的发展,人们的生活水平越来越高,对知识的和对时事的渴求也越来越高,人们希望能够方便快捷地订阅各种报刊杂志。但是各种各样的报刊名目和详细信息以及订阅,为相关企业的管理造成很大的麻烦。因此网上订阅成为不可或缺的一部分。 本系统就是面向一个企业的报刊订阅管理系统。此系统是一种比较智能化的管理系统,它面向所有企业部门的职工用户,但具有比较高的安全性能。它能够实现报刊订阅的基本功能,包括新报刊信息的录入、订阅、查询等操作以及后台数据库的备份和恢复。用户合法注册后必须输入有效密码才能成功进入此系统,可以进行订阅报刊,查询信息,统计信息等操作。对于非法操作,系统有识别和防护措施。 1. 需求分析 1.1 用户需求: 本系统就是面向一个企业的报刊订阅管理系统。此系统是一种比较智能化的管理系统,它面向所有企业部门的职工用户,但具有比较高的安全性能。它能够实现报刊订阅的基本功能,包括新报刊信息的录入、订阅、查询等操作以及后台数据库的备份和恢复。用户合法注册后必须输入有效密码才能成功进入此系统,可以进行订阅报刊,查询信息,统计信息等操作。对于非法操作,系统有识别和防护措施。 订阅信息处理的特点是订阅信息处理量比较大,所管理的信息信息种类繁多,而且订阅单、编辑单的发生量特别大,关联信息多,查询和统计的方式各不相同。因此在管理上实现起来有一定因难。 本系统在设计过程中,为了克服这些困难,需要使程序代码标准化,软件统一化,确保软件的可维护性和实用性;删除不必要的管理冗余,实现管理规范化、科学化;界面友好、简单化,做到实用、方便,尽量满足报刊订阅中员工的需要。 1.2 业务流程分析: 本系统主要面向的用户有系统管理员、读者。下面分角色对该系统的不同操作范围做说明。 本系统主要有以下功能模块: (1)登陆功能:登陆系统为身份验证登录。分为管理员登录和一般用户登录。分别通过不同的用户名和密码进入报刊订阅管理界面,新的用户需要注册。 (2)录入新信息功能:对于管理员,包括新用户信息和新报刊信息的录入功能,信息一旦提交就存入到后台数据库中;普通用户自行注册进行可以修改个人信息。 (3)订阅功能:用户可以订阅报刊,系统自动计算所需金额,并显示在界面上;管理员不可订阅报刊,必须以用户身份订阅报刊。 (4)查询功能:用户可以查询并显示自己所订阅的信息;管理员可以按人员、报刊、部门分类查询。查询出的信息显示在界面上,并且可以预览和打印出结果。 (5)统计功能:管理员可以按用户、部门、报刊统计报刊的销售情况,并对一些重要的订阅信息进行统计;普通用户可以统计出自己的订阅情况,并且可以预览和打印出结果。 (6)系统维护功能:数据的安全管理,主要是依靠管理员对数据库里的信息进行备份和恢复,数据库备份后,如果出了什么意外可以恢复数据库到当时备份的状态,这提高了系统和数据的安全性,有利于系统的维护。 下图为该系统的业务流程图 1.3 信息需求分析 1.3.1 资料收集:业务流程中用到的相关单据主要是报刊信息还有订单信息 报刊信息表: 报刊代号 46-250 报刊名称 IT时代周刊 出版报社 科技出版社 出版周期 半月刊 每月定价 10.00 元/月 分类编号 1001 报刊介绍 《IT时代周刊》是一本深刻解读信息时代商业变革的杂志。除深度报道信息产业的重大新闻外,还报道金融、汽车、股市、零售等传统行业利用IT提升商业与管理的新闻。《IT时代周刊》以调查见深度;以商业故事见功力。是CEO/CIO/CFO以及政府官员、商业领袖首选刊物。 订单信息表: 订单编号 报刊代号 用户编号 订阅日期 订阅月数 份数 操作 3003 46-205 3206 2008-7-1 订一月 1 取消订阅 3004 26-306 3108 2008-7-8 订半年 2 取消订阅 3005 72-310 3100 2008-7-9 订一年 1 取消订阅 3006 45-214 2541 2008-7-10 订一季 1 取消订阅 1.3.2 事项分析:根据以上资料中标题、表头等中各栏目名,可以得出相关事项,作为数据项;分析这些数据项,找出组合项、导出项、非结构化数据项,确定基本项。检查是否有要补充的基本数据项,是否有要改进的地方,补充改进之,得出所有基本项。 1.4 功能需求分析: 本系统的主要结构功能图如下: 2. (数据库)概念(模型)设计 基本项构思ERD的四条基本原则: ①原则1 (确定实体):能独立存在的事物,例如人、物、事、地、团体、机构、活动、事项等等,在其有多个由基本项描述的特性需要关注时,就应把它作为实体。 ②原则2 (确定联系):两个或多个实体间的关联与结合,如主管,从属,组成,占有,作用,配合,协同等等,当需要予以关注时,应作为联系。实体间的联系可分为一对一、一对多、多对多等三类,在确定联系时还要确定其类型。 ③原则3 (确定属性):实体的属性是实体的本质特征。实体应有标识属性(能把不同个体区分开来的属性组),并指定其中一个作为主标识。联系的属性是联系的结果或状态。 ④原则4(一事一地):信息分析中得到的基本项要在且仅在实体联系图中的一个地方作为属性出现。 经过上述系统功能分析和需求总结,设计如下面所示的数据项和数据结构。 管理员表(Adminuser):用于存放管理员的数据记录,包括数据项:管理员名、密码。 部门表(Department):用来存放部门的相关记录,包括数据项:部门号,部门名。 用户表(Users):用于存放注册用户的记录,包括数据项:用户账号、密码、真实姓名、身份证号、联系电话,联系地址,部门号(和部门表有关)等。 报刊类别表(NewspaperClass):用于存放初始的报刊类别记录,包括数据项:分类编号、分类名称。 报刊信息表(Newspaper):用于存放报刊记录,包括数据项:报刊代号、报刊名称、出版报社、出版周期、季度报价、内容介绍、分类编号(和报刊类别表有关)等。 订单表(Order):用于存放用户下达的订阅报刊的基本信息,包括数据项:订单编号、用户编号(用户表的主码)、报刊代号(报刊信息表的主码)、订阅份数、订阅月数等。 根据上面的设计规划出来的实体有部门实体、管理员实体、用户实体、报刊类别实体、报刊信息实体和订单实体。 部门实体的E-R图如下图所示: 管理员实体的E-R图如下图所示: 用户实体的E-R图如下图所示: 报刊信息实体的E-R图如下图所示: 订单实体的E-R图如下图所示: 报刊类别实体的E-R图如下图所示: 所有实体之间的的关系E-R图如下图所示: 3. (数据库)逻辑(模型)设计 3.1 一般逻辑模型设计: 关系模型的逻辑结构是一组关系模式的集合。将E-R图转换为关系模型就是要将实体型、实体的属性和实体型之间的联系转换为关系模式。 由ERD导出一般关系模型的四条原则; ①一个1:1联系可以转换为一个独立的关系模式,也可以与任意一端对应的关系模式合并。如果软换为一个独立的关系模式,则与该联系相连的各实体的码以及联系本身的属性均转换为关系的属性,每个实体的码均是该关系的候选码。如果与某一端实体对应的关系模式何明,则需要在该关系模式的属性中加入另一个关系模式的码和联系本身的属性。 ②一个1:n联系可以转换为一个独立的关系模式,也可以与n端对应的关系模式合并。如果转换为一个独立的关系模式,则与该联系相连的各实体的码以及联系本身的属性均转换为关系的属性,而关系的码为n端实体的码。 ③一个m:n联系转换为一个关系模式。与该联系相连的各实体的码以及联系本身的属性均转换为关系的属性,各实体的码组成关系的码或关系码的一部分。 ④3个或3个以上实体间的一个多元联系可以转换为一个关系模式。与该多元联系项链呢的各实体的码以及联系本身的属性均转换为关系的属性,各实体的码组成关系的码或关系码的一部分。 根据以上原则将E-R图转换成的关系模式如下: 部门(部门号,部门名称) 用户(用户账号,密码,用户真实姓名,联系电话,联系地址,部门号) 管理员(管理员名,密码) 报刊类别(分类编号,分类名称) 报刊(报刊代号,报刊名称,出版报社,出版周期,每月订价,内容介绍,分类编号) 订单(用户编号,报刊代号,订阅份数,订阅月数,订阅总额) 3.2 具体逻辑模型设计: 在SQL Server2000数据库中,首先创建newspaper数据库,然后根据数据库的逻辑结构分析创建表4-1━4-6的6张数据表。在前台访问数据库阶段设置了用户和密码,用户为sa,密码为空。 表4-2 department部门表结构 字段名称 字段类型 允许空 说明 depNumber(主码) Char(10) 否 部门号 depName Char(50) 是 部门名称 表4-3 users用户表结构 字段名称 字段类型 允许空 说明 userNo(主码) Char(10) 否 用户帐号 userName Char(20) 是 真实姓名 passWord Char(10) 否 用户密码 address Char(150) 是 用户联系地址 phone Char(20) 是 用户联系电话 depNumber Char(10) 否 用户所属部门号 表4-3 newspaperClass报刊分类表结构 字段名称 字段类型 允许空 说明 classid(主码) Int(4) 否 报刊分类编号 className Char(30) 是 报刊分类名称 表4-4 newspaper报刊表结构 字段名称 字段类型 允许空 说明 newsNo(主码) Char(10) 否 报刊代号 newsName Char(40) 否 报刊名称 classid Int(4) 否 报刊分类编号 publish Char(150) 是 出版报社 pubPeriod Char(30) 是 出版周期 content Char(4000) 是 内容介绍 price Float(8) 否 每月报价 表-6 book订单表结构 字段名称 字段类型 允许空 说明 userNo(主码) Char(10) 否 用户帐号 newsNo(主码) Char(10) 否 报刊代号 orderAmount Int(4) 否 订阅份数 orderMonth Int(4) 否 订阅月数 totalPrice Float(8) 是 订阅总额 表4-1 adminuser管理员表结构 字段名称 字段类型 允许空 说明 adminUser(主码) Char(20) 否 管理员用户名 adminPass Char(10) 否 管理员密码 4. 数据库物理设计与数据库保护设计 4.1设计索引:我们可以在最经常查询的列上建立索引以提高查询效率。 而在这个系统中,我们经常要按用户账号,按报刊代号,按部门查询,所以,我们可以为这三个表建立索引,建立所以的SQL语句如下,这几个都是字符型 Create unique index userNum on users(userNo) Create unique index departNum on department(depNumber) Create unique index newsNum on newspaper(newsNO) 4.2 设计表间关系: 4.3完整性设计列出主要字段完整性的字段名、完整性约束条件;列出记录完整性约束及其约束条件;列出参照完整性表。 主要字段的完整性字段名和参照完整性表可以参照上图各个表之间的关系来看。 比如建立报刊表newspaper时,要求报刊代号在100~99999之间,报刊名称和每月定价不能取空值,报刊类别是报刊类别表的主键,则 Create table user (userNo char(10) constraint C1 check(newsNo between 100 and 99999), newsName char(40) constraint C2 not null, classid int(4) constraint C3 not null, publish char(150),pubPeriod char(30),content char(4000), price float(8) not null, constraint C4 foreign key(classid) references newspaperclass(classid) ) 4.4在有多个用户操作时,考虑用户授权与安全性控制。 因为这个报刊订阅系统由多个用户使用,分为管理员和用户,他们拥有不同的权限和安全性控制。所以在权限设置方面,采用管理员和用户分别使用用户名和密码进入他们能使用权限范围里的界面。管理员登陆系统后,可以添加、修改用户和报刊的信息,可以对订单进行查询和统计,并且可以把查询统计的结果进行预览和打印出来,还要对数据库系统进行维护,适时备份数据库,一旦数据库遇到问题,可以恢复到最近备份的状态,减少不必要的损失。 用户登录,用户使用该系统前需要进行注册,他应该是该企业某个部门下面的员工,所以他需要输入他的部门号等信息,注册成功后,登录到系统,可以修改自己的信息还有订阅报刊,但由于权限的限制,他只能查看和统计自己的订单信息。 5. 处理功能设计 5.1 主控模块设计: 使用本系统,首先它会自动弹出"欢迎使用本系统"的欢迎界面,然后跳转到用户身份验证界面,选择管理员的身份进入,有录入(录入报刊信息、录入用户信息),查询,统计(统计用户、统计、报刊订单),系统维护(备份数据库、恢复数据库),注销,退出等菜单可使用,没注册的用户可进入注册界面进行注册,然后返回登录界面登录,进入后有欢迎界面,有订阅、查询、统计、修改、注销、退出等菜单可使用。 6. 数据库应用系统的实现 6.1 数据库及其表结构的建立:按照上面的逻辑分析见表 6.2数据输入:在建好的各个表中输入数据,要符合数据的约束条件 7. 数据库应用系统运行 7.1 写出系统操作使用的简要说明 本系统的运行需要安装PowerBuilder9.0和SQL Server2000软件。操作该系统,首先把备份的数据库还原出来,导入SQL Server中,然后打开该系统,连接上还原出来的数据库,再运行,就可以了。 7.2 系统实施过程 (1)打开PowerBuilder,新建一个工作区,命名为newspaper (2)新建一个Application,取名newspaper,然后点击工具栏上的DB Profile,新建一个MSS Microsoft SQL Server,填入Profile Name,服务器名,用户名,密码,数据库,如下图,然后输入连接数据库的主要代码: open(w_welcome) // Profile newspaper SQLCA.DBMS = "MSS Microsoft SQL Server" SQLCA.Database = "newspaper" SQLCA.ServerName = "CHINA-41CD782EF" SQLCA.LogId = "sa" SQLCA.LogPass="" SQLCA.AutoCommit = False SQLCA.DBParm = "" connect; if sqlca.sqlcode<>0 then messagebox("错误","数据库连接错误,程序将关闭!",stopsign!) return end if close(w_welcome) open(w_login) (3)制作登录页面w_login,在"确定"按钮输入如下: "注册"按钮代码:open(w_register) //打开用户注册页面 "退出"按钮代码:close(w_login) //退出本系统 (4)制作注册窗口w_register,在"注册"按钮的代码如下: "取消"按钮代码:close(w_register) open(w_login) (5)制作管理员主菜单w_adminview,建管理员主界面w_adminview,将该菜单放到窗口中 (6)制作用户主菜单w_userview,建用户主界面w_userview,将菜单放到窗口中 (7)制作管理员主菜单里的录入报刊信息窗口w_inmagazine,录入用户信息窗口w_inuser, 制作数据窗口dw_magagrid,dw_magafree,dw_userfree,dw_usergrid,在数据窗口调整好外观,添加控件,并设定相应的动作,分别放到这两个窗口中 这两个窗口功能相识,在窗口中输入: dw_1.settransobject(sqlca) dw_1.retrieve() dw_2.settransobject(sqlca) dw_2.retrieve() (8)制作管理员主菜单中的查询订阅信息窗口w_searchorder,制作数据窗口dw_booksearch,将其放入窗体中,在窗口中输入代码: dw_1.settransobject(sqlca) dw_1.retrieve() sle_1.setfocus() 在"查询"按钮中输入代码: "预览"按钮的代码: "关闭"按钮代码:close(w_searchorder) 数据窗口字段如下: (9)制作管理员主菜单中的统计用户订单窗口w_statuser,统计部门订单窗口w_statdept,统计报刊订单窗口w_statnews:制作统计数据窗口dw_statnews,dw_statuser,dw_statdept将dw_statnews,dw_statuser,dw_statdept分别放入w_statnews, w_statuser,w_statdept中;以下仅列出按出按部门统计的代码和界面 (按用户、报刊统计类似,略); 按部门统计代码: 窗口代码: 按部门统计数据窗口: dw_1.settransobject(sqlca) dw_1.retrieve() 预览键代码:(与上页预览代码相同) 退出:close(parent) (10)管理员主菜单中的更改登录在w_adminview中的代码 (11)管理员主菜单中的退出系统在w_adminview中的代码 (12)管理员主菜单中的数据库备份窗口w_backup,"开始备份"按钮的代码如下 在">>"按钮带输入代码: (13)管理员主菜单中的数据库恢复窗口w_restore,"开始恢复"按钮的代码如下 在">>"按钮带输入代码: 在"开始恢复"按钮输入代码: (14)用户主菜单的订阅报刊窗口w_userorder 该系统中定义了一个全局变量gs_userid,其它窗口界面都可以使用该变量,并显示用户名,用户登录后,它会显示"~~~~,欢迎使用本系统!"的欢迎界面。 窗口代码: dw_1.settransobject(sqlca) dw_1.retrieve() sle_1.setfocus() sle_2.text=gs_userid "清空"按钮代码: sle_1.text="" sle_3.text="" sle_5.text="" "退出"按钮代码: close(w_userorder) "订阅"按钮代码: (14)用户主菜单的查询订单窗口w_usersearch,将订单查找dw_booksearch放到窗口里,在窗口中过过滤器筛选中用户自己的订单信息,一打开就可以看到自己的订单信息,可打印和预览结果 窗口代码: "预览"和"退出"按钮同上 (15)用户主菜单的查询订单窗口w_userstatis,将用户统计dw_statuser放到窗口里,在窗口中过过滤器筛选中用户自己的订单信息,一打开就可以看到自己的订单信息,可打印和预览结果,窗口代码如下: 用户统计dw_statuser数据窗口如下: "预览""退出"按钮略 (16)用户主菜单中的修改用户信息窗口w_usermodify,打开会先显示出你的信息,而用户名这一栏是输入不了的,也就是不能修改用户名,窗口代码如下: "保存"按钮代码如下: (17)用户主菜单中的更改登录和退出系统的代码和管理员的一样,这里就省略了。 7.3系统使用结果 打开本系统,首先弹出欢迎界面,通常一闪而过,然后到了登录界面,点击"注册" 按确定后,弹出"恭喜,您已注册成功!"的对话框。如果这时刷新服务管理器,打开SQL Server企业管理器,打开该数据库的用户表,就可看到刚才注册的用户已经在表中了 然后返回到登陆页面,输入刚才注册到的用户名和密码maishning,123456 登录后,弹出一个窗口,有供用户使用的菜单,界面显示"~~~~,欢迎使用本系统" 选择"订阅"菜单,在这个订阅界面,用户可以浏览到所有的报刊信息,要订阅报刊时,用户不需输入用户名与密码,只需输入您要订阅的报刊代号(该报刊代号必须是报刊表中存在的),订阅份数(必须是小于8的整数才有效),然后选择需要订阅的月数(一月、一季、半年或一年)然后点击"订阅"按钮 订阅成功后,系统弹出"恭喜!你已成功订阅该报刊,总金额是~~~~"确定后会显示出您所订阅的总额是多少元,按"清空"按钮后可以订阅其它报刊(同样的报刊不可重复订阅) 再订阅其它报刊,然后按"退出"按钮,来到用户主菜单然后选择"查询"菜单,这个数据窗口经过过滤,一打开就直接显示该用户过订阅的订单,可以进行预览和打印。 由于权限的限制,"统计"菜单中的也是只能统计自己订单信息的数据 在"退订"报刊菜单中,可以查看自己的订单,单击"退订"然后"保存"即可完成退订 在"修改"信息菜单中,用户名也是不可输入的文本框,即不可修改用户名,其它信息可以修改,保存后它会自动添加到数据库中 选择菜单上的"注销",可以用不同的身份进入系统,确定后回到登录界面 以管理员的身份登录,用户名111,密码111,按登录按键,可看到管理员菜单 选择菜单栏中的录入->录入报刊信息,管理员可以大致浏览所有报刊信息,在上面的数据窗口可以查看上一页和下一页的具体内容,并且可以对其进行添加,删除、修改、保存等操作。 录入用户信息页面,基本相似 选择菜单栏中的"查询"->"订单信息",管理员拥有的权限可以看到所有的订单信息 管理员也可以根据需要分别按部门、按用户、按报刊查询,比如,要查询msishning用户,在文本框中输入关键字,选择单选按钮中的"按部门号",点击"查询",结果如下 可对全部订单或查询出来的订单进行预览和打印,方便使用 菜单栏中的"统计"菜单有三个子菜单,管理员可以分别统计用户订单信息、部门订单信息和报刊订单信息, 直接选择就可看到统计结果,比如选择"统计用户订单信息" 可将统计出来的结果进行预览和打印,方便使用,其它两个统计功能相似,略 主菜单中的系统维护->数据库备份,选择备份的位置,然后"开始备份" 主菜单中的系统维护->数据库恢复,选择之前备份的文件,输入路径和数据库名,然后"开始恢复" 7.4系统评价: 这次课程设计我选择了这个企业报刊订阅管理系统这个题目,它主要用于企业内部人员的报刊订阅,之所以选择这个题目,是因为在那三个可供选择的题目中,这个题目相对其它两个,在我脑海中形成清晰的结构,用户可以做什么,管理员需要做什么。选定这个题目后,老师要求我们写了份初稿,根据该系统需要实现的功能,进行系统分析,然后确定需要哪些属性,数据库的概念设计,逻辑设计最终建表。 关于这个课程设计,我的感触很深,这是我很难得的非常认真独立的做的一个课程设计。暑假时间回到家里,本来最初是打算用Jsp实现这个系统的,但后来由于某些功能发现还是用Powerbuilder会简单很多,而且它的代码也比较简单。由于电脑里没有我想要实现该系统的软件,我提前回到学校,下载了Powerbuilderd 9.0这个软件,然后我也到图书馆借了几本Powerbuilder入门的书,用了整整四天的时间,我都是在学习PB这个软件,并且按着那本书上的例子动手实现几个简单的程序。当然,这中间也有某些书本说的不是很清楚的地方,只能靠着自己慢慢摸索,找出错误的地方,实现程序的运行。在对PB有了一定的认识以后,我开始着手这个课程设计,用了大约五天的时间。构思整个系统的整体框架,权限方面分开了管理员和用户的登录,管理员和用户的菜单分别是哪些,每个菜单下的功能怎么实现,都一一设计代码,然后修改,运行,调试。 最后,整个系统基本上实现了所有要求,用户可以订阅报刊、查看和统计自己的订单信息,也可修改自己的信息,除了用户名。本系统的特色在于,用户订阅报刊非常方便,用户登录系统后,用户名作为全局变量保存在系统中,进入订阅菜单后,自动显示用户名,而用户只需要输入所要订阅的报刊代号和订阅份数,以及选择需要订阅的时间,系统会自动计算出这次订阅所需要的金额,确定后显示于文本框中。在查看和统计订单信息时,也是自动筛选出该用户的订单信息,而无需用户再次输入用户名和密码。 管理员方面,可以输入用户、报刊的信息,并且可以对这些信息进行修改。管理订单方面,管理员可以按人员、按部门、按报刊查询和统计所有的订单信息,方便对报刊的分发进行管理,并且可以预览和打印出这些结果。还有数据库备份和恢复功能使系统的数据安全性有了保障。 由于是初次学习了PowerBuilder做程序,难免有些不足之处。我体会到自己用Powerbuilder完成设计的乐趣,但是由于某些能力方面的限制,我的系统还不是那么完美,相比现实中的管理系统有段很大的距离。比如用户真实姓名没有纠错,应该把所有部门的职工全都输入到表中,当注册的时候,输入真实姓名,如果相关部门没有此人,则不允许注册,此功能尚未实现;本来的想法是用户订阅了某份报刊后,系统会自动生成一个订单号后,但是发现实现起来比较麻烦,订单表就直接用报刊代号和用户名作为主码了;订阅了报刊后,应该可以和管理员进行信息反馈,管理员确认了该订单,然后,在该报刊还没到发送时间,用户应该可以拥有,修改、取消订单之类的操作,这样比较符合实际。 以上是该系统的不足之处,我想在以后继续学习的过程中,我会找到解决的方法,通过这次课程设计,我觉得我对数据库有了更进一步更深刻的认识,比如:对表内一些字段的约束,关系等的运用已经比较熟练,巩固了我的数据库的知识。而且我也学会了Powerbuilder这个软件,对于这个软件的基础应用我已相当熟悉了,感觉自学挺自豪的,呵呵。我会继续学习这相关方面的知识,使我以后开发出来的系统更加完善!
.Net中使用WCF构建简单的基于B/S和C/S的服务
第1步:创建接口 namespace WCF.Interface { //[ServiceContract(CallbackContract=typeof(ICallback))]//回调接口(全双工) [ServiceContract] public interface ICalculator { [OperationContract]
Delphi设计B/S
基于Delphi设计B/S 基于Delphi设计B/S 基于Delphi设计B/S
关闭