如何使用ssm实现宠物医院信息管理系统

252 篇文章 0 订阅
151 篇文章 0 订阅

@TOC

10920ssm宠物医院信息管理系统

系统概述

进过系统的分析后,就开始记性系统的设计,系统设计包含总体设计和详细设计。总体设计只是一个大体的设计,经过了总体设计,我们能够划分出系统的一些东西,例如文件、文档、数据等。而且我们通过总体设计,大致可以划分出了程序的模块,以及功能。但是只是一个初步的分类,并没有真正的实现。

整体设计,只是一个初步设计,而且,对于一个项目,我们可以进行多个整体设计,通过对比,包括性能的对比、成本的对比、效益的对比,来最终确定一个最优的设计方案,选择优秀的整体设计可以降低开发成本,增加公司效益,从这一点来讲,整体设计还是非常重要的。

宠物医院信息管理系统工作原理图如图4-1所示:

图4-1 系统工作原理图

4.2 系统结构设计

系统架构图属于系统设计阶段,系统架构图只是这个阶段一个产物,系统的总体架构决定了整个系统的模式,是系统的基础。宠物医院信息管理系统的整体结构设计如图4-2所示。

图4-2 系统结构图

4.3数据库设计

数据库是计算机信息系统的基础。目前,电脑系统的关键与核心部分就是数据库。数据库开发的优劣对整个系统的质量和速度有着直接影响。

4.3.1 数据库设计原则

数据库的概念结构设计采用实体—联系(E-R)模型设计方法。E-R模型法的组成元素有:实体、属性、联系,E-R模型用E-R图表示,是提示用户工作环境中所涉及的事物,属性则是对实体特性的描述。在系统设计当中数据库起着决定性的因素。下面设计出这几个关键实体的实体—关系图。

4.3.2 数据库实体

数据模型中的实体(Entity),也称为实例,对应现实世界中可区别于其他对象的“事件”或“事物”。例如,公司中的每个用户,家里中的每个家具。

本系统的E-R图如下图所示:

1、医生信息实体图如图4-3所示:

图4-3医生信息实体图

2、医嘱信息实体图如图4-4所示:

图4-4医嘱信息实体图

3、订单信息实体图如图4-5所示:

图4-5订单信息实体图

#########

4.3.3 数据库表设计

数据库的表信息属于设计的一部分,下面介绍数据库中的各个表的详细信息。

表4-1 allusers表

|列名|数据类型|长度|约束| | :-: | :-: | - | :-: | |id|int|11|NOT NULL| |username|varchar|50|default NULL| |pwd|varchar|50|default NULL| |cx|varchar|50|default NULL|

表4-2 keshixinxi表

|列名|数据类型|长度|约束| | :-: | :-: | - | :-: | |id|int|11|NOT NULL| |addtime|varchar|50|default NULL| |keshimingcheng|varchar|50|default NULL| |tupian|varchar|50|default NULL| |yishengrenshu|varchar|50|default NULL| |keshijianjie|varchar|50|default NULL|

表4-3:yaopinxinxi表

列名数据类型长度约束
idint11NOT NULL
addtimevarchar50default NULL
yaopinmingchengvarchar50default NULL
tupianvarchar50default NULL
guigevarchar50default NULL
shengchanshangvarchar50default NULL
shuliangvarchar50default NULL
jiagevarchar50default NULL
shengchanshangvarchar50default NULL
shuliangvarchar50default NULL
jiagevarchar50default NULL
yaopinxiangqingvarchar50default NULL

表4-4 yisheng表

|列名|数据类型|长度|约束| | :-: | :-: | - | :-: | |id|int|11|NOT NULL| |addtime|varchar|50|default NULL| |yishenggonghao|varchar|50|default NULL| |mima|varchar|50|default NULL| |yishengxingming|varchar|50|default NULL| |touxiang|varchar|50|default NULL| |xingbie|varchar|50|default NULL| |lianxifangshi|varchar|50|default NULL|

表4-5 yishengxinxi表

|列名|数据类型|长度|约束| | :-: | :-: | - | :-: | |id|int|11|NOT NULL| |addtime|varchar|50|default NULL| |yishenggonghao|varchar|50|default NULL| |touxiang|varchar|50|default NULL| |yishengxingming|varchar|50|default NULL| |xingbie|varchar|50|default NULL| |yiling|varchar|50|default NULL| |shanzhanglingyu|varchar|50|default NULL| |keshimingcheng|varchar|50|default NULL| |gerenjianjie|varchar|50|default NULL|

