24基于java的宠物医院管理系统

项目背景

随着互联网的普及,已经和我们的生活不可分割;宠物渐渐的已经成为了我们的好朋友,宠物医院管理系统可以帮助用户合理的管理宠物,呵护宠物的健康,对宠物起到了一个健康监控的作用;

项目介绍

系统总体分为3个角色:分别是系统管理员;医生和用户;不能的角色拥有不同的功能权限,下面详细介绍:
系统管理员:

  1. 系统设置
  2. 宠物管理
  3. 预约管理
  4. 日常健康
  5. 宠物档案管理
  6. 医院管理(预约统计,发布指南等等...)

医生:

  1. 宠物管理(宠物健康史 ...)
  2. 预约管理(预约管理,医生时间管理....)
  3. 宠物档案管理(宠物日志...)
  4. 医院管理(预约统计,发布指南等等...)

用户:

  1. 宠物管理(个人宠物列表,宠物健康史....)
  2. 预约管理(预约管理,医生时间管理....)
  3. 日常健康(健康指南,健康监测,健康标准....)
  4. 宠物档案管理(预约统计,宠物日志,日志图片分析...)

以上的权限都是可以由系统管理员重新分配的

项目环境

> 前端:html, css, js, layui, jquery等;
> 后端:java, spring,maven等
> 开发工具:eclipse或idea
> 数据库:mysql
> 更多内容可查看:http://projecthelp.top

部分核心代码

import org.springframework.stereotype.Service;
import xyz.shiguangliang.mybatis.dao.UserMapper;

import xyz.shiguangliang.mybatis.domain.User;
import xyz.shiguangliang.service.UserService;
import xyz.shiguangliang.util.query.QueryInfo;

import javax.annotation.Resource;
import java.util.Date;
import java.util.List;
import java.util.Objects;

@Service
public class UserServiceImpl implements UserService {
    @Resource
    private UserMapper userMapper;

    //登录
    @Override
    public User login(String username, String password) {
        User user = userMapper.selectLogin(username,password);
        if (user != null) {
            //登录次数加一
            if (user.getIntimes() !=  null) {
                user.setIntimes(user.getIntimes() + 1);
            }else {
                user.setIntimes(1);
            }
            //更新登录时间
            user.setLastlogin(new Date());
            return user;
        }
        return null;
    }

    //注册
    @Override
    public boolean register(User user) {
        int i = 0;
        //检测用户是否存在
        User user1 = userMapper.selectUsername(user.getUsername());
        if (user1 == null) {
            i = userMapper.insert(user);
        }
        return i > 0;
    }

    //用户列表
    @Override
    public QueryInfo getUserList(String query, Integer pagenum,Integer pagesize) {
        QueryInfo queryInfo = new QueryInfo();
        int start;
        int end;
        if (pagenum == null||pagesize == null){
            pagenum =0;
            pagesize = 3;
        }
        start = (pagenum-1)*pagesize;
        end = pagesize;
        int userSize = userMapper.selectUserListLimitSize(query,start,end);
        List<User> users = userMapper.selectUserListLimit(query,start,end);
        queryInfo.setList(users);
        queryInfo.setTotal(userSize);
        return queryInfo;
    }

    //删除用户
    @Override
    public int deleteUser(Integer tid) {
        return userMapper.deleteByPrimaryKey(tid);
    }

    //通过id查找用户
    @Override
    public User findById(Integer tid) {
        return userMapper.selectByPrimaryKey(tid);
    }



    //更新用户
    @Override
    public int updateUser(User user) {
        if (user.getPassword()==null|| Objects.equals(user.getPassword(), "")){
            user.setPassword(userMapper.selectByPrimaryKey(user.getTid()).getPassword());
        }
        return userMapper.updateByPrimaryKey(user);
    }

    //通过用户名查找用户
    @Override
    public User findByUsername(String username) {
        return userMapper.selectUsername(username);
    }

    //获取用户权限
    @Override
    public int getPower(String username) {
        return userMapper.selectUsername(username).getPower();
    }
}

