java SSM家庭财务管理系统myeclipse开发mysql数据库springMVC模式java编程计算机网页设计

一、源码特点
    java SSM家庭财务管理系统是一套完善的web设计系统(系统采用SSM框架进行设计开发,spring+springMVC+mybatis),对理解JSP java编程开发语言有帮助,系统具有完整的源代
码和数据库,系统主要采用B/S模式开发。开发环境为TOMCAT7.0,Myeclipse8.5开发,数据库为Mysql5.0,使用java语言开发。

java ssm 家庭财务管理系统


二、功能介绍
通过对需求进行分析,家庭财务管理系统包括用户信息管理、基础数据信息管理、收支信息管理、项目信息管理、借还款信息管理。
1)用户管理模块笔记用户信息该模块主要用于系统的用户管理,其中主要包括系统用户的登录和注册以及管理员添加用户、用户编辑个人信息等部分。
2)收支管理模块
家庭管理员登陆进入家庭财务管理系统可以根据实际需要添加收入信息、编辑收入信息、添加支出信息、编辑支出信息,删除信息
3)存储管理模块 
家庭系统管理员进入家庭财务管理系统可以根据实际需要选择定期存储信息和活期存储信息管理。
4)借还款管理模块
家庭系统管理员进入家庭财务管理系统可以根据实际需要点击添加借入、添加借出进入相应页面进行管理。
5)基本数据管理模块
在基本数据管理模块中,管理员登陆财务管理系统可以对收入、支出、家庭信息、家庭称呼信息、家庭活期账号信息、家庭定期账号信息等基本数据进行分析管理。

数据库设计

(1)用户信息表如表3.1所示:

表3.1 用户信息表

序号

字段名称

数据类型

长度

主键

描述

1

yhid

INTEGER

11

用户编号

2

yhm

VARCHAR

40

用户名

3

mm

VARCHAR

40

密码

4

xm

VARCHAR

40

姓名

5

lxdh

VARCHAR

40

联系电话

6

lxdz

VARCHAR

40

联系地址

7

qx

VARCHAR

40

权限

8

ch

VARCHAR

40

称呼

(2)项目信息表如表3.2所示:

表3.2 项目信息表

序号

字段名称

数据类型

长度

主键

描述

1

xmid

INTEGER

11

项目编号

2

xm

VARCHAR

40

项目

3

lx

VARCHAR

40

类型

(3)收入信息表如表3.3所示:

表3.3收入信息表

序号

字段名称

数据类型

长度

主键

描述

1

srid

INTEGER

11

收入编号

2

rq

VARCHAR

40

日期

3

xm

VARCHAR

40

项目

4

je

VARCHAR

40

金额

5

yh

VARCHAR

40

用户

6

sj

VARCHAR

40

时间

(4)支出信息表如表3.4所示:

表3.4 支出信息表

序号

字段名称

数据类型

长度

主键

描述

1

zcid

INTEGER

11

支出编号

2

rq

VARCHAR

40

日期

3

xm

VARCHAR

40

项目

4

je

VARCHAR

40

金额

5

yh

VARCHAR

40

用户

6

sj

VARCHAR

40

时间

(5)借款信息表如表3.5所示:

表3.5 借款信息表

序号

字段名称

数据类型

长度

主键

描述

1

jkid

INTEGER

11

借款编号

2

rq

VARCHAR

40

日期

3

sm

VARCHAR

40

说明

4

jkje

VARCHAR

40

借款金额

5

jkr

VARCHAR

40

借款人

6

jksj

VARCHAR

40

借款时间

(6)还款信息表如表3.6所示:

表3.6 还款信息表

序号

字段名称

数据类型

长度

主键

描述

1

hkid

INTEGER

11

还款编号

2

rq

VARCHAR

40

日期

3

sm

VARCHAR

40

说明

4

hkje

VARCHAR

40

还款金额

5

hkr

VARCHAR

40

还款人

6

hksj

VARCHAR

40

还款时间

(7)卡折信息表如表3.7所示:

表3.7 卡折信息表

序号

字段名称

数据类型

长度

主键

描述

1

kzxxid

INTEGER

11

卡折信息编号

2

mc

VARCHAR

40

名称

3

kh

VARCHAR

40

卡号

4

mm

VARCHAR

40

密码

5

yh

VARCHAR

40

用户

6

djsj

VARCHAR

40

登记时间

系统ER图

系统功能图

控制类

