一个项目的简单开发流程——需求、数据库、编码

简介: 关于一个项目的简单开发流程   前言:从11月8号开始到11月12号我们小组使用html+easyUI+ashx+异步,开发了一个简易的网 站,也就是简单的门户网站,下面我就将我们这几天开发中遇到的一些问题以及我自己的一些关于项目的开发流程的见解,当然我的见解很有限,所以希望广大博友 们能提出你们在工作中所接触到的一些流程的见解,方便我们大家来学习。

关于一个项目的简单开发流程

  前言:从11月8号开始到11月12号我们小组使用html+easyUI+ashx+异步,开发了一个简易的网 站,也就是简单的门户网站,下面我就将我们这几天开发中遇到的一些问题以及我自己的一些关于项目的开发流程的见解,当然我的见解很有限,所以希望广大博友 们能提出你们在工作中所接触到的一些流程的见解,方便我们大家来学习。下面我们就来说一下整个项目的过程

1.首先就是需求

  (1) 在整个项目中这块可以说是非常重要,没有需求或者需求不明确那么我们开发人员将无存下手,因为不知道怎么写,所以前期的需求调研是非常重要的,如果在这块没有好好整理的话将会在后面遇到很多的问题,后面我会说到我们遇到的问题。

  (2) 当然虽然我们知道需要需求分析,但是我们也没有做需求分析,因为数据库已经是建好的,而且我们是为了学习技术,只是为了编码,自己写着玩,当然从这些项目中我们都在学习进步,所以基本的需求我们都知道。

  (3)记得以前刚去公司的时候,我们主任曾经给我们提过让我写一个需求分析,项目是煤矿的《人员定位管理系统》,当 时刚一接触,头大啊,根本不知道什么需求,然后我就查资料,但是最后没有写,因为需求本来是有的,我们主任只是为了锻炼我一下,所以让我自己琢磨一下,后 来我们公司小组设计了一个分层的权限设置,权限大家都知道,好几个表嵌套,所以那次也学到了好多东西,最后公司有个OA项目,需求分析也是我写的,网址:http://www.cnblogs.com/hanyinglong/archive/2012/07/13/2589927.html,但是这些全部是我主任为了训练我,所以在这里我感谢我的主任和以前的同事,他们对我的帮助挺大的。

2.接下来就是设计数据库

  (1)当我们需求写完的时候,这时候就到搭建整个数据库的时候了,也可以说数据库是整个项目中最重要的角色了,一个优秀的数据库设计者就能从这里看出来,因为我们数据库是设计好的,所以我这里只说一下自己的感觉吧,我在数据库方面比较弱,所以见解很浅的。

  (2)我觉得主键是必须的,每个表都有其对应的主键,而且主键最好用一个不相干的字段ID来表示,这样方便我们在项目里面写代码。

  (3)其他的就是一些命名之类的最好要见名知意,不要使用汉字命名,还有数据库的设计遵循三大范式。

3.最后就是编码的实现了

  (1)首先建立解决方案项目,最后使用动软生成器生成相应的代码,然后放到解决方案中,修改bug,使动软的代码可以运行,最后建立web应用程序,整个架构下来如图所示:就是一个典型的三层架构。

    

  (2)在不使用任何技术的前提下,将小组各自的项目整合在一起,如果前期不讨论如何弄的话在整和项目的时候将会遇到 许多的问题,我想大家都是很清楚的吧,如果项目大点,那就是生不如死啊,怎么样才能是项目合并起来很方便呢,下面我就说一下我的想法吧,只是参考,大家有 更好的可以提出来我们共同学习进步。

  (3)首先我们在Web应用程序中必须建立相应的使用外部文件的文件夹,比如我们使用的JS文件我们可以放到Jquerys文件夹下面,css文件可以放到相应的style文件夹下面,还有调用的dll我们可以放到lib文件夹下面,如下图所示。

    

(4)动软生成的代码,我们一般情况下不可以直接在里面操作,因为那样的话如果数据库的结构变了,我们需要重新生成代 码,将会覆盖我们的代码或者我们一个一个的去复制黏贴,那可真就是典型的苦逼的程序员了,所以如果我们需要给DLL层的用户表里面添加一个分页的方法,那 么我们可以直接建立一个部分类LYSC_userExt,然后再实现代码,结构图和代码如图所示:高清加亮的就是我们给重新建立的。

      

      

(5)然后我主要说一下我们后台的实现,因为我们后台是分角色写的,每个人都有每个人的模块,所以后天的开发尤其能体现 出来前面所说的内容,因为后台分为用户管理,客户管理,企业文化,新闻和人才管理,所以我对应的每个角色都建立一个文件夹,比如用户对应Users,新闻 对应news,然后将该使用的easyUI文件夹行放到后台下面,然后因为我们在后台用到了富文本编辑器,所以将富文本编辑器的文件夹也放到下面,这样我 们就搭建好了整个系统的开发环境,如图所示:
      

(6)这样我们的整个环境的开发就搭建好了,然后将这个文件发给我们的每个成员,然后每个成员对应每个成员的开发角色,在其相应的文件夹下面建立html,一般处理程序和代码的书写,在最后合并的时候我们只需要拷贝过来一个成员的文件夹复制到项目里面就行了。

4.调试测试

  (1)首先我们在写代码的时候就应该适当的调试,比如那些很低级的错误,文本框的长度,邮件格式,文本框不能为空等这些本来可以避免的Bug我们应该就不要让其发生,所以我们在编写代码的时候就应该写完。

  (2)如果我们的团队有测试团队的话他们的测试将会编写测试代码来测试,那样是最好的,但是我们没有测试人员,所以,我们自己成员测试项目。

  (3)在测试中最忌讳的就是自己测试自己的代码,那样可能一些潜在的代码始终是测试不出来的,所以等项目成型之后就要将自己开发的模块分给别人测试,而你测试别人的模块,这样使用黑盒测试一下基本通过,那样一个企业的网站算是成型了,我们的网站也正在测试中。