5统详细设计

5.1前台首页功能模块

宠物医院信息管理系统,在系统首页可以查看首页、医学知识、医生信息、药品信息、新闻资讯、留言反馈、我的、跳转到后台等内容,如图5-1所示。

图5-1前台首页功能界面图

用户登录、用户注册,在注册页面可以填写用户名、密码、用户姓名、手机号码等信息进行注册、登录,如图5-2所

示。

图5-2用户注册、用户登录界面图 ######### 个人中心,在个人中心页面通过填写用户名、密码、用户姓名、头像、性别、手机号码等信息进行更新信息、退出登录,如图5-3所示。在医生信息页面通过查看医生工号、头像、医生姓名、性别、医龄、擅长领域、科室名称、个人简介等信息进行预约挂号操作,如图5-4所示。

图5-3个人中心界面图 #########

图5-4医生信息界面图

5.2管理员功能模块

管理员登录,通过填写用户名、密码进行登录,如图5-5所示。

图5-5管理员登录界面图

管理员登录进入宠物医院信息管理系统可以查看个人中心、用户管理、医生管理、医学知识管理、科室信息管理、医生信息管理、预约挂号管理、医嘱信息管理、药品信息管理、订单信息管理、留言板管理、系统管理等信息。

用户管理,在用户管理页面中可以通过查看用户名、用户姓名、头像、性别、手机号码等内容进行详情、修改、删除,如图5-6所示。还可以根据需要对医生管理进行详情,修改等详细操作,如图5-7所示。

图5-6用户管理界面图

图5-7医生管理界面图

医学知识管理,在医学知识管理页面中可以查看文章标题、图片、文章内容、发布日期等信息,并可根据需要对已有医学知识管理进行修改或删除等操作,如图5-8所示。

图5-8医学知识管理界面图

科室信息管理,在科室信息管理页面中可以查看科室名称、图片、医生人数、科室简介等信息,并可根据需要对已有科室信息管理进行修改或删除等详细操作,如图5-9所示。

图5-9科室信息管理界面图

医生信息管理,在医生信息管理页面中可以查看医生工号、头像、医生姓名、性别、医龄、擅长领域、科室名称、个人简介等内容,并且根据需要对已有医生信息管理进行详情,修改或删除等详细操作,如图5-10所示。

图5-10医生信息管理界面图

轮播图;该页面为轮播图管理界面。管理员可以在此页面进行首页轮播图的管理,通过新建操作可在轮播图中加入新的图片,还可以对以上传的图片进行修改操作,以及图片的删除操作,如图5-11所示。

图5-11轮播图管理界面图

订单信息管理,在订单信息管理页面中可以查看订单编号、药品名称、规格、生产商、数量、价格、总金额、用户名、用户姓名、是否支付等内容,并且根据需要对已有订单信息管理进行详情,修改或删除等详细操作,如图5-12所示。

图5-12订单信息管理界面图

5.3医生功能模块

医生登录进入宠物医院信息管理系统可以查看个人中心、预约挂号管理、医嘱信息管理等内容。

预约挂号管理,在预约挂号管理页面中通过查看用户名、用户姓名、手机号码、宠物名、宠物状况、预约日期、医生工号、医生姓名、科室名称、是否审核、审核回复等信息,还可以根据需要对预约挂号管理进行修改,如图5-13所示。

图5-13预约挂号管理界面图

医嘱信息管理,在医嘱信息管理页面中可以查看用户名、用户姓名、宠物名、宠物状况、医嘱、日期、医生工号、医生姓名、科室等信息,并且根据需要对已有医嘱信息管理进行查看删除等其他详细操作,如图5-14所示。

图5-14医嘱信息管理界面图 #########

5.4用户功能模块

用户登录进入宠物医院信息管理系统可以查看个人中心、预约挂号管理、医嘱信息管理、订单信息管理等内容。

订单信息管理,在订单信息管理页面中通过查看订单编号、药品名称、规格、生产商、数量、价格、总金额、用户名、用户姓名、是否支付等信息,还可以根据需要对订单信息管理进行修改,如图5-15所示。

图5-15订单信息管理界面图

YixuezhishiController.java
package com.controller;

import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Calendar;
import java.util.Map;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Date;
import java.util.List;
import javax.servlet.http.HttpServletRequest;

