毕业设计-基于JAVA的机场航班起降与协调管理系统

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: 毕业设计-基于JAVA的机场航班起降与协调管理系统

一,环境介绍

语言环境:Java:  jdk1.8

数据库:Mysql: mysql5.7

应用服务器:Tomcat:  tomcat8.5.31

开发工具:IDEA或eclipse

二,项目简介

随着社会的发展和科技的进步,信息化时代的到来,各种智能的用电设备也随之而来,到目前为止最原始、最普遍的也就是计算机的使用,计算机软件的出现是计算机科学进步的非常大的转折点,对于计算机软件,现代计算机软件编写程序语言中用途最广泛的莫过于JAVA。在各种编程语言发展的今天,其仍然牢牢占据着计算机语言的核心地位,并衍生出Jsp、JavaEE和Struts2等多种先进的计算机技术,为计算机和软件科学的发展做出了巨大的贡献,也为人类的生产和现代社会的发展做出了非常卓越的贡献,各种基于Java的电脑软件和手机app面向市场开放。在航班飞行安全方面,据不完全统计,航班83.5%的事故发生在航班的起飞和降落阶段,2016年10月11日发生的虹桥机场跑道入侵事件充分说明了在机场调度和机长与塔台沟通的及时和清楚的指令发布对航班飞行安全的重要性,为了安全地帮助地面指挥员实行航班调度的重大职责,航班起降与协调管理系统就显得尤为重要了,他能实时管理航班信息,建立地面指挥员与机长之间的指令通信,这样对于航班飞行安全尤其是在机场及其空域时的航班飞行安全起到了至关重要的作用。

Java语言在现代计算机编程上是核心的且运用范围最广的语言,Java是面向对象的开元的一种计算机语言,运用广泛且灵活,且Java系统稳定,用Java语言进行编程是一种很好的选择。

通过此次项目编写一个基于Java的机场航班起降与协调系统(机场航班调度系统)。通过此系统帮助机场地面指挥人员进行更加明确的航班调度和指令发送,尽可能减少航班调度的错误率,尽可能规避航班调度错误的风险,极大程度地避免空难的发生。减少地面指挥人员指令发布的失误率,与航班建立数据上的可视的指令发布,使航班在可能的无线电干扰的情况下可以正常起降。实时管理航班信息,建立地面指挥员与机长之间的指令通信。

本次项目是设计一个基于JAVA的机场航班起降与协调管理系统。

(1)在经济可行性上来分析的话,该软件是机场内部使用的一个指挥协调软件,属于航空安全投资,本软件开发成本并不高,软件和服务器数据库可以用机场原有的数据库进行开发,比起空难给航空公司造成的损失来说九牛一毛。

(2)在技术可行性上来分析的话,该软件主要运用了Java技术、jQuery-easyui和Mysql数据库技术。Java是到目前来说最稳定的、最可靠的软件开发工具;jQuery-easyui虽然是比较新的前台开发技术,但是他的界面新颖整洁,适合于功能性软件的开发;Mysql数据库也是许多大公司都采用的软件项目开发数据库,不仅稳定而且性能可靠,可以用作本次软件的开发。

(3)在法律可行性上来分析的话,该软件使用的技术都为开源的软件开发工具和语言,虽然Java等开发技术都存在Sun公司的版权问题,但是Java技术是可以免费使用的,没有涉及到法律上的侵权。

(4)在方案可行性上来分析的话,此次软件开发的很大一部分精力都放在了软件的需求分析和设计方面,设计出来的软件可以很好地去实现我们所要完成的软件预先设计的功能。

三,系统展示

本项目分为地面指挥人员端和机长端两个端口来进行描述。

1.地面指挥人员端在未登陆的情况下,不能进入系统主界面,只有在登录后才可以进入指挥员界面,对航班信息进行浏览;然后查看是否有飞机晚点航班信息需要修改、取消航班以及添加航班;之后获取指定航班动态,并发送与接收指令,直至航班离开机场管辖空域脱离管制。对待降落航班下达降落指令和接收航班请求,直至航班降落完成。

图4-2 用户端流程图

2.机长端在登录状态下,才可以进行机长端操作,机长首先查看航班信息,然后更新航班状态,对塔台发送请求并接收塔台指令,并实时更新航班状态,直至航班完成起飞或降落动作。

图4-3 机长端流程图