@RequestMapping(value="/add")public String add(jiekuan jiekuan,HttpServletRequest request){Map<String,Object> map= new HashMap<String,Object>();//String name=(String)request.getParameter("name");map.put("jkid", jiekuan.getJkid());//借款编号map.put("rq", jiekuan.getRq());//日期map.put("sm", jiekuan.getSm());//说明map.put("jkje", jiekuan.getJkje());//借款金额map.put("jkr", jiekuan.getJkr());//借款人map.put("jksj", jiekuan.getJksj());//借款时间String jkid=(String)jiekuan.getJkid();//借款编号String rq=(String)jiekuan.getRq();//日期String sm=(String)jiekuan.getSm();//说明String jkje=(String)jiekuan.getJkje();//借款金额String jkr=(String)jiekuan.getJkr();//借款人String jksj=(String)jiekuan.getJksj();//借款时间jiekuandao.save(map);request.setAttribute("msg", "<script>alert('添加成功');</script>");System.out.println("addok");return "jiekuan/jiekuanadd";}/**删除 * */@RequestMapping(value="/del")public String  del(Integer id,HttpServletRequest request,Map<String,Object> map){//	Map<String,Object> map= new HashMap<String,Object>();String a=(String)request.getParameter("keyid");id=Integer.parseInt(a);request.setAttribute("msg", "<script>alert('删除成功');</script>");jiekuandao.del(id);return selectall(null,map,request);}/*** 修改jiekuan信息*/@RequestMapping(value="/update")public String update(jiekuan jiekuan,HttpServletRequest request,Map<String,Object> map1){Map<String,Object> map= new HashMap<String,Object>();map.put("jkid", jiekuan.getJkid());//借款编号map.put("rq", jiekuan.getRq());//日期map.put("sm", jiekuan.getSm());//说明map.put("jkje", jiekuan.getJkje());//借款金额map.put("jkr", jiekuan.getJkr());//借款人map.put("jksj", jiekuan.getJksj());//借款时间String jkid=(String)jiekuan.getJkid();//借款编号String rq=(String)jiekuan.getRq();//日期String sm=(String)jiekuan.getSm();//说明String jkje=(String)jiekuan.getJkje();//借款金额String jkr=(String)jiekuan.getJkr();//借款人String jksj=(String)jiekuan.getJksj();//借款时间request.setAttribute("msg", "<script>alert('修改成功');</script>");jiekuandao.update(map);return selectall(null,map1,request);}/*** 查询jiekuan信息*/@RequestMapping(value="/modify")public String modify(Integer id,Map<String,Object> map,HttpServletRequest request){String keyid=(String)request.getParameter("keyid");List<Map<String,Object>> list= new  ArrayList<Map<String,Object>>();list=jiekuandao.select(Integer.parseInt(keyid));request.setAttribute("jkid", list.get(0).get("jkid"));//借款编号request.setAttribute("rq", list.get(0).get("rq"));//日期request.setAttribute("sm", list.get(0).get("sm"));//说明request.setAttribute("jkje", list.get(0).get("jkje"));//借款金额request.setAttribute("jkr", list.get(0).get("jkr"));//借款人request.setAttribute("jksj", list.get(0).get("jksj"));//借款时间return "jiekuan/jiekuanmodify";}

持久层类

 */public void save(Map<String, Object> map) {sqlSession.insert("com.jiekuan.insertjiekuan", map);}/*** 删除aa* @param id*/public void del(Integer id) {sqlSession.delete("com.jiekuan.deljiekuan", id);}/*** 修改jiekuan信息* @param map*/public void update(Map<String, Object> map) {sqlSession.update("com.jiekuan.updatejiekuan", map);}/*** 查询jiekuan信息* @param id* @return */public List<Map<String, Object>> select(Integer id) {return sqlSession.selectList("com.jiekuan.selectjiekuan", id) ; }/*** 查询jiekuan信息* * @return */public List<Map<String, Object>> selectAll(Map<String, Object> map) {return sqlSession.selectList("com.jiekuan.selectall", map) ; }

mybaits类

<insert id="insertjiekuan"  parameterType="java.util.Map">insert  into  jiekuan(rq,sm,jkje,jkr,jksj)  values(#{rq},#{sm},#{jkje},#{jkr},#{jksj})
</insert><delete id="deljiekuan" parameterType="int">delete  from  jiekuan where jkid=#{jkid}
</delete><update id="updatejiekuan" parameterType="java.util.Map">
update jiekuan set rq=#{rq},sm=#{sm},jkje=#{jkje},jkr=#{jkr},jksj=#{jksj} where jkid=#{jkid}
</update><!--  查询返回的是 list<map> -->
<!-- resultType 就是返回查询结果的类型,而如果是resultMap=则返回的就是你定义的javabean  -->
<select  id="selectjiekuan"  parameterType="int" resultType="java.util.Map">select  * from jiekuan where jkid=#{jkid}
</select><!-- resultType 就是返回查询结果的类型,而如果是resultMap=则返回的就是你定义的javabean  -->
<select  id="selectall"  parameterType="java.util.Map" resultType="java.util.Map">select  * from jiekuan where 1=1
<if test=" null != rq and rq!=''" >and rq = #{rq}
</if>
<if test=" null != sm and sm!=''" >and sm = #{sm}
</if>
<if test=" null != jkje and jkje!=''" >and jkje = #{jkje}
</if>
<if test=" null != jkr and jkr!=''" >and jkr = #{jkr}
</if>
<if test=" null != jksj and jksj!=''" >and jksj = #{jksj}
</if></select>


三、注意事项
    1、管理员账号:admin 密码:admin 数据库配置文件datasource.properties
     2、开发环境为TOMCAT7.0,Myeclipse8.5开发,数据库为Mysql5.0,使用java语言开发。
    3、数据库文件名是jspssmjtcw.sql,系统名称ssmjtcw
    4、系统首页地址:http://127.0.0.1:8080/ssmjtcw/login.jsp

四 系统实现

源码获取 下方联系卡片↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/295735.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

阅读笔记-A Cluster Separation Measure

A Cluster Separation Measure&#xff08;一种聚类分离测度&#xff09; 1.这篇论文要解决什么问题&#xff1f;要验证一个什么科学假设&#xff1f; 问题是确定数据中聚类的适当数量&#xff0c;解决这种问题的两种方法都取决于确定指数中相对较大的变化&#xff0c;而不是…

多模态大模型:关于Better Captions那些事儿

Overview 一、ShareGPT4V1.1、Motivation1.2、ShareGPT4V数据集构建1.3、ShareGPT4V-7B模型 一、ShareGPT4V 题目: ShareGPT4V: Improving Large Multi-Modal Models with Better Captions 机构&#xff1a;中科大&#xff0c;上海人工智能实验室 论文: https://arxiv.org/pdf…

Unity中获取时间戳、日期、时间、毫秒、秒以相互转换、自定义格式时间

Unity中获取时间戳、日期、时间、毫秒、秒以相互转换、自定义格式时间 介绍时间戳是什么什么时候用时间戳 获取时间获取当前时间获取时间戳日期转时间戳时间戳转日期将时间戳转换为多久之前星期自定义格式时间 总结 介绍 这里附带一个时间戳和时间转换的网址 时间戳是什么 时…

使用Ubuntu22+Minikube快速搭建K8S开发环境

安装Vmware 这一步&#xff0c;可以参考我的如下课程。 安装Ubuntu22 下载ISO镜像 这里我推荐从清华镜像源下载&#xff0c;速度会快非常多。 下载地址&#xff1a;https://mirrors.tuna.tsinghua.edu.cn/ubuntu-releases/22.04.3/ 如果你报名了我的这门视频课程&#xf…

软件工程期末复习

● 用例&#xff1a;借书 ●参与者&#xff1a;管理员,借阅者 ●操作流&#xff1a; ① 管理员进入图书借阅界面&#xff0c;用例开始。 ② 系统要求输入借阅者的借书证编码。 ③系统检验借书证编码,如果正确,则显示借阅者的信息。 A1&#xff1a;借书证编码有错。 A2: 如果该借…

【运维面试100问】(十一)淡淡I/O过程

本站以分享各种运维经验和运维所需要的技能为主 《python零基础入门》&#xff1a;python零基础入门学习 《python运维脚本》&#xff1a; python运维脚本实践 《shell》&#xff1a;shell学习 《terraform》持续更新中&#xff1a;terraform_Aws学习零基础入门到最佳实战 《k8…

DFS与BFS算法总结

知识概览 DFS、BFS都可以对整个问题空间进行搜索&#xff0c;搜索的结构都是像一棵树。DFS会尽可能往深搜&#xff0c;当搜索到叶节点时就会回溯。而BFS每一次只会扩展一层。 DFS与BFS的区别&#xff1a; 搜索方式数据结构空间复杂度性质DFS栈O(h)&#xff0c;其中h为搜索空间…

4.4【共享源】克隆实战开发之截屏(二)

三,显示器截图 screen_read_display() 函数则用于捕获显示器的屏幕截图。我们需要在特权上下文中工作,以便可以完全访问系统的显示属性。我们可以通过调用具有 SCREEN_DISPLAY_MANAGER_CONTEXT 上下文类型的 screen_create_context() 来创建特权上下文。进程必须具有 root 的…

simulinkveristandlabview联合仿真——模型导入搭建人机界面

目录 1.软件版本 2.搭建simulink仿真模型 编译错误 3.导入veristand并建立工程 4.veristand导入labview labview显示veristand工程数据 labview设置veristand工程数据 运行labview工程 1.软件版本 matlab2020a&#xff0c;veristand2020 R4&#xff0c;labview2020 SP…

Python入门学习篇(五)——列表字典

1 列表 1.1 定义 ①有序可重复的元素集合 ②可以存放不同类型的数据 ③个人理解:类似于java中的数组1.2 相关方法 1.2.1 获取列表长度 a 语法 len(列表名)b 示例代码 list2 [1, 2, "hello", 4] print(len(list2))c 运行结果 1.2.2 获取列表值 a 语法 列表名…

TLC549(8位A/D转换器)实现将输入的模拟电压显示到数码管上

代码&#xff1a; #include "reg51.h" #include "intrins.h" #define uchar unsigned char #define uint unsigned intsbit SDO P1^0; // 芯片的三个关键的输入数据端口&#xff0c;主要是靠外电压来提供的 sbit CS P1^1; sbit SCLK P1^2;sbit wei0 P…

lv13 操作系统、内核实现 1

目录 一、程序分类 二、计算机系统的层次结构 2.1 无操作系统的简单的两层结构 ​编辑 2.2 有操作系统的复杂的四层结构 三、 什么是操作系统 四、操作系统内核的实现模式 五、什么是设备驱动程序 一、程序分类 程序按其运行环境分为&#xff1a; 裸机程序&#xff1a;…