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.mzph.cn/news/240036.shtml

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

相关文章

百川大模型AI对话实战——Python开发一个对话机器人

百川大模型开放提供API体验中心&#xff0c;体验不错&#xff0c;有小伙伴也对搭建自己的对话机器人比较兴趣&#xff0c;今天通过Python来简单介绍下&#xff0c;如何调用百川大模型的API来构建自己的小产品。 在开发环境中安装Python&#xff0c;如何安装&#xff1f;参照网…

AI“百模大战”现状:向垂直、B端谋场景,算力仍是主要制约因素

文章目录 每日一句正能量前言AI&#xff08;人工智能&#xff09;大模型正“飞入”百姓家和行业中。向垂直、B端谋场景算力仍是主要制约因素构建“数据-模型-应用”飞轮后记 每日一句正能量 我们必须在失败中寻找胜利&#xff0c;在绝望中寻求希望。 前言 在当前快速发展的人工…

SecureCRT连接vmware虚拟机的centos系统配置

软件版本&#xff1a;VMware10.0.3&#xff0c;centos 7&#xff0c;securecrt 8.7.2 1&#xff0c;虚拟网络编辑器选择桥接模式&#xff0c; 2&#xff0c;如果不小心删除网络&#xff0c;centos关机状态下&#xff0c;选择恢复默认设置。 3&#xff0c;进入linux系统&#…

革命性突破:Great River推出XL高速ARINC 818传感器测试卡

Great River Technology荣幸地宣布&#xff0c;与RVS&#xff08;远程视觉系统&#xff09;2.0平台合作推出的XL高速ARINC 818传感器测试卡正式亮相。这款开创性的测试卡在柯林斯航空电子公司&#xff08;RTX业务部&#xff09;和波音公司开发和测试RVS 2.0系统中发挥了重要作用…

牛客小白月赛84——k级序列(超级无敌详解)(贪心)

前言&#xff1a; 这b题费了我一身牛劲&#xff0c;结果还是没有做出来&#xff0c;晚上请教大佬后&#xff0c;知晓方法&#xff0c;才将其ac&#xff0c;于是决心务必再次使用传说中的费曼学习法&#xff0c;并与大家分享一下这道题目。 题目&#xff1a; 登录—专业IT笔试…

09.list 容器

9、list 容器 功能&#xff1a; 将数据进行链式存储 链表&#xff08;list&#xff09;是一种物理存储单元上非连续的存储结构&#xff0c;数据元素的逻辑顺序是通过链表中的指针链接实现的 链表的组成&#xff1a; 链表由一系列结点组成 结点的组成&#xff1a; 一个是存…

Zabbix6 使用Agent2实现证书监控的详细步骤

目标 我们的目标是通过获取网站的证书信息来实现网站证书监控。 使用agent2的key 只需使用其中的key&#xff0c;就能实现我们的目标功能。然而&#xff0c;由于它返回的是json格式的数据&#xff0c;我们需要根据数据来配置监控项目&#xff08;item&#xff09;和触发器&am…

六西格玛的科技漩涡——张驰咨询如何促成企业变革

在管理的海洋里&#xff0c;六西格玛管理是一艘稳健的航船&#xff0c;在质量管理的汪洋中乘风破浪&#xff0c;尽管质疑之声像远处的风暴不断逼近&#xff0c;但张驰咨询公司依靠这艘航船坚持初心&#xff0c;驭风而行。 20载耕耘&#xff0c;张驰咨询不仅仅是培养了超过8000…

IP地址子网划分案例

网络工程师基本功&#xff0c;每人必会的IP地址划分案例。 要求&#xff1a; 一段C类地址192.168.1.0/24&#xff0c;请你将地址分给网络中的主机&#xff0c;要求至少有5个子网&#xff0c;每个子网至少有20台主机。 步骤&#xff1a; 1、要求5个子网&#xff0c;要向主机…

Jenkins自动化部署-配置ssh代码拉去方式的密钥(公私钥)

Jenkins想要通过ssh方式拉去gitlab代码&#xff0c;则需要在在Jenkins服务器配置私钥&#xff0c;gitlab服务器配置公钥 使用root用户生成公钥和私钥 ssh-keygen -t rsa在/root/.ssh/目录保存了公钥和使用 id_rsa&#xff1a;私钥文件 id_rsa.pub&#xff1a;公钥文件 把生…