import com.utils.ValidatorUtils;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.format.annotation.DateTimeFormat;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.baomidou.mybatisplus.mapper.Wrapper;
import com.annotation.IgnoreAuth;

import com.entity.YixuezhishiEntity;
import com.entity.view.YixuezhishiView;

import com.service.YixuezhishiService;
import com.service.TokenService;
import com.utils.PageUtils;
import com.utils.R;
import com.utils.MD5Util;
import com.utils.MPUtil;
import com.utils.CommonUtil;


/**
 * 医学知识
 * 后端接口
 * @author 
 * @email 
 * @date 2021-03-11 11:23:12
 */
@RestController
@RequestMapping("/yixuezhishi")
public class YixuezhishiController {
    @Autowired
    private YixuezhishiService yixuezhishiService;
    


    /**
     * 后端列表
     */
    @RequestMapping("/page")
    public R page(@RequestParam Map<String, Object> params,YixuezhishiEntity yixuezhishi, 
		HttpServletRequest request){

        EntityWrapper<YixuezhishiEntity> ew = new EntityWrapper<YixuezhishiEntity>();
    	PageUtils page = yixuezhishiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, yixuezhishi), params), params));
		request.setAttribute("data", page);
        return R.ok().put("data", page);
    }
    
    /**
     * 前端列表
     */
	@IgnoreAuth
    @RequestMapping("/list")
    public R list(@RequestParam Map<String, Object> params,YixuezhishiEntity yixuezhishi, HttpServletRequest request){
        EntityWrapper<YixuezhishiEntity> ew = new EntityWrapper<YixuezhishiEntity>();
    	PageUtils page = yixuezhishiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, yixuezhishi), params), params));
		request.setAttribute("data", page);
        return R.ok().put("data", page);
    }

	/**
     * 列表
     */
    @RequestMapping("/lists")
    public R list( YixuezhishiEntity yixuezhishi){
       	EntityWrapper<YixuezhishiEntity> ew = new EntityWrapper<YixuezhishiEntity>();
      	ew.allEq(MPUtil.allEQMapPre( yixuezhishi, "yixuezhishi")); 
        return R.ok().put("data", yixuezhishiService.selectListView(ew));
    }

	 /**
     * 查询
     */
    @RequestMapping("/query")
    public R query(YixuezhishiEntity yixuezhishi){
        EntityWrapper< YixuezhishiEntity> ew = new EntityWrapper< YixuezhishiEntity>();
 		ew.allEq(MPUtil.allEQMapPre( yixuezhishi, "yixuezhishi")); 
		YixuezhishiView yixuezhishiView =  yixuezhishiService.selectView(ew);
		return R.ok("查询医学知识成功").put("data", yixuezhishiView);
    }
	
    /**
     * 后端详情
     */
    @RequestMapping("/info/{id}")
    public R info(@PathVariable("id") Long id){
        YixuezhishiEntity yixuezhishi = yixuezhishiService.selectById(id);
        return R.ok().put("data", yixuezhishi);
    }

    /**
     * 前端详情
     */
	@IgnoreAuth
    @RequestMapping("/detail/{id}")
    public R detail(@PathVariable("id") Long id){
        YixuezhishiEntity yixuezhishi = yixuezhishiService.selectById(id);
        return R.ok().put("data", yixuezhishi);
    }
    



    /**
     * 后端保存
     */
    @RequestMapping("/save")
    public R save(@RequestBody YixuezhishiEntity yixuezhishi, HttpServletRequest request){
    	yixuezhishi.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
    	//ValidatorUtils.validateEntity(yixuezhishi);

        yixuezhishiService.insert(yixuezhishi);
        return R.ok();
    }
    
    /**
     * 前端保存
     */
    @RequestMapping("/add")
    public R add(@RequestBody YixuezhishiEntity yixuezhishi, HttpServletRequest request){
    	yixuezhishi.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
    	//ValidatorUtils.validateEntity(yixuezhishi);

        yixuezhishiService.insert(yixuezhishi);
        return R.ok();
    }

    /**
     * 修改
     */
    @RequestMapping("/update")
    public R update(@RequestBody YixuezhishiEntity yixuezhishi, HttpServletRequest request){
        //ValidatorUtils.validateEntity(yixuezhishi);
        yixuezhishiService.updateById(yixuezhishi);//全部更新
        return R.ok();
    }
    

    /**
     * 删除
     */
    @RequestMapping("/delete")
    public R delete(@RequestBody Long[] ids){
        yixuezhishiService.deleteBatchIds(Arrays.asList(ids));
        return R.ok();
    }
    
    /**
     * 提醒接口
     */
	@RequestMapping("/remind/{columnName}/{type}")
	public R remindCount(@PathVariable("columnName") String columnName, HttpServletRequest request, 
						 @PathVariable("type") String type,@RequestParam Map<String, Object> map) {
		map.put("column", columnName);
		map.put("type", type);
		
		if(type.equals("2")) {
			SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
			Calendar c = Calendar.getInstance();
			Date remindStartDate = null;
			Date remindEndDate = null;
			if(map.get("remindstart")!=null) {
				Integer remindStart = Integer.parseInt(map.get("remindstart").toString());
				c.setTime(new Date()); 
				c.add(Calendar.DAY_OF_MONTH,remindStart);
				remindStartDate = c.getTime();
				map.put("remindstart", sdf.format(remindStartDate));
			}
			if(map.get("remindend")!=null) {
				Integer remindEnd = Integer.parseInt(map.get("remindend").toString());
				c.setTime(new Date());
				c.add(Calendar.DAY_OF_MONTH,remindEnd);
				remindEndDate = c.getTime();
				map.put("remindend", sdf.format(remindEndDate));
			}
		}
		
		Wrapper<YixuezhishiEntity> wrapper = new EntityWrapper<YixuezhishiEntity>();
		if(map.get("remindstart")!=null) {
			wrapper.ge(columnName, map.get("remindstart"));
		}
		if(map.get("remindend")!=null) {
			wrapper.le(columnName, map.get("remindend"));
		}


		int count = yixuezhishiService.selectCount(wrapper);
		return R.ok().put("count", count);
	}
	
	


}

