计算机毕业设计-基于Java+SSM架构的医院住院管理系统项目开发实战(附源码+文档)

大家好!我是职场程序猿,感谢您阅读本文,欢迎一键三连哦。

💞当前专栏:Java毕业设计

精彩专栏推荐👇🏻👇🏻👇🏻

🎀 Python毕业设计
🌎微信小程序毕业设计

开发运行环境

  • 框架:ssm
  • JDK版本:JDK1.8
  • 服务器:tomcat7
  • 数据库:mysql 5.7
  • 数据库工具:Navicat12
  • 开发软件:eclipse/myeclipse/idea
  • Maven包:Maven3.3.9
  • 浏览器:谷歌浏览器

源码下载地址:

https://download.csdn.net/download/m0_46388260/89272282

论文目录

【如需全文请按文末获取联系】
在这里插入图片描述
在这里插入图片描述

一、项目简介

使用Java语言SSM框架。系统可以提供信息显示和相应服务,其管理员查看住院病人消费金额统计报表,管理医生与护士的资料,管理床位,药品,医嘱以及住院消费。医生查询床位,管理病人,管理医嘱,管理病人住院信息。护士查询医嘱,药品,病人以及病人住院信息,管理病人住院消费信息。

二、系统设计

2.1软件功能模块设计

在前面分析的管理员功能的基础上,进行接下来的设计工作,最终展示设计的管理员结构图(见下图)。
在这里插入图片描述
在前面分析的医生功能的基础上,进行接下来的设计工作,最终展示设计的医生结构图(见下图)。
在这里插入图片描述
在前面分析的护士功能的基础上,进行接下来的设计工作,最终展示设计的护士结构图(见下图)。
在这里插入图片描述

2.2数据库设计

(1)下图是医生实体和其具备的属性。
在这里插入图片描述
(2)下图是病人信息实体和其具备的属性。
在这里插入图片描述
(3)下图是住院信息实体和其具备的属性。
在这里插入图片描述
(5)下图为上述各实体间相互之间的关系。
在这里插入图片描述

三、系统项目部分截图

3.1管理员功能实现

医生管理
管理员进入指定功能操作区之后可以管理医生。其页面见下图。本系统设置了医生角色,其信息需要管理员管理,包括添加,修改。
在这里插入图片描述
护士管理
管理员进入指定功能操作区之后可以管理护士。其页面见下图。管理员增删改查护士资料。
在这里插入图片描述
住院统计报表
管理员进入指定功能操作区之后可以查看住院统计报表。其页面见下图。管理员查看各个病人住院消费金额以及其所占比值信息。
在这里插入图片描述

3.2医生功能实现

医嘱管理
医生进入指定功能操作区之后可以管理医嘱。其页面见下图。医生负责登记医嘱,修改或删除本页面显示的医嘱信息。
在这里插入图片描述
病人信息管理
医生进入指定功能操作区之后可以管理病人信息。其页面见下图。医生负责对病人信息进行登记,可以修改病人的患病详情,家属联系方式以及负责医生姓名等资料,删除数据异常的病人信息。
在这里插入图片描述
添加住院信息
医生进入指定功能操作区之后可以添加住院信息。其页面见下图。医生为病人登记住院信息,包括检查医生,床位,患病类型等信息的登记。
在这里插入图片描述

3.3护士功能实现

住院消费管理
护士进入指定功能操作区之后可以管理病人住院消费信息。其页面见下图。护士新增病人住院消费信息,可以在当前页面修改消费原因和消费金额。
在这里插入图片描述
查询医嘱
护士进入指定功能操作区之后可以查询医嘱。其页面见下图。护士根据病人名称,或根据医生姓名查询医嘱信息。
在这里插入图片描述
住院查询
护士进入指定功能操作区之后可以查询住院信息。其页面见下图。护士根据病人名称,或者是根据床位编号查询病人住院信息,可以查看病人是否出院。
在这里插入图片描述

四、部分核心代码

package com.controller;


import java.text.SimpleDateFormat;
import com.alibaba.fastjson.JSONObject;
import java.util.*;

import com.entity.ZhuyuanEntity;
import com.service.*;
import org.springframework.beans.BeanUtils;
import javax.servlet.http.HttpServletRequest;
import org.springframework.web.context.ContextLoader;
import javax.servlet.ServletContext;

import com.utils.StringUtil;
import java.lang.reflect.InvocationTargetException;

import org.apache.commons.lang3.StringUtils;
import com.annotation.IgnoreAuth;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.*;
import com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.baomidou.mybatisplus.mapper.Wrapper;

import com.entity.XiaofeijiluEntity;

import com.entity.view.XiaofeijiluView;
import com.entity.BingrenEntity;
import com.utils.PageUtils;
import com.utils.R;

/**
 * 住院消费
 * 后端接口
 * @author
 * @email
 * @date 2021-04-08
*/
@RestController
@Controller
@RequestMapping("/xiaofeijilu")
public class XiaofeijiluController {
    private static final Logger logger = LoggerFactory.getLogger(XiaofeijiluController.class);

    @Autowired
    private XiaofeijiluService xiaofeijiluService;


    @Autowired
    private ZhuyuanService zhuyuanService;
    @Autowired
    private TokenService tokenService;
    @Autowired
    private DictionaryService dictionaryService;


    //级联表service
    @Autowired
    private BingrenService bingrenService;