BDD - Python Behave VS Code 插件 Behave VSC

BDD - Python Behave VS Code 插件 Behave VSC 引言Behave VSC 插件Behave VSC 安装Behave VSC 注意事项Behave VSC 插件默认可识别的项目结构Behave VSC 设置识别非 features 文件名的项目 引言 上一篇《BDD - Python Behave 入门》介绍了 Behave 的入门基础知识&#xff0c;…

IP应用场景的规划

IP地址作为互联网通信的基石&#xff0c;在现代社会中扮演着至关重要的角色。本文将深入探讨IP地址在不同应用场景中的规划与拓展&#xff0c;探讨其在网络通信、安全、商业、医疗和智能城市等领域的关键作用与未来发展趋势。 IP地址的基本原理 IP地址是分配给网络上设备的数…

python画图【00】Anaconda和Pycharm和jupyter的使用

①Anaconda ②Pycharm 一、Anaconda安装步骤 1、双击安装包&#xff0c;点击next。 2、点我同意I agree 3、 4、选择需要安装的位置&#xff0c;位置可根据自己情况安装到具体位置&#xff0c;但要记住安装到了哪里。然后点击next 5、可选择加入到环境变量&#xff0c;…

深入了解 Android 中的应用程序签名

深入了解 Android 中的应用程序签名 一、应用程序签名介绍1.1 应用程序签名1.2 应用程序签名的意义1.3 应用程序签名的流程1.4 应用程序签名的方案1.5 签名的重要性和应用场景 二、AOSP 的应用签名2.1 AOSP的应用签名文件路径2.2 应用程序指定签名文件 三、Android Studio 的应…

基于电商场景的高并发RocketMQ实战-NameServer内核原理剖析、Broker 主从架构与集群模式原理分析

&#x1f308;&#x1f308;&#x1f308;&#x1f308;&#x1f308;&#x1f308;&#x1f308;&#x1f308; 【11来了】文章导读地址&#xff1a;点击查看文章导读&#xff01; &#x1f341;&#x1f341;&#x1f341;&#x1f341;&#x1f341;&#x1f341;&#x1f3…

自动生成数控加工的轨迹刀具轨迹阿基米德螺旋线(3D)

文章目录 1. 阿基米德螺旋线2. 生成步骤目标: 基于点云自动生成阿基米德螺旋线轨迹点 针对的是半球形模型效果 1. 阿基米德螺旋线 阿基米德螺旋线(Archimedean spiral)是一种数学曲线,由古希腊数学家阿基米德(Archimedes)在公元前225年左右首次研究和描述。这条曲线的方…

Ignite内存配置

配置内存 #1.内存架构 #1.1.概述 Ignite内存架构通过可以同时在内存和磁盘上存储和处理数据及索引&#xff0c;得到了支持磁盘持久化的内存级性能。 多层存储的运行方式类似于操作系统&#xff08;例如Linux&#xff09;的虚拟内存。但是这两种类型架构之间的主要区别是&…

zustand 搞定 react 中复杂状态管理

Zustand 是一个轻量级的、无依赖的状态库&#xff0c;适用于 React 和函数式编程。它提供了一个简单、灵活的方式来管理应用程序的状态。本文就讲讲如何使用 zustand 搞定 react 中复杂状态管理&#xff0c;进而替代 redux 。 一、前言 以 redux 为代表的这类单向数据流状态管…

化繁为简,Python快速入门,从基础到实践的学习。

文章目录 前言一、安装与运行命令行运行 python 文件 二、变量和简单数据类型2.1 变量命名规则2.2 字符串2.2.1 字符串的简单运算title()upper()、lower() 2.2.2 合并&#xff08;拼接&#xff09;字符串2.2.3 使用制表符或换行符来添加空白2.2.4 删除空白2.2.5 Python 2 中的 …

Pixelmator Pro 中文

Pixelmator Pro是一款专为Mac用户设计的强大图像编辑软件。它提供了丰富的功能和直观的界面&#xff0c;使用户可以轻松进行各种图像处理任务。该软件支持各种文件格式&#xff0c;包括JPEG、PNG、GIF、BMP和TIFF等&#xff0c;并可导入Photoshop的psd文件。它提供了丰富的绘画…