使用Java怎么制作记账软件
导读:本文共12191字符,通常情况下阅读需要41分钟。同时您也可以点击右侧朗读,来听本文内容。按键盘←(左) →(右) 方向键可以翻页。
摘要: 1.项目介绍1.1.项目安排1.1.1.项目目标本项目为JAVAEE基础班综合项目,包含了若干个知识点,达到将基础班所学知识综合使用,提高了我们对项目的理解与知识点的运用。熟练View层、Service层、Dao层之间的方法相互调用操作、熟练dbutils操作数据库表完成增删改查通过本项目,让我们了解公司项目开发的流程,充分的掌握项目需求分析、设计与功能的代码实... ...
目录
(为您整理了一些要点),点击可以直达。- (32):1.使用Eclipse创建Java工程,命名为gjp
- (33):2.创建工程包
- (40):3.创建lib文件夹,用来存储使用的jar包
- (56):1编写MainView类run方法
- (57):1.1完成功能界面菜单显示
- (58):1.2接收键盘输入的功能选项
- (59):1.3根据选项值,调用对应的功能方法
- (60):2编写MainApp类的main主方法
- (62):1.在view包MainView类中编写run方法
- (63):1编写MainView类中selectZhangWu方
- (76):1. 编写MainView类中selectZhangW
- (77):2. 编写MainView类中selectAll方法
- (78):3. 编写MainView类中print方法
- (81):1编写MainView类中select方法
- (82):1.1通过键盘输入查询日期的范围
- (85):2编写ZhangWuService类中select方法
- (89):1. 编写MainView类中select方法
- (90):2. 编写ZhangWuService类中select
- (91):3. 编写ZhangWuDao类中select方法
- (92):1编写MainView类中addZhangWu方法
- (93):1.1键盘输入新添加的账务信息
- (96):2编写ZhangWuService类中addZhang
- (100):1. 编写MainView类中addZhangWu方法
- (101):2. 编写ZhangWuService类中addZha
- (102):3. 编写ZhangWuDao类中addZhangWu
- (103):1编写MainView类中editZhangWu方法
- (104):1.1键盘输入要编辑的账务信息ID号
- (105):1.2键盘输入要修改的账务信息内容
- (108):2编写ZhangWuService类中editZhan
- (112):1. 编写MainView类中editZhangWu方
- (113):2. 编写ZhangWuService类中editZh
- (114):3. 编写ZhangWuDao类中editZhangW
- (115):1编写MainView类中deleteZhangWu方
- (116):1.1键盘输入要删除的账务信息ID号
- (119):2编写ZhangWuService类中deleteZh
- (123):1. 编写MainView类中deleteZhangW
- (124):2. 编写ZhangWuService类中delete
- (125):3. 编写ZhangWuDao类中deleteZhan
本项目为JAVAEE基础班综合项目,包含了若干个知识点,达到将基础班所学知识综合使用,提高了我们对项目的理解与知识点的运用。
熟练View层、Service层、Dao层之间的方法相互调用操作、熟练dbutils操作数据库表完成增删改查通过本项目,让我们了解公司项目开发的流程,充分的掌握项目需求分析、设计与功能的代码实现。提高同学们独立分析需求与功能实现的能力。
本项目通过1天课程时间完成。
l查询账务
l多条件组合查询账务
l添加账务
l编辑账务
l删除账务
每个项目都要使用一些已经成熟的技术,它们通常是由一些专业组织或团队所提供的开源免费技术。在今后的学习过程中,我们会逐渐对这些专业组织有所了解。本项目中使用的技术如下:lapache的commons组件:Øcommons-dbutils-1.4.jar:封装并简化了JDBC;Øcommons-dbcp-1.4.jar:apache commons提供的数据库连接池组件,命名为DBCP;Øcommons.pool-1.3.jar:DBCP连接池依赖该jar包;lmysql-connector-java-5.1.28-bin.jar:MySQL的JDBC驱动包,用JDBC连接MySQL数据库必须使用该JAR包。
每个项目都会用到一些工具类,本项目也不例外。我们不会教大家如何实现这些类,而是让大家知道在项目我们如何使用这些工具类,下面是本项目中所使用的工具类以及介绍:lJDBCUtils:用来创建数据库连接池对象;在项目的实现过程中,我们会说明工具类的使用,这里就不再过多介绍。
对一个项目而言,表设计是非常重要的,因为应用程序中所有的操作都是基于数据库表而进行的,所以我们第一步就是创建数据库表。管家婆项目的数据库设计很简单,我们只需找到gjp.sql文件,然后执行之即可。下面是创建库及表的SQL语句:
创建管家婆数据库 gjpCREATE DATABASE gjp;
创建账务表gjp_zhangwu
添加账务表数据
程序为什么要分包分层?
以顾客去饭店吃饭案例分析一下:
小饭店: 一个服务员搞定(接待顾客点菜炒菜)
大饭店:
l迎宾员(是否有预定询问吃中餐还是西餐或者烧烤等几位用餐 领路到指定的包间找点菜员为顾客点菜 )
l点菜员(记录顾客点餐内容记录是否有忌口等问题找厨师为顾客炒菜)
l厨师(按照顾客菜肴清单,进行炒菜)
通过案例发现,当程序规模小的时候,可以一个人全部完成;但程序规模大的时候,一个人难以完成,这时,要采用多人合作的方式来完成程序开发。
多人合作方式将会碰到工作任务分配问题,这时我们会想,每个人负责完成项目的一块内容就可以了。那么,这一块块内容的划分,就需要我们采用分层(分包)的方式完成了。
通过下图(用户注册功能)来讲解下,项目中常见的分层(分包)。
lview层作用:视图层,即项目中的界面
lcontroller层作用:控制层,获取界面上的数据,为界面设置数据;将要实现的功能交给业务层处理
lservice层作用:业务层,功能的实现,与controller控制层和数据访问层DAO交互,将对数据库的操作交给DAO数据访问层来处理
ldao层作用:数据访问层,用来操作数据库表的数据
ldb数据库:这里指MySQL
ldomain 实体包:存放JavaBean
ltools工具包:存放项目中使用到的工具类
ltest 测试包:存放项目功能测试的代码
1.使用Eclipse创建Java工程,命名为gjp
2.创建工程包
Øcn.itcast.gjp.app:存放main方法类;
Øcn.itcast.gjp.domain:存放JavaBean;
Øcn.itcast.gjp.view:存放界面,及表现层类;
Øcn.itcast.gjp.service:存放业务层类;
Øcn.itcast.gjp.dao:存放数据访问层类;
Øcn.itcast.gjp.tools:存放工具类
3.创建lib文件夹,用来存储使用的jar包
完成本项目中类的创建,无需在类中添加代码。
1.复制已编写好的工具类JDBCUtils.java 到 tools包中;
2.复制jar包mysql-connector-java-5.1.28-bin.jar、commons-dbutils-1.4.jar、commons-dbcp-1.4.jar、commons-pool-1.3.jar,到lib文件夹中,通过Build Path操作,添加到classPath路径中,提供给JDBCUtils使用;
3.在app包中,创建类MainApp.java,编写main主方法,用来完成本项目的启动
4.在domain包中,创建类ZhangWu.java,它是用来封装账务信息的JavaBean。
5.在dao包中,创建类ZhangWuDao.java,给ZhangWuDao类添加一个成员变量QueryRunner对象,因为我们使用dbutils来操作数据库。
6.在service包中,创建类ZhangWuService.java,给ZhangWuService类添加一个类型为ZhangWuDao的成员变量,因为service依赖dao。
7.在view包中,创建类MainView.java,给MainView类添加一个类型为ZhangWuService的成员变量,因为本项目中view依赖service。
编写app包中MainApp.java
编写domain包中ZhangWu.java
编写Dao包中ZhangWuDao.java
编写Service包,ZhangWuService.java
编写view包,
JavaBean是指的是Java中的类,该类中的成员变量与数据库表中的字段相对应(变量名对应数据库表字段名、变量数据类型对应数据库表字段类型),并提供空参数构造方法、set、get方法。我们现在来完成账务类的代码编写,如下
界面菜单的完成,是项目编写的第一步。我们通过输出语句,完成界面菜单的输出,之后再根据输入的功能序号,进行对应功能的调用执行。
1编写MainView类run方法
1.1完成功能界面菜单显示
1.2接收键盘输入的功能选项
1.3根据选项值,调用对应的功能方法
2编写MainApp类的main主方法
2.1调用MainView类中run方法,实现将程序执行起来,显示功能界面菜单。
1.在view包MainView类中编写run方法
1编写MainView类中selectZhangWu方法
1.1通过输出语句,显示出要查询账务的方式
1.2接收键盘的输入项,调用对应的方法(1.查询所有 2.按条件查询)
2编写MainView类中selectAll查询所有账务方法
2.1调用ZhangWuService类selectAll方法,返回包含所有账务数据的List<ZhangWu>集合
2.2调用MainView类中print方法,实现控制台显示所有账务数据
3编写MainView类中print方法
3.1使用输出语句,打印出账务表的表头名称
3.2遍历账务集合,将每个账务信息输出打印
4编写ZhangWuService类中selectAll方法
4.1调用ZhangWuDao类中selectAll方法,返回包含所有账务数据的List<ZhangWu>集合
5编写ZhangWuDao类中selectAll()方法
5.1通过QueryRunner对象,调用query方法查询数据库表gjp_zhangwu,返回包含所有账务数据的List<ZhangWu>集合
1. 编写MainView类中selectZhangWu方法
2. 编写MainView类中selectAll方法
3. 编写MainView类中print方法
4. 编写ZhangWuService类中selectAll方法
5. 编写ZhangWuDao类中selectAll()方法
1编写MainView类中select方法
1.1通过键盘输入查询日期的范围
1.2调用ZhangWuSerice类中select方法,返回查询日期范围内的账务信息集合List<ZhangWu>
1.3调用MainView类中的print方法,将账务信息集合中的内容显示在控制台中
2编写ZhangWuService类中select方法
2.1调用ZhangWuDao 类中select方法,返回查询日期范围内的账务信息集合List<ZhangWu>
3编写ZhangWuDao类中select方法
3.1通过QueryRunner对象,调用query方法查询数据库表gjp_zhangwu,返回包含查询日期范围内的账务数据List<ZhangWu>集合
1. 编写MainView类中select方法
2. 编写ZhangWuService类中select方法
3. 编写ZhangWuDao类中select方法
1编写MainView类中addZhangWu方法
1.1键盘输入新添加的账务信息
1.2调用ZhangWuService类中addZhangWu方法,用来指定账务的添加
1.3添加完毕后,使用输出语句,提示“添加账务成功!”
2编写ZhangWuService类中addZhangWu方法
2.1调用ZhangWuDao类中addZhangWu方法,用来指定账务的添加
3编写ZhangWuDao类中addZhangWu方法
3.1通过QueryRunner对象,调用update方法更新数据库表gjp_zhangwu,完成指定账务添加到数据库表中
1. 编写MainView类中addZhangWu方法
2. 编写ZhangWuService类中addZhangWu方法
3. 编写ZhangWuDao类中addZhangWu方法
1编写MainView类中editZhangWu方法
1.1键盘输入要编辑的账务信息ID号
1.2键盘输入要修改的账务信息内容
1.3调用ZhangWuService类中editZhangWu方法,用来将指定的账务信息进行更新
1.4更新完毕后,使用输出语句,提示 “编辑账务成功!”
2编写ZhangWuService类中editZhangWu方法
2.1调用ZhangWuDao类中editZhangWu方法,用来将指定的账务信息进行更新
3编写ZhangWuDao类中editZhangWu方法
3.1通过QueryRunner对象,调用update方法更新数据库表gjp_zhangwu,完成数据库表中指定账务更新操作
1. 编写MainView类中editZhangWu方法
2. 编写ZhangWuService类中editZhangWu方法
3. 编写ZhangWuDao类中editZhangWu方法
1编写MainView类中deleteZhangWu方法
1.1键盘输入要删除的账务信息ID号
1.2调用ZhangWuService类中deleteZhangWu方法,用来将指定的账务信息删除
1.3删除完毕后,使用输出语句,提示 “删除账务成功!”
2编写ZhangWuService类中deleteZhangWu方法
2.1调用ZhangWuDao类中deleteZhangWu方法,用来将指定的账务信息删除
3编写ZhangWuDao类中deleteZhangWu方法
3.1通过QueryRunner对象,调用update方法更新数据库表gjp_zhangwu,完成数据库表中指定账务删除操作
1. 编写MainView类中deleteZhangWu方法
2. 编写ZhangWuService类中deleteZhangWu方法
3. 编写ZhangWuDao类中deleteZhangWu方法
恭喜大家,我们已经完成了分类模块所有功能。通过分类模块功能的实现,大家可能会发现如下几个问题:
l难度大的地方:自行功能分析的能力欠缺,需要讲师来分析;
l代码实现:
ØView(Controller):代码量最大;
ØService层:代码量最小;
ØDAO层:相似度高,难度不大;
view层的作用是“界面”,用来完成数据显示给用户。当前项目view层中,包含了Controller层代码。
Controller层的作用是“调度”,调度的是表现层view和业务层Service,主要功能分为:一是把表现层的数据交给业务层处理;二是把业务层返回的数据交给表现层显示。至于为什么这一层View(Controller)的代码量大,这里我要说明一下,其实不是View(Controller)层的代码量大,而是其他层代码量少,所以你会感觉View(Controller)层代码量大。
Service层的作用是“业务”,我们也可以把“业务”当成是“功能”。那为什么Service层代码量少呢?原因是现在我们写的项目很小,没有什么复杂的业务,而今后大家要写的大型项目代码量最大的就是Service层。
DAO层是操作数据库,现在我们使用的是commons-dbutils工具来简化JDBC,所以我们发现代码不多,比较简单。
最后我们还会学习其他DAO层的工具,例如:hibernate和mybatis,他们都是JDBC的封装,用来简化JDBC。
使用Java怎么制作记账软件的详细内容,希望对您有所帮助,信息来源于网络。