YixuezhishiServiceImpl.java
package com.service.impl;

import org.springframework.stereotype.Service;
import java.util.Map;
import java.util.List;

import com.baomidou.mybatisplus.mapper.Wrapper;
import com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.baomidou.mybatisplus.plugins.Page;
import com.baomidou.mybatisplus.service.impl.ServiceImpl;
import com.utils.PageUtils;
import com.utils.Query;


import com.dao.YixuezhishiDao;
import com.entity.YixuezhishiEntity;
import com.service.YixuezhishiService;
import com.entity.vo.YixuezhishiVO;
import com.entity.view.YixuezhishiView;

@Service("yixuezhishiService")
public class YixuezhishiServiceImpl extends ServiceImpl<YixuezhishiDao, YixuezhishiEntity> implements YixuezhishiService {


    @Override
    public PageUtils queryPage(Map<String, Object> params) {
        Page<YixuezhishiEntity> page = this.selectPage(
                new Query<YixuezhishiEntity>(params).getPage(),
                new EntityWrapper<YixuezhishiEntity>()
        );
        return new PageUtils(page);
    }
    
    @Override
	public PageUtils queryPage(Map<String, Object> params, Wrapper<YixuezhishiEntity> wrapper) {
		  Page<YixuezhishiView> page =new Query<YixuezhishiView>(params).getPage();
	        page.setRecords(baseMapper.selectListView(page,wrapper));
	    	PageUtils pageUtil = new PageUtils(page);
	    	return pageUtil;
 	}
    
    @Override
	public List<YixuezhishiVO> selectListVO(Wrapper<YixuezhishiEntity> wrapper) {
 		return baseMapper.selectListVO(wrapper);
	}
	
	@Override
	public YixuezhishiVO selectVO(Wrapper<YixuezhishiEntity> wrapper) {
 		return baseMapper.selectVO(wrapper);
	}
	
	@Override
	public List<YixuezhishiView> selectListView(Wrapper<YixuezhishiEntity> wrapper) {
		return baseMapper.selectListView(wrapper);
	}

	@Override
	public YixuezhishiView selectView(Wrapper<YixuezhishiEntity> wrapper) {
		return baseMapper.selectView(wrapper);
	}

}

YuyueguahaoServiceImpl.java
package com.service.impl;

import org.springframework.stereotype.Service;
import java.util.Map;
import java.util.List;

import com.baomidou.mybatisplus.mapper.Wrapper;
import com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.baomidou.mybatisplus.plugins.Page;
import com.baomidou.mybatisplus.service.impl.ServiceImpl;
import com.utils.PageUtils;
import com.utils.Query;


