22基于java的电影院售票管理系统

项目背景

随着互联网和电子商务的快速发展,开发一个电影院订票系统来帮助电影院对电影信息,售票信息进行统一化的信息管理;

遇到的问题

在设计的过程中,需要解决以下的几个问题:

  1. 电影院会有多个播放厅,从而在同一时间播放不同的电影来满足客户需求
  2. 每个厅的大小可能不同,即容纳的人数不同
  3. 电影院会不断引进新片
  4. 电影院会把电影安排在各个播放厅的不同时间段来进行播放,即会有一个排片表
  5. 一个客户可能买一张或多张电影票,这些电影票可能会是不同厅,不同场次的电影

项目简短介绍

电影院系统包含下面的一些模块:

登录
电影类别管理
电影信息管理
放映大厅管理
员工信息管理
放映信息管理
售票信息管理,用户在线选座
收益管理
收入明细

项目环境

> 前端: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/17375204.html

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

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

相关文章

  • 浅谈在页面中获取到ModelAndView绑定的值方法

    获取ModelAndView中绑定的值是很常见的操作,在MVC框架中,ModelAndView作为控制器处理请求后返回给视图的结果,其包含有业务逻辑处理的结果、响应状态和视图(jsp、html等)等信息。下面是获取ModelAndView中绑定的值的几种方法: 方法一:使用EL表达式(${})获取 EL表达式是JavaEE提供的一种表达式语言,可以在JSP或…

    Java 2023年6月15日
    00
  • 详解spring security安全防护

    详解Spring Security安全防护 什么是Spring Security Spring Security是Spring Framework的子项目,它提供了一种基于Spring的安全框架来保护Java应用程序。Spring Security可以处理身份验证和授权,可以保护Web应用程序和非Web应用程序。 Spring Security的核心概念 S…

    Java 2023年5月20日
    00
  • java算法Leecode刷题统计有序矩阵中的负数

    Java算法Leetcode刷题是大多数Java程序员在提高自己的算法能力时所选择的途径之一。其中,《有序矩阵中的负数》是一道常见的算法题目。下面我将给出一份完整攻略,以便Java程序员能够更好地掌握这道题目。 题目描述 给定一个m*n的矩阵grid,其中每行和每列均已按非递增顺序排好序,请你统计并返回grid中 负数 的个数。 解题思路 因为矩阵已按照非递…

    Java 2023年5月19日
    00
  • spring 整合 mybatis 中数据源的几种配置方式(总结篇)

    下面是关于“spring 整合 mybatis 中数据源的几种配置方式(总结篇)”的完整攻略: 1. 简介 在Java项目中,数据源是一个非常重要的组成部分,而MyBatis是一款数据库框架,而Spring是一个很不错的框架,其中,Spring可以与MyBatis进行整合,提供便捷的数据访问功能,其中数据源的配置是一个重要环节。 在这篇攻略中,我们将会全面讲…

    Java 2023年5月19日
    00
  • 在Intellij Idea中使用jstl标签库的方法

    使用JSTL(JSP标准标签库)可以在JSP页面中更轻松地实现一些复杂的逻辑操作,例如循环、条件判断等操作。下面是在IntelliJ IDEA中使用JSTL的方法。 步骤一:导入JSTL Jar包 在项目中引入JSTL的Jar包。可以在Maven或Gradle中配置依赖项,或者手动下载Jar包并将其添加到项目的类路径中。 以下是Maven依赖项的示例: &l…

    Java 2023年6月15日
    00
  • MyBatis3源码解析之如何获取数据源详解

    首先,我们需要明确一下MyBatis3是什么,它的作用是什么。MyBatis3是一个持久层框架,它的作用是将Java对象和关系型数据库之间的操作映射起来,使得我们可以通过Java对象对数据库进行简单的增、删、改、查操作,而无需编写大量的SQL语句。接下来,我将从获取数据源的角度出发,给大家讲解如何理解MyBatis3的数据源配置。 数据源配置 在MyBati…

    Java 2023年5月20日
    00
  • 线程调度的作用是什么?

    以下是关于线程调度的完整使用攻略: 线程调度的作用是什么? 线程调度是指操作系统或者虚拟机对多个线程进行调度和管理,以实现多个线程之间的作和同步。线程度的作用主要有以下几个方面: 1. 提高程序的执行效率 在多线程编程中,如果多个线同时执行,就会出现线程之间的竞争和冲突,从而影响程序的执行效率。线程调度,可以合理地分配 CPU 时间片,从而提高程序的执行效率…

    Java 2023年5月12日
    00
  • JSP 获取真实IP地址的代码

    JSP 获取真实IP地址的代码攻略如下: 步骤一:获取HttpServletRequest对象 首先,我们需要获取HttpServletRequest对象,因为它包含了对象的许多属性和方法。在JSP中,可以直接使用内置对象request获取HttpServletRequest对象。 <% HttpServletRequest request = (Ht…

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