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日

相关文章

  • Springboot初始化项目并完成登入注册的全过程

    Spring Boot初始化项目并完成登入注册的全过程 Spring Boot是一个非常流行的Java Web框架,它提供了许多方便的功能,如自动配置、快速开发和易于部署。本文将介绍如何使用Spring Boot初始化项目并完成登入注册的全过程,并提供两个示例。 步骤 以下是使用Spring Boot初始化项目并完成登入注册的全过程的步骤: 创建Spring…

    Java 2023年5月15日
    00
  • 详解spring boot jpa整合QueryDSL来简化复杂操作

    下面我来为你详细讲解“详解spring boot jpa整合QueryDSL来简化复杂操作”的完整攻略。 什么是QueryDSL QueryDSL 是一个DSL query 框架,基于类型安全,可以使用 Java而非 SQL 来查询数据。它支持多种后端数据库,包括 MySQL,PostgreSQL 和 SQL Server。QueryDSL提供了一种比直接写…

    Java 2023年5月20日
    00
  • springboot整合JSR303校验功能实现代码

    下面我来详细讲解“Spring Boot整合JSR303校验功能实现代码”的完整攻略。 什么是JSR303校验功能? JSR303校验功能是指一种JavaBean的校验方式,用于对JavaBean的属性进行自定义校验,从而实现对表单数据合法性的校验。它基于注解实现,注解具有可读性强、可扩展性强的特点,而且使用非常简单。 Spring Boot整合JSR303…

    Java 2023年5月20日
    00
  • request如何获取body的json数据

    获取HTTP请求的request body是常见的开发任务。在Node.js中,可以使用body-parser中间件来解析请求体解析成JSON对象。以下是获取HTTP请求的request body的完整攻略。 步骤1:安装body-parser中间件 在Node.js应用程序中,安装和使用body-parser中间件是处理请求体最常见的方法。要安装它,请使用…

    Java 2023年5月26日
    00
  • Mybatis实现动态SQL编写的示例详解

    下面是针对“Mybatis实现动态SQL编写的示例详解”的完整攻略。 什么是动态SQL 动态SQL是一种可以根据条件生成不同SQL语句的技术,它可以在SQL运行时决定具体的SQL语句。Mybatis是一种支持动态SQL的持久层框架,可以通过动态SQL来实现不同场景下的复杂SQL语句。 Mybatis实现动态SQL的方式 Mybatis实现动态SQL主要有以下…

    Java 2023年5月19日
    00
  • SpringBoot+jpa配置如何根据实体类自动创建表

    SpringBoot可以通过JPA(Java Persistence API)来进行数据库操作。在使用JPA时,我们可以让它自动创建数据表,而不需要手动创建。 下面是Spring Boot与JPA自动生成数据表的配置方法: 配置数据源 首先,在application.properties中配置数据源: spring.datasource.url=jdbc:m…

    Java 2023年5月20日
    00
  • jsp response.sendRedirect不跳转的原因分析及解决

    针对“jsp response.sendRedirect不跳转的原因分析及解决”,以下是完整攻略: 1. 确认response.sendRedirect是否执行 首先要确认response.sendRedirect是否真正执行了。可以通过在response.sendRedirect前后,分别加入System.out.println语句,输出一些信息,在控制台…

    Java 2023年6月15日
    00
  • Java垃圾回收之标记清除算法详解

    Java垃圾回收之标记清除算法详解 什么是垃圾回收算法 垃圾回收算法是一种自动管理内存的机制,用于自动回收不再使用的内存空间。 Java 中垃圾回收算法主要有标记清除算法、复制算法、标记整理算法和分代收集算法。 标记清除算法 标记清除算法是最简单的一种垃圾回收算法,它分为两个步骤:标记和清除。 标记 标记可以理解为“识别”不再使用的对象,通常从“根对象”开始…

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