useMapper.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="xyz.shiguangliang.mybatis.dao.UserMapper">
  <resultMap id="BaseResultMap" type="xyz.shiguangliang.mybatis.domain.User">
    <id column="tid" jdbcType="INTEGER" property="tid" />
    <result column="username" jdbcType="VARCHAR" property="username" />
    <result column="password" jdbcType="VARCHAR" property="password" />
    <result column="teachername" jdbcType="VARCHAR" property="teachername" />
    <result column="dno" jdbcType="INTEGER" property="dno" />
    <result column="power" jdbcType="INTEGER" property="power" />
    <result column="intimes" jdbcType="INTEGER" property="intimes" />
    <result column="lastlogin" jdbcType="TIMESTAMP" property="lastlogin" />
  </resultMap>
  <delete id="deleteByPrimaryKey" parameterType="java.lang.Integer">
    delete from teacher
    where tid = #{tid,jdbcType=INTEGER}
  </delete>
  <insert id="insert" parameterType="xyz.shiguangliang.mybatis.domain.User">
    insert into teacher (tid, username, password, 
      teachername, dno, power, 
      intimes, lastlogin)
    values (#{tid,jdbcType=INTEGER}, #{username,jdbcType=VARCHAR}, #{password,jdbcType=VARCHAR}, 
      #{teachername,jdbcType=VARCHAR}, #{dno,jdbcType=INTEGER}, #{power,jdbcType=INTEGER}, 
      #{intimes,jdbcType=INTEGER}, #{lastlogin,jdbcType=TIMESTAMP})
  </insert>
  <update id="updateByPrimaryKey" parameterType="xyz.shiguangliang.mybatis.domain.User">
    update teacher
    set username = #{username,jdbcType=VARCHAR},
      password = #{password,jdbcType=VARCHAR},
      teachername = #{teachername,jdbcType=VARCHAR},
      dno = #{dno,jdbcType=INTEGER},
      power = #{power,jdbcType=INTEGER},
      intimes = #{intimes,jdbcType=INTEGER},
      lastlogin = #{lastlogin,jdbcType=TIMESTAMP}
    where tid = #{tid,jdbcType=INTEGER}
  </update>
  <select id="selectByPrimaryKey" parameterType="java.lang.Integer" resultMap="BaseResultMap">
    select tid, username, password, teachername, dno, power, intimes, lastlogin
    from teacher
    where tid = #{tid,jdbcType=INTEGER}
  </select>
  <select id="selectAll" resultMap="BaseResultMap">
    select tid, username, password, teachername, dno, power, intimes, lastlogin
    from teacher
  </select>
    <select id="selectLogin" resultType="xyz.shiguangliang.mybatis.domain.User">
        select tid, username, password, teachername, dno, power, intimes, lastlogin
        from teacher
        where username = #{username} and password = #{password}
    </select>
  <select id="selectUsername" resultType="xyz.shiguangliang.mybatis.domain.User">
    select tid, username, password, teachername, dno, power, intimes, lastlogin
        from teacher
        where username = #{username}
  </select>
  <select id="selectUserListLimit" resultType="xyz.shiguangliang.mybatis.domain.User">
    select tid, username, password, teachername, dno, power, intimes, lastlogin
    from teacher
    where
    /*条件判断*/
    <if test="#{query} != null and #{query} != ''">
      /*模糊查询*/
      <bind name="query2" value="'%' + query + '%'"/>
      username like #{query2}
    </if>
    LIMIT #{start},#{end}
  </select>
  <select id="selectUserListLimitSize" resultType="java.lang.Integer">
    select count(*)
    from teacher
    where
    /*条件判断*/
    <if test="#{query} != null and #{query} != ''">
      /*模糊查询*/
      <bind name="query2" value="'%' + query + '%'"/>
      username like #{query2}
    </if>
  </select>
</mapper>

系统功能

系统管理员

  • 登录
    在这里插入图片描述
  • 用户管理
    在这里插入图片描述
  • 角色管理
    在这里插入图片描述
  • 页面管理
    在这里插入图片描述
  • 宠物列表管理
    在这里插入图片描述
  • 宠物健康史
    在这里插入图片描述
  • 预约列表管理
    在这里插入图片描述

增加预约
在这里插入图片描述

  • 健康指南
    在这里插入图片描述
  • 健康监控
    在这里插入图片描述
  • 健康标准
    在这里插入图片描述
  • 预约统计
    在这里插入图片描述
  • 宠物日志
    在这里插入图片描述
    在这里插入图片描述
  • 医院管理
    在这里插入图片描述
    ......

医生角色

  • 宠物健康史
    在这里插入图片描述

  • 预约管理
    在这里插入图片描述

  • 宠物档案
    在这里插入图片描述

  • 医院管理
    在这里插入图片描述

用户角色

  • 我的宠物列表
    在这里插入图片描述
  • 宠物健康史
    在这里插入图片描述
  • 预约管理
    在这里插入图片描述

日常健康

在这里插入图片描述
在这里插入图片描述

  • 宠物日志
    在这里插入图片描述
  • 预约统计
    在这里插入图片描述
  • 系统完整
    在这里插入图片描述

原文链接:https://www.cnblogs.com/projecthelp/p/17375587.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:24基于java的宠物医院管理系统 - Python技术站

(0)
上一篇 2023年5月6日
下一篇 2023年5月6日

相关文章

  • CCF考试试题之门禁系统java解题代码

    关于“CCF考试试题之门禁系统java解题代码”的完整攻略,请看下面的详细讲解。 一、题目背景 这是一道CCF认证考试的试题,要求我们写一段代码实现一个门禁系统。门禁系统需要记录人员的姓名和进出时间,并按照时间排序输出人员进入和离开的记录。 二、解题思路 首先,我们需要定义一个类,来存储每位人员的姓名和进出时间。 class AccessRecord { S…

    Java 2023年5月24日
    00
  • 5分钟快速学会spring boot整合Mybatis的方法

    5分钟快速学会Spring Boot整合MyBatis的方法 Spring Boot是一个流行的Java框架,可以帮助开发人员快速构建和部署应用程序。MyBatis是一个流行的Java持久化框架,可以帮助开发人员管理数据库。在本文中,将详细讲解如何使用Spring Boot整合MyBatis,以便在开发过程中更加高效和便捷。 步骤1:添加依赖关系 首先,我们…

    Java 2023年5月15日
    00
  • xml+php动态载入与分页

    下面我将详细讲解 “XML+PHP动态载入与分页” 的实现过程。 什么是XML+PHP动态载入与分页? XML+PHP动态载入与分页是一种网站动态载入和分页内容的技术,它可以帮助网站实现异步加载、无刷新加载和分页加载等功能。在这种技术中,我们将数据存储在XML文件中,通过PHP程序实现读取和处理XML数据,并通过Ajax技术进行实时载入数据,从而实现网页内容…

    Java 2023年6月16日
    00
  • JAVA堆排序算法的讲解

    JAVA堆排序算法的讲解 算法简介 堆排序(Heap Sort)是一种选择排序,它的主要思想是将待排序序列构建成一个大顶堆或小顶堆,然后将堆顶元素与最后一个元素交换位置,再对剩余 n – 1 个元素进行同样的操作,依次类推,直到整个序列有序。 堆排序的时间复杂度为 O(nlogn),是一种比较高效的排序算法。 算法步骤 对待排序的序列进行堆的构建,构建出一个…

    Java 2023年5月19日
    00
  • 详解用maven将dubbo工程打成jar包运行

    下面是详解用 Maven 将 Dubbo 工程打成 Jar 包运行的完整攻略。 1. 确认dubbo工程已经创建并可正常运行 首先,需要确认 Dubbo 工程已经创建并且能够正常运行。其中,建议使用 Java 8 或更高版本。 2. 在 pom.xml 文 件 中 增 加 打 包 插 件 配 置 在工程的 pom.xml 文件中,需要增加打包插件配置,以生成…

    Java 2023年5月20日
    00
  • Java Spring Boot请求方式与请求映射过程分析

    Java Spring Boot请求方式与请求映射过程分析 引言 Java Spring Boot是一款高效、快速、便捷的Java Web框架,通过对象依赖注入(DI)和面向切面编程(AOP)实现了模块化开发,提高了代码的简洁性和可维护性,常用于开发web应用程序、RESTful API接口等。 本文将详细讲解Java Spring Boot中的请求方式和请…

    Java 2023年5月19日
    00
  • maven 隐式依赖引起的包冲突解决办法

    当使用Maven构建项目时,一个常见的问题是来自传递依赖的冲突。这个问题的根源在于Maven隐式依赖的传递机制。本文将介绍如何通过Maven来解决这个问题,主要包括以下几个方面: 了解Maven的依赖传递机制 利用Maven Dependency Plugin分析依赖冲突 使用依赖排除,去除冲突依赖 了解 Maven 的依赖传递机制 Maven的依赖传递机制…

    Java 2023年5月20日
    00
  • JavaWeb实战之开发网上购物系统(超详细)

    JavaWeb实战之开发网上购物系统(超详细) 完整攻略 系统需求 为了方便读者更好地理解开发过程,我们假设我们要开发一个网上购物系统,该系统需要满足以下基本需求: 用户可以浏览商品信息,并将商品添加进购物车。 用户可以查看购物车中的商品,并对购物车中的商品进行结算。 用户可以对订单进行在线支付。 管理员可以管理商品信息,包括添加商品、删除商品、修改商品信息…

    Java 2023年5月24日
    00
合作推广
合作推广
分享本页
返回顶部