    /**
    * 后端列表
    */
    @RequestMapping("/page")
    public R page(@RequestParam Map<String, Object> params, HttpServletRequest request){
        logger.debug("page方法:,,Controller:{},,params:{}",this.getClass().getName(),JSONObject.toJSONString(params));
        String role = String.valueOf(request.getSession().getAttribute("role"));
        if(StringUtil.isNotEmpty(role) && "医生".equals(role)){
            params.put("yishengId",request.getSession().getAttribute("userId"));
        }
        if(StringUtil.isNotEmpty(role) && "护士".equals(role)){
            params.put("yonghuId",request.getSession().getAttribute("userId"));
        }
        params.put("orderBy","id");
        PageUtils page = xiaofeijiluService.queryPage(params);

        //字典表数据转换
        List<XiaofeijiluView> list =(List<XiaofeijiluView>)page.getList();
        for(XiaofeijiluView c:list){
            //修改对应字典表字段
            dictionaryService.dictionaryConvert(c);
        }
        return R.ok().put("data", page);
    }

    /**
    * 后端详情
    */
    @RequestMapping("/info/{id}")
    public R info(@PathVariable("id") Long id){
        logger.debug("info方法:,,Controller:{},,id:{}",this.getClass().getName(),id);
        XiaofeijiluEntity xiaofeijilu = xiaofeijiluService.selectById(id);
        if(xiaofeijilu !=null){
            //entity转view
            XiaofeijiluView view = new XiaofeijiluView();
            BeanUtils.copyProperties( xiaofeijilu , view );//把实体数据重构到view中

            //级联表
            BingrenEntity bingren = bingrenService.selectById(xiaofeijilu.getBingrenId());
            if(bingren != null){
                BeanUtils.copyProperties( bingren , view ,new String[]{ "id", "createDate"});//把级联的数据添加到view中,并排除id和创建时间字段
                view.setBingrenId(bingren.getId());
            }
            //修改对应字典表字段
            dictionaryService.dictionaryConvert(view);
            return R.ok().put("data", view);
        }else {
            return R.error(511,"查不到数据");
        }

    }

    /**
    * 后端保存
    */
    @RequestMapping("/save")
    public R save(@RequestBody XiaofeijiluEntity xiaofeijilu, HttpServletRequest request){
        logger.debug("save方法:,,Controller:{},,xiaofeijilu:{}",this.getClass().getName(),xiaofeijilu.toString());
        Wrapper<XiaofeijiluEntity> queryWrapper = new EntityWrapper<XiaofeijiluEntity>()
            .eq("bingren_id", xiaofeijilu.getBingrenId())
            .eq("xiaofeijilu_money", xiaofeijilu.getXiaofeijiluMoney())
            ;
        logger.info("sql语句:"+queryWrapper.getSqlSegment());
        ZhuyuanEntity zhuyuanEntity = zhuyuanService.selectOne(
                new EntityWrapper<ZhuyuanEntity>().eq("bingren_id", xiaofeijilu.getBingrenId())
                        .eq("zhuyuan_types", 0));
        if(zhuyuanEntity == null){
            return R.error("住院后才可以添加住院消费信息");
        }
        if(zhuyuanEntity.getZhuyuanTypes() != 0){
            return R.error("这个病人已经出院了");
        }
        XiaofeijiluEntity xiaofeijiluEntity = xiaofeijiluService.selectOne(queryWrapper);
        if(xiaofeijiluEntity==null){
            xiaofeijilu.setInsertTime(new Date());
            xiaofeijilu.setCreateTime(new Date());
            xiaofeijiluService.insert(xiaofeijilu);
            zhuyuanEntity.setZhuyuanMoney(zhuyuanEntity.getZhuyuanMoney()+xiaofeijilu.getXiaofeijiluMoney());
            zhuyuanService.updateById(zhuyuanEntity);
            return R.ok();
        }else {
            return R.error(511,"表中有相同数据");
        }
    }

    /**
    * 后端修改
    */
    @RequestMapping("/update")
    public R update(@RequestBody XiaofeijiluEntity xiaofeijilu, HttpServletRequest request){
        logger.debug("update方法:,,Controller:{},,xiaofeijilu:{}",this.getClass().getName(),xiaofeijilu.toString());
        //根据字段查询是否有相同数据
        Wrapper<XiaofeijiluEntity> queryWrapper = new EntityWrapper<XiaofeijiluEntity>()
            .notIn("id",xiaofeijilu.getId())
            .andNew()
            .eq("bingren_id", xiaofeijilu.getBingrenId())
            .eq("xiaofeijilu_money", xiaofeijilu.getXiaofeijiluMoney())
            ;
        logger.info("sql语句:"+queryWrapper.getSqlSegment());
        XiaofeijiluEntity xiaofeijiluEntity = xiaofeijiluService.selectOne(queryWrapper);
        if(xiaofeijiluEntity==null){
            //  String role = String.valueOf(request.getSession().getAttribute("role"));
            //  if("".equals(role)){
            //      xiaofeijilu.set
            //  }
            xiaofeijiluService.updateById(xiaofeijilu);//根据id更新
            return R.ok();
        }else {
            return R.error(511,"表中有相同数据");
        }
    }


    /**
    * 删除
    */
    @RequestMapping("/delete")
    public R delete(@RequestBody Integer[] ids){
        logger.debug("delete:,,Controller:{},,ids:{}",this.getClass().getName(),ids.toString());
        xiaofeijiluService.deleteBatchIds(Arrays.asList(ids));
        return R.ok();
    }



}


获取源码或论文

如需对应的论文或源码,以及其他定制需求,也可以下方微信联系我。

  • 4
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值