6.1.1 指挥员登陆

打开软件,进入地面指挥登录界面,如图6-1所示:

图6-1 地面指挥登录界面

地面指挥员登录页面用户名为userName,密码为password,登录按钮为submit按钮,重置按钮为button按钮。

当点击登录时,服务器会进行用户名密码的验证,当用户名和密码为空时,显示用户名密码为空;当用户名密码错误时显示用户名密码错误。当验证正确时,跳转到index.jsp页面,运用到了数据传递的doget和dopost的方法。下面列出了doGet和doPost的主要方法,服务器端部分代码如下:

    protected void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        this.doPost(request, response);
    }
    protected void doPost(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        String userName=request.getParameter("userName");
        String password=request.getParameter("password");
        request.setAttribute("userName", userName);
        request.setAttribute("password", password);
}
  1. 机长登录

打开软件,出现机长登录界面,如图6-2所示:

图6-2 机长登录界面

机长登录页面用户名为userName,密码为password,登录按钮为submit按钮,重置按钮为button按钮。

当点击登录时,服务器会进行用户名密码的验证,当用户名和密码为空时,显示用户名密码为空、当用户名密码错误时显示用户名密码错误。当用户名密码验证正确时,跳转到index.jsp页面服务器端代码与地面指挥端服务器代码一致。

  1. 主界面的实现

6.2.1 地面指挥端主界面的实现

当登录成功后,进入地面指挥端主界面,主界面由功能菜单和含有两个分页的树组成主界面的功能,主界面由jquery-easyui实现。右上角可以读取当前登录的指挥员姓名和现在时间,左侧功能栏可以选择隐藏和显示。当点击树中相应的按钮时,触发服务器响应弹出对应窗口,窗口可以关闭。如图6-3所示:

图6-3 地面指挥系统主界面

      左侧树中两个分页运用了jquery获取分页的值,其的跳转代码为:

         