import com.dao.YuyueguahaoDao;
import com.entity.YuyueguahaoEntity;
import com.service.YuyueguahaoService;
import com.entity.vo.YuyueguahaoVO;
import com.entity.view.YuyueguahaoView;

@Service("yuyueguahaoService")
public class YuyueguahaoServiceImpl extends ServiceImpl<YuyueguahaoDao, YuyueguahaoEntity> implements YuyueguahaoService {


    @Override
    public PageUtils queryPage(Map<String, Object> params) {
        Page<YuyueguahaoEntity> page = this.selectPage(
                new Query<YuyueguahaoEntity>(params).getPage(),
                new EntityWrapper<YuyueguahaoEntity>()
        );
        return new PageUtils(page);
    }
    
    @Override
	public PageUtils queryPage(Map<String, Object> params, Wrapper<YuyueguahaoEntity> wrapper) {
		  Page<YuyueguahaoView> page =new Query<YuyueguahaoView>(params).getPage();
	        page.setRecords(baseMapper.selectListView(page,wrapper));
	    	PageUtils pageUtil = new PageUtils(page);
	    	return pageUtil;
 	}
    
    @Override
	public List<YuyueguahaoVO> selectListVO(Wrapper<YuyueguahaoEntity> wrapper) {
 		return baseMapper.selectListVO(wrapper);
	}
	
	@Override
	public YuyueguahaoVO selectVO(Wrapper<YuyueguahaoEntity> wrapper) {
 		return baseMapper.selectVO(wrapper);
	}
	
	@Override
	public List<YuyueguahaoView> selectListView(Wrapper<YuyueguahaoEntity> wrapper) {
		return baseMapper.selectListView(wrapper);
	}

	@Override
	public YuyueguahaoView selectView(Wrapper<YuyueguahaoEntity> wrapper) {
		return baseMapper.selectView(wrapper);
	}

}

de-DE.js
if(!window.calendar_languages) {
	window.calendar_languages = {};
}
window.calendar_languages['de-DE'] = {
	error_noview: 'Kalender: View {0} nicht gefunden',
	error_dateformat: 'Kalender: Falsches Datumsformat {0}. Sollte entweder "now" oder "yyyy-mm-dd" sein',
	error_loadurl: 'Kalender: Event-URL nicht gesetzt.',
	error_where: 'Kalender: Falsche Navigationsrichtung {0}. Nur "next", "prev" oder "today" sind erlaubt',

	no_events_in_day: 'Keine Ereignisse an diesem Tag.',

	title_year: '{0}',
	title_month: '{0} {1}',
	title_week: 'Woche {0} im Jahr {1}',
	title_day: '{0}, der {1}. {2} {3}',

	week:'Woche',

	m0: 'Januar',
	m1: 'Februar',
	m2: 'März',
	m3: 'April',
	m4: 'Mai',
	m5: 'Juni',
	m6: 'Juli',
	m7: 'August',
	m8: 'September',
	m9: 'Oktober',
	m10: 'November',
	m11: 'Dezember',

	ms0: 'Jan',
	ms1: 'Feb',
	ms2: 'Mär',
	ms3: 'Apr',
	ms4: 'Mai',
	ms5: 'Jun',
	ms6: 'Jul',
	ms7: 'Aug',
	ms8: 'Sep',
	ms9: 'Okt',
	ms10: 'Nov',
	ms11: 'Dez',

	d0: 'Sonntag',
	d1: 'Montag',
	d2: 'Dienstag',
	d3: 'Mittwoch',
	d4: 'Donnerstag',
	d5: 'Freitag',
	d6: 'Samstag',

	first_day: 1,

	holidays: {
		'01-01': 'Neujahr',
		'easter-2': 'Karfreitag',
		'easter+1': 'Ostermontag',
		'01-05': 'Erster Mai',
		'easter+39': 'Himmelfahrt',
		'easter+49': 'Pfingstsonntag',
		'easter+49': 'Pfingstmontag',
		'03-10': 'Tag der Deutschen Einheit',
		'25-12': 'Erster Weihnachtsfeiertag',
		'26-12': 'Zweiter Weihnachtsfeiertag',
	}
};

声明

本博客适用于广泛的学术和教育用途,包括但不限于个人学习、开发设计,产品设计。仅供学习参考,旨在为读者提供深入理解和学术研究的材料。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值