5.效果展示图:

  (1) 用户管理

 

 

 

  (2)新闻管理

 

      

  

      

 

 

 项目下载地址:本来是在博客园上传的,可是太大了,只能在CSDN里面了,http://download.csdn.net/detail/hanyinglong/4767316

 

转自:http://www.cnblogs.com/hanyinglong/archive/2012/11/12/2766769.html

img_e00999465d1c2c1b02df587a3ec9c13d.jpg
微信公众号: 猿人谷
如果您认为阅读这篇博客让您有些收获,不妨点击一下右下角的【推荐】
如果您希望与我交流互动,欢迎关注微信公众号
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接。

目录
相关文章
|
3月前
|
存储 关系型数据库 MySQL
一个项目用5款数据库?MySQL、PostgreSQL、ClickHouse、MongoDB区别,适用场景
一个项目用5款数据库?MySQL、PostgreSQL、ClickHouse、MongoDB——特点、性能、扩展性、安全性、适用场景比较
|
3月前
|
SQL JavaScript 关系型数据库
node博客小项目:接口开发、连接mysql数据库
【10月更文挑战第14天】node博客小项目:接口开发、连接mysql数据库
|
3月前
|
SQL 关系型数据库 MySQL
Go语言项目高效对接SQL数据库:实践技巧与方法
在Go语言项目中,与SQL数据库进行对接是一项基础且重要的任务
110 11
|
4月前
|
JavaScript Java 关系型数据库
毕设项目&课程设计&毕设项目:基于springboot+vue实现的在线考试系统(含教程&源码&数据库数据)
本文介绍了一个基于Spring Boot和Vue.js实现的在线考试系统。随着在线教育的发展,在线考试系统的重要性日益凸显。该系统不仅能提高教学效率,减轻教师负担,还为学生提供了灵活便捷的考试方式。技术栈包括Spring Boot、Vue.js、Element-UI等,支持多种角色登录,具备考试管理、题库管理、成绩查询等功能。系统采用前后端分离架构,具备高性能和扩展性,未来可进一步优化并引入AI技术提升智能化水平。
毕设项目&课程设计&毕设项目:基于springboot+vue实现的在线考试系统(含教程&源码&数据库数据)
|
3月前
|
Java 关系型数据库 数据库连接
SpringBoot项目使用yml文件链接数据库异常
【10月更文挑战第3天】Spring Boot项目中数据库连接问题可能源于配置错误或依赖缺失。YAML配置文件的格式不正确,如缩进错误,会导致解析失败;而数据库驱动不匹配、连接字符串或认证信息错误同样引发连接异常。解决方法包括检查并修正YAML格式,确认配置属性无误,以及添加正确的数据库驱动依赖。利用日志记录和异常信息分析可辅助问题排查。
405 10
|
3月前
|
Java 关系型数据库 MySQL
SpringBoot项目使用yml文件链接数据库异常
【10月更文挑战第4天】本文分析了Spring Boot应用在连接数据库时可能遇到的问题及其解决方案。主要从四个方面探讨:配置文件格式错误、依赖缺失或版本不兼容、数据库服务问题、配置属性未正确注入。针对这些问题,提供了详细的检查方法和调试技巧,如检查YAML格式、验证依赖版本、确认数据库服务状态及用户权限,并通过日志和断点调试定位问题。
271 6
|
3月前
|
前端开发 Java 数据库连接
表白墙/留言墙 —— 中级SpringBoot项目,MyBatis技术栈MySQL数据库开发,练手项目前后端开发(带完整源码) 全方位全步骤手把手教学
本文是一份全面的表白墙/留言墙项目教程,使用SpringBoot + MyBatis技术栈和MySQL数据库开发,涵盖了项目前后端开发、数据库配置、代码实现和运行的详细步骤。
88 0
表白墙/留言墙 —— 中级SpringBoot项目,MyBatis技术栈MySQL数据库开发,练手项目前后端开发(带完整源码) 全方位全步骤手把手教学
|
18天前
|
存储 Oracle 关系型数据库
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
44 3
|
18天前
|
安全 关系型数据库 MySQL
MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!
《MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!》介绍了MySQL中的三种关键日志:二进制日志(Binary Log)、重做日志(Redo Log)和撤销日志(Undo Log)。这些日志确保了数据库的ACID特性,即原子性、一致性、隔离性和持久性。Redo Log记录数据页的物理修改,保证事务持久性;Undo Log记录事务的逆操作,支持回滚和多版本并发控制(MVCC)。文章还详细对比了InnoDB和MyISAM存储引擎在事务支持、锁定机制、并发性等方面的差异,强调了InnoDB在高并发和事务处理中的优势。通过这些机制,MySQL能够在事务执行、崩溃和恢复过程中保持
47 3
|
18天前
|
SQL 关系型数据库 MySQL
数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog
《数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog》介绍了如何利用MySQL的二进制日志(Binlog)恢复误删除的数据。主要内容包括: 1. **启用二进制日志**:在`my.cnf`中配置`log-bin`并重启MySQL服务。 2. **查看二进制日志文件**:使用`SHOW VARIABLES LIKE 'log_%';`和`SHOW MASTER STATUS;`命令获取当前日志文件及位置。 3. **创建数据备份**:确保在恢复前已有备份,以防意外。 4. **导出二进制日志为SQL语句**:使用`mysqlbinlog`
62 2