$(function(){
        //数据
        var treeData=[{
            text:"根",
            children:[{
                text:"航班信息管理",
                attributes:{
                    url:"gradeInfoManage.jsp"
                }
            },{
                text:"航班指挥信息管理",
                attributes:{
                    url:"standardInfoManage.jsp"
                }
            }]
        }];

     

右侧从登录页面获取地面指挥员的登录名,运用了jQuery语言,其代码为:

<div style="padding-top:10px;padding-rignt:20px;">当前用户: <font color="red" size="4">${currentUser.userName}</font></div>

     

若用户想不经过登录直接访问主页面,则是行不通的,因为页面中还加入了权限设置,防止跳过登录直接访问main页面,其代码为:

if(session.getAttribute("currentUser")==null){
        response.sendRedirect("index.jsp");
        return;
    }

在网页中还加入了一个时间控件,其代码为:

 function startTime()    
     {    
         var today=new Date();//定义日期对象    
         var yyyy = today.getFullYear();//通过日期对象的getFullYear()方法返回年     
         var MM = today.getMonth()+1;//通过日期对象的getMonth()方法返回年     
         var dd = today.getDate();//通过日期对象的getDate()方法返回年      
         var hh=today.getHours();//通过日期对象的getHours方法返回小时    
         var mm=today.getMinutes();//通过日期对象的getMinutes方法返回分钟    
         var ss=today.getSeconds();//通过日期对象的getSeconds方法返回秒    
         // 如果分钟或小时的值小于10,则在其值前加0,比如如果时间是下午3点20分9秒的话,则显示15:20:09    
         MM=checkTime(MM); 
         dd=checkTime(dd); 
         mm=checkTime(mm);    
         ss=checkTime(ss);     
         var day; //用于保存星期(getDay()方法得到星期编号) 
         if(today.getDay()==0)   day   =   "星期日 "  
         if(today.getDay()==1)   day   =   "星期一 "  
         if(today.getDay()==2)   day   =   "星期二 "  
         if(today.getDay()==3)   day   =   "星期三 "  
         if(today.getDay()==4)   day   =   "星期四 "  
         if(today.getDay()==5)   day   =   "星期五 "  
         if(today.getDay()==6)   day   =   "星期六 "  
         document.getElementById('nowDateTimeSpan').innerHTML=yyyy+"-"+MM +"-"+ dd +" " + hh+":"+mm+":"+ss+"   " + day;    
         setTimeout('startTime()',1000);//每一秒中重新加载startTime()方法  
     }
  1. 机长端主界面的实现

当登录成功后,进入机长端主界面,主界面由功能菜单和含有两个分页的树组成主界面的功能,主界面由jquery-easyui实现。右上角可以读取当前登录的机长姓名和现在时间,左侧功能栏可以选择隐藏和显示。当点击树中相应的按钮时,触发服务器响应弹出对应窗口,窗口可以关闭,和地面指挥端功能相类似。如图6-4所示:

图6-4 机长系统客户端主界面

  1. 地面指挥管理功能的实现

6.3.1 地面指挥端航班信息管理功能的实现

点击地面指挥端中的航班信息管理按钮,弹出航班信息管理界面,界面可以关闭和刷新。航班可以进行搜索、添加、修改和删除等操作。若地面指挥人员想要查看指定信息的航班,那么输入航班名称即可搜索出对应的航班;若航班加出班次,则地面指挥人员可以点击添加添加航班信息,但是航班状态需要由机长进行填写;若航班班次取消,则点击删除按钮删除要取消的航班,若误点了已经起飞或者降落的航班的删除按钮,则弹出窗口航班正在运行,不能进行删除;若航班修改了架次,则点击修改按钮进行航班信息的修改。如图6-5所示

图6-5 航班信息管理

显示航班信息需要读取数据库,进行搜索操作时也需要读取数据库,其读取数据库的部分代码如下:

     

public ResultSet gradeList(Connection con,PageBean pageBean,Grade grade)throws Exception{
        StringBuffer sb=new StringBuffer("select * from t_grade");
        PreparedStatement pstmt=con.prepareStatement(sb.toString().replaceFirst("and", "where"));
        return pstmt.executeQuery();
    }
    public int gradeCount(Connection con,Grade grade)throws Exception{
        StringBuffer sb=new StringBuffer("select count(*) as total from t_grade");
            }

服务器端需要读取每一条数据的行和页,这里服务器端也运用了doget和dopost方法。

数据操作有添加功能、删除功能和修改功能,如图所示:

图6-6 添加航班信息

图6-7 修改航班信息

图6-8 删除航班信息

      在增加、修改航班信息时,航班信息的每个信息都是必输入项,所以设置一个输入字符的验证,用jquery进行验证直接调用easyui语句:required="true"

      在执行增加、删除和修改操作时,会在数据库中读取和写入信息以数据删除和添加为例,其代码为:

public int gradeDelete(Connection con,String delIds)throws Exception{
        String sql="delete from t_grade where id in("+delIds+")";
        PreparedStatement pstmt=con.prepareStatement(sql);
        return pstmt.executeUpdate();
    }
    public int gradeAdd(Connection con,Grade grade)throws Exception{
        String sql="insert into t_grade values(null,?,?,?,?)";
        PreparedStatement pstmt=con.prepareStatement(sql);
        pstmt.setString(1, grade.getGradeName());
        pstmt.setString(2, grade.getGradeDate());
        pstmt.setString(3, grade.getGradeLine());
        pstmt.setString(4, grade.getGradeState());
        return pstmt.executeUpdate();
    }

6.3.2 地面指挥端航班指挥信息管理功能的实现

从主页面点击航班指挥信息页面,打开航班指挥信息分页,如图6-9所示:

图6-9 航班指挥信息管理

航班指挥信息管理的主要功能是航班指令的发布、航班指令的修改和删除,还有不同的条件查询。我们这里提供了各种不同条件的航班指令信息查询方法方便航班指令信息的查看和管理。当收到航班发出的请求或者遇到情况时,地面指挥端点击发布指令进行指令的发布,在发布指令界面可以向任意一搜航班发送信息。当信息发送错误时,可以点击修改指令进行修改,或者点击删除指令重新对指令进行发布。如图:

图6-10 指令信息发布

图6-11修改指令信息

图6-12 删除指令信息

在显示航班指令信息和执行航班指令信息的操作时,都需要访问数据库或者将修改写入数据库,以指令信息的读取为例,则我们需要如下代码:

public ResultSet standardList(Connection con,PageBean pageBean,Standard standard)throws Exception{
        StringBuffer sb=new StringBuffer("select * from t_standard s,t_grade g where s.gradeId=g.id");
        return pstmt.executeQuery();
    }
    public int standardCount(Connection con,Standard standard)throws Exception{
        StringBuffer sb=new StringBuffer("select count(*) as total from t_standard s,t_grade g where s.gradeId=g.id");
        PreparedStatement pstmt=con.prepareStatement(sb.toString());
        ResultSet rs=pstmt.executeQuery();
    }

在删除航班信息时,如果航班已经发出指令,则不能删除航班,这就涉及到数据库的关联操作:

public boolean getStandardByGradeId(Connection con,String gradeId)throws Exception{
        String sql="select * from t_standard where gradeId=?";
        PreparedStatement pstmt=con.prepareStatement(sql);
        pstmt.setString(1, gradeId);
        ResultSet rs=pstmt.executeQuery();
        if(rs.next()){
            return true;
        }else{
            return false;
        }
    }
  1. 机长端功能的实现

6.4.1 机长端航班信息显示的实现

点击机长端中的航班信息查询按钮,弹出航班信息查询界面,界面可以关闭和刷新。可以查看此次航班的信息,并对航班现在的状态进行实时的更新。在机长想要查看自己所飞航班的信息时,点击下拉框,选择自己将要飞行的航班班次;若航班状态发生改变,则点击更新航班状态按钮对航班状态进行实时更新。如图6-13所示:

图6-13 航班信息查询

显示航班信息需要读取数据库,进行搜索操作时也需要读取数据库,其读取数据库的代码与地面指挥端的代码基本一致。

服务器端需要读取每一条数据的行和页,这里服务器端dopost和doget方法代码也和地面指挥端的代码基本一致。

对指定航班状态进行更新,如图所示:

图6-14 更新航班状态

      在更新航班状态时,会在数据库中读取和写入信息,代码为:

public int gradeCount(Connection con,Grade grade)throws Exception{
        StringBuffer sb=new StringBuffer("select count(*) as total from t_grade");
        if(StringUtil.isNotEmpty(grade.getGradeName())){
            sb.append(" and gradeName like '%"+grade.getGradeName()+"%'");
        }
        PreparedStatement pstmt=con.prepareStatement(sb.toString().replaceFirst("and", "where"));
        ResultSet rs=pstmt.executeQuery();
    }
public int gradeModify(Connection con,Grade grade)throws Exception{
        String sql="update t_grade set gradeName=?,gradeDate=?,gradeLine=?,gradeState=? where id=?";
        PreparedStatement pstmt=con.prepareStatement(sql);
        pstmt.setString(1, grade.getGradeName());
        pstmt.setString(2, grade.getGradeDate());
        pstmt.setString(3, grade.getGradeLine());
        pstmt.setString(4, grade.getGradeState());
        pstmt.setInt(5, grade.getId());
        return pstmt.executeUpdate();
    }

                                                     

6.4.2 地面指挥端航班指挥信息管理功能的实现

机长端航班指挥信息管理的主要功能是航班指令的发布、航班指令的修改和删除,还有不同的条件查询。我们这里提供了各种不同条件的航班指令信息查询方法方便航班指令信息的查看和管理。当收到塔台发出的请求或者遇到情况时,机长端点击发布指令进行请求指令的发布,在发布指令界面可以向塔台发送信息。当信息发送错误时,可以点击修改指令进行修改,或者点击删除指令重新对指令进行发布。如图6-15所示:

图6-15 航班指挥信息管理

航班指挥信息管理的主要功能是航班请求的发布、航班请求的修改和删除,还有不同的条件查询,如图:

图6-16 请求信息发布

图6-17修改请求信息

图6-12 删除请求信息

在显示航班指令信息和执行航班指令信息的操作时,都需要访问数据库或者将修改写入数据库,则我们需要如下代码来访问数据库:

public ResultSet standardList(Connection con,PageBean pageBean,Standard standard)throws Exception{
        StringBuffer sb=new StringBuffer("select * from t_standard s,t_grade g where s.gradeId=g.id");
        PreparedStatement pstmt=con.prepareStatement(sb.toString());
        return pstmt.executeQuery();
    }
    public int standardCount(Connection con,Standard standard)throws Exception{
        StringBuffer sb=new StringBuffer("select count(*) as total from t_standard s,t_grade g where s.gradeId=g.id");
        PreparedStatement pstmt=con.prepareStatement(sb.toString());
        ResultSet rs=pstmt.executeQuery();
    }

四,核心代码展示

package com.java1234.web;
import java.io.IOException;
import java.sql.Connection;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import net.sf.json.JSONArray;
import net.sf.json.JSONObject;
import com.java1234.dao.GradeDao;
import com.java1234.model.Grade;
import com.java1234.model.PageBean;
import com.java1234.util.DbUtil;
import com.java1234.util.JsonUtil;
import com.java1234.util.ResponseUtil;
public class GradeListServlet extends HttpServlet{
  DbUtil dbUtil=new DbUtil();
  GradeDao gradeDao=new GradeDao();
  @Override
  protected void doGet(HttpServletRequest request, HttpServletResponse response)
      throws ServletException, IOException {
    this.doPost(request, response);
  }
  @Override
  protected void doPost(HttpServletRequest request, HttpServletResponse response)
      throws ServletException, IOException {
    String page=request.getParameter("page");
    String rows=request.getParameter("rows");
    String gradeName=request.getParameter("gradeName");
    if(gradeName==null){
      gradeName="";
    }
    Grade grade=new Grade();
    grade.setGradeName(gradeName);
    PageBean pageBean=new PageBean(Integer.parseInt(page),Integer.parseInt(rows));
    Connection con=null;
    try{
      con=dbUtil.getCon();
      JSONObject result=new JSONObject();
      JSONArray jsonArray=JsonUtil.formatRsToJsonArray(gradeDao.gradeList(con, pageBean,grade));
      int total=gradeDao.gradeCount(con,grade);
      result.put("rows", jsonArray);
      result.put("total", total);
      ResponseUtil.write(response, result);
    }catch(Exception e){
      e.printStackTrace();
    }finally{
      try {
        dbUtil.closeCon(con);
      } catch (Exception e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
      }
    }
  }
}
package com.java1234.web;
import java.io.IOException;
import java.sql.Connection;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import net.sf.json.JSONArray;
import net.sf.json.JSONObject;
import com.java1234.dao.GradeDao;
import com.java1234.dao.StandardDao;
import com.java1234.model.Grade;
import com.java1234.model.PageBean;
import com.java1234.util.DbUtil;
import com.java1234.util.JsonUtil;
import com.java1234.util.ResponseUtil;
public class GradeDeleteServlet extends HttpServlet{
  DbUtil dbUtil=new DbUtil();
  GradeDao gradeDao=new GradeDao();
  StandardDao standardDao=new StandardDao();
  @Override
  protected void doGet(HttpServletRequest request, HttpServletResponse response)
      throws ServletException, IOException {
    this.doPost(request, response);
  }
  @Override
  protected void doPost(HttpServletRequest request, HttpServletResponse response)
      throws ServletException, IOException {
    String delIds=request.getParameter("delIds");
    Connection con=null;
    try{
      con=dbUtil.getCon();
      JSONObject result=new JSONObject();
      String str[]=delIds.split(",");
      for(int i=0;i<str.length;i++){
        boolean f=standardDao.getStandardByGradeId(con, str[i]);
        if(f){
          result.put("errorIndex",i);
          result.put("errorMsg", "航班有指令发出,为在运行航班,不能删除!");
          ResponseUtil.write(response, result);
          return;
        }
      }
      int delNums=gradeDao.gradeDelete(con, delIds);
      if(delNums>0){
        result.put("success", "true");
        result.put("delNums", delNums);
      }else{
        result.put("errorMsg", "删除失败");
      }
      ResponseUtil.write(response, result);
    }catch(Exception e){
      e.printStackTrace();
    }finally{
      try {
        dbUtil.closeCon(con);
      } catch (Exception e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
      }
    }
  }
}

五,相关作品展示

基于Java开发、Python开发、PHP开发、C#开发等相关语言开发的实战项目

基于Nodejs、Vue等前端技术开发的前端实战项目

基于微信小程序和安卓APP应用开发的相关作品

基于51单片机等嵌入式物联网开发应用

基于各类算法实现的AI智能应用

基于大数据实现的各类数据管理和推荐系统


相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2月前
|
Java Apache Maven
Java百项管理之新闻管理系统 熟悉java语法——大学生作业 有源码!!!可运行!!!
文章提供了使用Apache POI库在Java中创建和读取Excel文件的详细代码示例,包括写入数据到Excel和从Excel读取数据的方法。
65 6
Java百项管理之新闻管理系统 熟悉java语法——大学生作业 有源码!!!可运行!!!
|
1月前
|
监控 Java API
如何使用Java语言快速开发一套智慧工地系统
使用Java开发智慧工地系统,采用Spring Cloud微服务架构和前后端分离设计,结合MySQL、MongoDB数据库及RESTful API,集成人脸识别、视频监控、设备与环境监测等功能模块,运用Spark/Flink处理大数据,ECharts/AntV G2实现数据可视化,确保系统安全与性能,采用敏捷开发模式,提供详尽文档与用户培训,支持云部署与容器化管理,快速构建高效、灵活的智慧工地解决方案。
|
3月前
|
前端开发 JavaScript Java
基于Java+Springboot+Vue开发的服装商城管理系统
基于Java+Springboot+Vue开发的服装商城管理系统(前后端分离),这是一项为大学生课程设计作业而开发的项目。该系统旨在帮助大学生学习并掌握Java编程技能,同时锻炼他们的项目设计与开发能力。通过学习基于Java的服装商城管理系统项目,大学生可以在实践中学习和提升自己的能力,为以后的职业发展打下坚实基础。
192 2
基于Java+Springboot+Vue开发的服装商城管理系统
|
26天前
|
设计模式 消息中间件 搜索推荐
Java 设计模式——观察者模式:从优衣库不使用新疆棉事件看系统的动态响应
【11月更文挑战第17天】观察者模式是一种行为设计模式,定义了一对多的依赖关系,使多个观察者对象能直接监听并响应某一主题对象的状态变化。本文介绍了观察者模式的基本概念、商业系统中的应用实例,如优衣库事件中各相关方的动态响应,以及模式的优势和实际系统设计中的应用建议,包括事件驱动架构和消息队列的使用。
|
1月前
|
运维 自然语言处理 供应链
Java云HIS医院管理系统源码 病案管理、医保业务、门诊、住院、电子病历编辑器
通过门诊的申请,或者直接住院登记,通过”护士工作站“分配患者,完成后,进入医生患者列表,医生对应开具”长期医嘱“和”临时医嘱“,并在电子病历中,记录病情。病人出院时,停止长期医嘱,开具出院医嘱。进入出院审核,审核医嘱与住院通过后,病人结清缴费,完成出院。
98 3
|
1月前
|
Java 数据库连接 数据库
深入探讨Java连接池技术如何通过复用数据库连接、减少连接建立和断开的开销,从而显著提升系统性能
在Java应用开发中,数据库操作常成为性能瓶颈。本文通过问题解答形式,深入探讨Java连接池技术如何通过复用数据库连接、减少连接建立和断开的开销,从而显著提升系统性能。文章介绍了连接池的优势、选择和使用方法,以及优化配置的技巧。
41 1
|
1月前
|
JavaScript Java 项目管理
Java毕设学习 基于SpringBoot + Vue 的医院管理系统 持续给大家寻找Java毕设学习项目(附源码)
基于SpringBoot + Vue的医院管理系统,涵盖医院、患者、挂号、药物、检查、病床、排班管理和数据分析等功能。开发工具为IDEA和HBuilder X,环境需配置jdk8、Node.js14、MySQL8。文末提供源码下载链接。
|
2月前
|
移动开发 前端开发 JavaScript
java家政系统成品源码的关键特点和技术应用
家政系统成品源码是已开发完成的家政服务管理软件,支持用户注册、登录、管理个人资料,家政人员信息管理,服务项目分类,订单与预约管理,支付集成,评价与反馈,地图定位等功能。适用于各种规模的家政服务公司,采用uniapp、SpringBoot、MySQL等技术栈,确保高效管理和优质用户体验。
|
2月前
|
XML JSON 监控
告别简陋:Java日志系统的最佳实践
【10月更文挑战第19天】 在Java开发中,`System.out.println()` 是最基本的输出方法,但它在实际项目中往往被认为是不专业和不足够的。本文将探讨为什么在现代Java应用中应该避免使用 `System.out.println()`,并介绍几种更先进的日志解决方案。
62 1
|
2月前
|
Java 关系型数据库 API
介绍一款Java开发的企业接口管理系统和开放平台
YesApi接口管理平台Java版,基于Spring Boot、Vue.js等技术,提供API接口的快速研发、管理、开放及收费等功能,支持多数据库、Docker部署,适用于企业级PaaS和SaaS平台的二次开发与搭建。