计算机毕业设计 沉浸式戏曲文化体验系统的设计与实现 Java实战项目 附源码+文档+视频讲解

news2024/9/20 21:44:09

博主介绍:✌从事软件开发10年之余,专注于Java技术领域、Python人工智能及数据挖掘、小程序项目开发和Android项目开发等。CSDN、掘金、华为云、InfoQ、阿里云等平台优质作者✌
🍅文末获取源码联系🍅
👇🏻 精彩专栏推荐订阅👇🏻 不然下次找不到哟
————————————————
计算机毕业设计《1000套》✌

目录

1、项目介绍及开发技术

1.1 项目介绍

1.2 开发技术

2、系统功能设计结构图

3、功能截图

3.1 前台功能

3.2 后台功能

4、数据库表结构设计

5、关键代码

5.1 戏曲剧目Controller模块 

5.2 戏曲剧目Service模块 

5.3 戏曲剧目ServiceImpl模块

5.4  戏曲剧目Dao模块

6、论文目录结构

7、源码获取


1、项目介绍及开发技术

1.1 项目介绍

随着数字时代的到来,传统文化的传承和推广面临着新的机遇与挑战。戏曲作为中国传统文化的重要组成部分,其独特的艺术魅力需要通过创新的方式被更多人所了解和欣赏。然而,现代快节奏的生活方式使得人们难以抽出时间去剧院欣赏戏曲,同时,戏曲文化的推广也缺乏有效的数字化平台。为了解决这一问题,我们设计并开发了一个沉浸式戏曲文化体验系统,旨在通过现代科技手段,让更多人能够随时随地体验和学习戏曲文化。

背景:
戏曲文化是中国的国粹,蕴含着丰富的历史和艺术价值。然而,由于缺乏有效的推广渠道和现代传播手段,戏曲文化在年轻一代中的普及率逐渐下降。为了适应数字化时代的需求,将戏曲文化与现代技术相结合,开发一个沉浸式体验平台显得尤为重要。

目的意义:

  • 1. 文化传承:通过数字化平台,系统能够将戏曲文化传承给更广泛的受众,特别是年轻一代,从而保护和弘扬这一传统艺术。
  • 2. 沉浸式体验:利用多媒体技术,如音频、视频和互动元素,为用户提供沉浸式的戏曲体验,增强用户对戏曲艺术的感受和理解。
  • 3. 知识普及:系统提供戏曲知识学习模块,帮助用户了解戏曲的历史背景、艺术特点和表演技巧,提升戏曲文化的认知度。
  • 4. 互动交流:平台的互动功能,如活动信息管理和个人收藏管理,使用户能够参与到戏曲文化的交流和讨论中,形成戏曲爱好者社区。
  • 5. 便捷访问: 用户可以通过网站或移动应用轻松访问平台服务,随时随地进行戏曲欣赏和学习。

综上所述,沉浸式戏曲文化体验系统的设计与实现,不仅能够为戏曲文化的传播提供新的途径,还能够为用户提供一个全新的文化体验平台。通过技术手段优化戏曲文化的体验方式,该系统有望成为戏曲文化爱好者的新天地,同时也是推动传统文化创新性转化、创造性发展的重要工具。
 

1.2 开发技术

类别技术名称用途/描述
开发语言Java一种广泛使用的面向对象编程语言。
框架Spring Boot简化Spring应用的初始搭建以及开发过程。
ORM工具MyBatis PlusMyBatis的增强工具,简化CRUD操作。
数据库MySQL流行的关系型数据库管理系统。
构建工具Maven项目管理和理解工具。
开发工具IDEA集成开发环境,用于代码编写和调试。
JDK版本JDK 1.8+Java开发工具包,提供运行Java程序所需的环境。
前端框架Vue用于构建用户界面的渐进式JavaScript框架。
UI框架Element UI基于Vue的桌面端组件库。
前端技术HTML网页内容的标准标记语言。
前端技术CSS描述HTML文档的样式。
前端技术JS网页脚本语言,用于实现网页的动态效果。

2、系统功能设计结构图

功能模块结构图

├── 管理员
│   ├── 登录
│   ├── 首页
│   ├── 用户管理
│   ├── 管理员管理
│   ├── 戏曲剧目管理
│   ├── 戏曲知识管理
│   ├── 活动信息管理
│   └── 系统管理

└── 用户
    ├── 登录
    ├── 注册
    ├── 首页
    ├── 戏曲剧目浏览
    ├── 戏曲倾听
    ├── 戏曲知识学习
    ├── 活动信息查看
    ├── 系统公告查看
    └── 个人中心
        ├── 个人中心信息
        ├── 修改密码
        ├── 活动信息管理
        └── 我的收藏管理

系统MVC框架,请求流程展示:

3、功能截图

3.1 前台功能

 

 

 

 

3.2 后台功能

 

4、数据库表结构设计

CREATE TABLE `huodongbaoming` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `baomingbianhao` varchar(200) DEFAULT NULL COMMENT '报名编号',
  `huodongmingcheng` varchar(200) NOT NULL COMMENT '活动名称',
  `huodongdidian` varchar(200) NOT NULL COMMENT '活动地点',
  `lianxirenxingming` varchar(200) DEFAULT NULL COMMENT '联系人姓名',
  `lianxifangshi` varchar(200) DEFAULT NULL COMMENT '联系方式',
  `renshu` int(11) DEFAULT NULL COMMENT '报名人数',
  `baomingshijian` datetime DEFAULT NULL COMMENT '报名时间',
  `yonghuzhanghao` varchar(200) DEFAULT NULL COMMENT '用户账号',
  `yonghuxingming` varchar(200) DEFAULT NULL COMMENT '用户姓名',
  `dianhuahaoma` varchar(200) DEFAULT NULL COMMENT '电话号码',
  `sfsh` varchar(200) DEFAULT NULL COMMENT '是否审核',
  `shhf` longtext COMMENT '回复内容',
  `crossuserid` bigint(20) DEFAULT NULL COMMENT '跨表用户id',
  `crossrefid` bigint(20) DEFAULT NULL COMMENT '跨表主键id',
  PRIMARY KEY (`id`),
  UNIQUE KEY `baomingbianhao` (`baomingbianhao`)
) ENGINE=InnoDB AUTO_INCREMENT=1712891431649 DEFAULT CHARSET=utf8 COMMENT='活动报名';

CREATE TABLE `huodongxinxi` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `huodongmingcheng` varchar(200) NOT NULL COMMENT '活动名称',
  `huodongtupian` longtext COMMENT '活动图片',
  `kaishishijian` datetime DEFAULT NULL COMMENT '开始时间',
  `jieshushijian` datetime DEFAULT NULL COMMENT '结束时间',
  `huodongdidian` varchar(200) DEFAULT NULL COMMENT '活动地点',
  `lianxirenxingming` varchar(200) DEFAULT NULL COMMENT '联系人姓名',
  `lianxifangshi` varchar(200) DEFAULT NULL COMMENT '联系方式',
  `renshu` int(11) DEFAULT NULL COMMENT '已报名人数',
  `huodongneirong` longtext COMMENT '活动内容',
  `fabushijian` datetime DEFAULT NULL COMMENT '发布时间',
  `storeupnum` int(11) DEFAULT NULL COMMENT '收藏数量',
  `thumbsupnum` int(11) DEFAULT NULL COMMENT '赞',
  `crazilynum` int(11) DEFAULT NULL COMMENT '踩',
  `clicknum` int(11) DEFAULT NULL COMMENT '点击次数',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1712891311275 DEFAULT CHARSET=utf8 COMMENT='活动信息';

CREATE TABLE `storeup` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `refid` bigint(20) DEFAULT NULL COMMENT 'refid',
  `tablename` varchar(200) DEFAULT NULL COMMENT '表名',
  `name` varchar(200) NOT NULL COMMENT '名称',
  `picture` longtext NOT NULL COMMENT '图片',
  `type` varchar(200) DEFAULT NULL COMMENT '类型(1:收藏,21:赞,22:踩,31:竞拍参与,41:关注)',
  `inteltype` varchar(200) DEFAULT NULL COMMENT '推荐类型',
  `remark` varchar(200) DEFAULT NULL COMMENT '备注',
  `userid` bigint(20) NOT NULL COMMENT '用户id',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1712891425984 DEFAULT CHARSET=utf8 COMMENT='我的收藏';

CREATE TABLE `token` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `userid` bigint(20) NOT NULL COMMENT '用户id',
  `username` varchar(100) NOT NULL COMMENT '用户名',
  `tablename` varchar(100) DEFAULT NULL COMMENT '表名',
  `role` varchar(100) DEFAULT NULL COMMENT '角色',
  `token` varchar(200) NOT NULL COMMENT '密码',
  `addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '新增时间',
  `expiratedtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '过期时间',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8 COMMENT='token表';

CREATE TABLE `xiqufenlei` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `xiqufenlei` varchar(200) DEFAULT NULL COMMENT '戏曲分类',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1712891109029 DEFAULT CHARSET=utf8 COMMENT='戏曲分类';

CREATE TABLE `xiquqingting` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `fengmian` longtext COMMENT '封面',
  `songname` varchar(200) NOT NULL COMMENT '戏曲名称',
  `songfile` longtext NOT NULL COMMENT '戏曲文件',
  `singer` varchar(200) NOT NULL COMMENT '艺术家',
  `xiqujieshao` longtext COMMENT '戏曲介绍',
  `shangchuanshijian` datetime DEFAULT NULL COMMENT '上传时间',
  `thumbsupnum` int(11) DEFAULT NULL COMMENT '赞',
  `crazilynum` int(11) DEFAULT NULL COMMENT '踩',
  `storeupnum` int(11) DEFAULT NULL COMMENT '收藏数量',
  `clicktime` datetime DEFAULT NULL COMMENT '最近点击时间',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1712891237950 DEFAULT CHARSET=utf8 COMMENT='戏曲倾听';

CREATE TABLE `xiquzhishi` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `biaoti` varchar(200) DEFAULT NULL COMMENT '标题',
  `fengmian` longtext COMMENT '封面',
  `neirong` longtext COMMENT '内容',
  `fabushijian` datetime DEFAULT NULL COMMENT '发布时间',
  `thumbsupnum` int(11) DEFAULT NULL COMMENT '赞',
  `crazilynum` int(11) DEFAULT NULL COMMENT '踩',
  `storeupnum` int(11) DEFAULT NULL COMMENT '收藏数量',
  `clicktime` datetime DEFAULT NULL COMMENT '最近点击时间',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1712891267964 DEFAULT CHARSET=utf8 COMMENT='戏曲知识';

CREATE TABLE `yonghu` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `yonghuzhanghao` varchar(200) NOT NULL COMMENT '用户账号',
  `yonghumima` varchar(200) NOT NULL COMMENT '用户密码',
  `yonghuxingming` varchar(200) NOT NULL COMMENT '用户姓名',
  `touxiang` longtext COMMENT '头像',
  `xingbie` varchar(200) DEFAULT NULL COMMENT '性别',
  `dianhuahaoma` varchar(200) DEFAULT NULL COMMENT '电话号码',
  PRIMARY KEY (`id`),
  UNIQUE KEY `yonghuzhanghao` (`yonghuzhanghao`)
) ENGINE=InnoDB AUTO_INCREMENT=1712891368898 DEFAULT CHARSET=utf8 COMMENT='用户';

5、关键代码

5.1 戏曲剧目Controller模块 


package com.cl.controller;

import java.math.BigDecimal;
import java.text.SimpleDateFormat;
import java.text.ParseException;
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.cl.utils.ValidatorUtils;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.transaction.annotation.Transactional;
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.cl.annotation.IgnoreAuth;

import com.cl.entity.XiqujumuEntity;
import com.cl.entity.view.XiqujumuView;

import com.cl.service.XiqujumuService;
import com.cl.service.TokenService;
import com.cl.utils.PageUtils;
import com.cl.utils.R;
import com.cl.utils.MPUtil;
import com.cl.utils.CommonUtil;
import java.io.IOException;
import com.cl.service.StoreupService;
import com.cl.entity.StoreupEntity;

/**
 * 戏曲剧目
 * 后端接口
 * @author 
 * @email 
 */
@RestController
@RequestMapping("/xiqujumu")
public class XiqujumuController {
    @Autowired
    private XiqujumuService xiqujumuService;

    @Autowired
    private StoreupService storeupService;


    


    /**
     * 后端列表
     */
    @RequestMapping("/page")
    public R page(@RequestParam Map<String, Object> params,XiqujumuEntity xiqujumu,
		HttpServletRequest request){
        EntityWrapper<XiqujumuEntity> ew = new EntityWrapper<XiqujumuEntity>();

		PageUtils page = xiqujumuService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, xiqujumu), params), params));

        return R.ok().put("data", page);
    }
    
    /**
     * 前端列表
     */
	@IgnoreAuth
    @RequestMapping("/list")
    public R list(@RequestParam Map<String, Object> params,XiqujumuEntity xiqujumu, 
		HttpServletRequest request){
        EntityWrapper<XiqujumuEntity> ew = new EntityWrapper<XiqujumuEntity>();

		PageUtils page = xiqujumuService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, xiqujumu), params), params));
        return R.ok().put("data", page);
    }

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

	 /**
     * 查询
     */
    @RequestMapping("/query")
    public R query(XiqujumuEntity xiqujumu){
        EntityWrapper< XiqujumuEntity> ew = new EntityWrapper< XiqujumuEntity>();
 		ew.allEq(MPUtil.allEQMapPre( xiqujumu, "xiqujumu")); 
		XiqujumuView xiqujumuView =  xiqujumuService.selectView(ew);
		return R.ok("查询戏曲剧目成功").put("data", xiqujumuView);
    }
	
    /**
     * 后端详情
     */
    @RequestMapping("/info/{id}")
    public R info(@PathVariable("id") Long id){
        XiqujumuEntity xiqujumu = xiqujumuService.selectById(id);
		xiqujumu.setClicktime(new Date());
		xiqujumuService.updateById(xiqujumu);
		xiqujumu = xiqujumuService.selectView(new EntityWrapper<XiqujumuEntity>().eq("id", id));
        return R.ok().put("data", xiqujumu);
    }

    /**
     * 前端详情
     */
	@IgnoreAuth
    @RequestMapping("/detail/{id}")
    public R detail(@PathVariable("id") Long id){
        XiqujumuEntity xiqujumu = xiqujumuService.selectById(id);
		xiqujumu.setClicktime(new Date());
		xiqujumuService.updateById(xiqujumu);
		xiqujumu = xiqujumuService.selectView(new EntityWrapper<XiqujumuEntity>().eq("id", id));
        return R.ok().put("data", xiqujumu);
    }
    


    /**
     * 赞或踩
     */
    @RequestMapping("/thumbsup/{id}")
    public R vote(@PathVariable("id") String id,String type){
        XiqujumuEntity xiqujumu = xiqujumuService.selectById(id);
        if(type.equals("1")) {
        	xiqujumu.setThumbsupnum(xiqujumu.getThumbsupnum()+1);
        } else {
        	xiqujumu.setCrazilynum(xiqujumu.getCrazilynum()+1);
        }
        xiqujumuService.updateById(xiqujumu);
        return R.ok("投票成功");
    }

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



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



    

    /**
     * 删除
     */
    @RequestMapping("/delete")
    public R delete(@RequestBody Long[] ids){
        xiqujumuService.deleteBatchIds(Arrays.asList(ids));
        return R.ok();
    }
    
	
	/**
     * 前端智能排序
     */
	@IgnoreAuth
    @RequestMapping("/autoSort")
    public R autoSort(@RequestParam Map<String, Object> params,XiqujumuEntity xiqujumu, HttpServletRequest request,String pre){
        EntityWrapper<XiqujumuEntity> ew = new EntityWrapper<XiqujumuEntity>();
        Map<String, Object> newMap = new HashMap<String, Object>();
        Map<String, Object> param = new HashMap<String, Object>();
		Iterator<Map.Entry<String, Object>> it = param.entrySet().iterator();
		while (it.hasNext()) {
			Map.Entry<String, Object> entry = it.next();
			String key = entry.getKey();
			String newKey = entry.getKey();
			if (pre.endsWith(".")) {
				newMap.put(pre + newKey, entry.getValue());
			} else if (StringUtils.isEmpty(pre)) {
				newMap.put(newKey, entry.getValue());
			} else {
				newMap.put(pre + "." + newKey, entry.getValue());
			}
		}
		params.put("sort", "clicktime");
        params.put("order", "desc");
		PageUtils page = xiqujumuService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, xiqujumu), params), params));
        return R.ok().put("data", page);
    }

    /**
     * 按收藏推荐
     */
    @RequestMapping("/autoSort2")
    public R autoSort2(@RequestParam Map<String, Object> params,XiqujumuEntity xiqujumu, HttpServletRequest request){
        String userId = request.getSession().getAttribute("userId").toString();
        String inteltypeColumn = "xiqumingcheng";
        List<StoreupEntity> storeups = storeupService.selectList(new EntityWrapper<StoreupEntity>().eq("type", 1).eq("userid", userId).eq("tablename", "xiqujumu").orderBy("addtime", false));
        List<String> inteltypes = new ArrayList<String>();
        Integer limit = params.get("limit")==null?10:Integer.parseInt(params.get("limit").toString());
        List<XiqujumuEntity> xiqujumuList = new ArrayList<XiqujumuEntity>();
        //去重
        if(storeups!=null && storeups.size()>0) {
            for(StoreupEntity s : storeups) {
                xiqujumuList.addAll(xiqujumuService.selectList(new EntityWrapper<XiqujumuEntity>().eq(inteltypeColumn, s.getInteltype())));
            }
        }
        EntityWrapper<XiqujumuEntity> ew = new EntityWrapper<XiqujumuEntity>();
        params.put("sort", "id");
        params.put("order", "desc");
        PageUtils page = xiqujumuService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, xiqujumu), params), params));
        List<XiqujumuEntity> pageList = (List<XiqujumuEntity>)page.getList();
        if(xiqujumuList.size()<limit) {
            int toAddNum = (limit-xiqujumuList.size())<=pageList.size()?(limit-xiqujumuList.size()):pageList.size();
            for(XiqujumuEntity o1 : pageList) {
                boolean addFlag = true;
                for(XiqujumuEntity o2 : xiqujumuList) {
                    if(o1.getId().intValue()==o2.getId().intValue()) {
                        addFlag = false;
                        break;
                    }
                }
                if(addFlag) {
                    xiqujumuList.add(o1);
                    if(--toAddNum==0) break;
                }
            }
        } else if(xiqujumuList.size()>limit) {
            xiqujumuList = xiqujumuList.subList(0, limit);
        }
        page.setList(xiqujumuList);
        return R.ok().put("data", page);
    }


}

5.2 戏曲剧目Service模块 

 package com.cl.service;

import com.baomidou.mybatisplus.mapper.Wrapper;
import com.baomidou.mybatisplus.service.IService;
import com.cl.utils.PageUtils;
import com.cl.entity.XiqujumuEntity;
import java.util.List;
import java.util.Map;
import org.apache.ibatis.annotations.Param;
import com.cl.entity.view.XiqujumuView;


/**
 * 戏曲剧目
 *
 * @author 
 * @email 
 */
public interface XiqujumuService extends IService<XiqujumuEntity> {

    PageUtils queryPage(Map<String, Object> params);
    
   	List<XiqujumuView> selectListView(Wrapper<XiqujumuEntity> wrapper);
   	
   	XiqujumuView selectView(@Param("ew") Wrapper<XiqujumuEntity> wrapper);
   	
   	PageUtils queryPage(Map<String, Object> params,Wrapper<XiqujumuEntity> wrapper);
   	

}

5.3 戏曲剧目ServiceImpl模块


package com.cl.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.cl.utils.PageUtils;
import com.cl.utils.Query;


import com.cl.dao.XiqujumuDao;
import com.cl.entity.XiqujumuEntity;
import com.cl.service.XiqujumuService;
import com.cl.entity.view.XiqujumuView;

@Service("xiqujumuService")
public class XiqujumuServiceImpl extends ServiceImpl<XiqujumuDao, XiqujumuEntity> implements XiqujumuService {
	
	
    @Override
    public PageUtils queryPage(Map<String, Object> params) {
        Page<XiqujumuEntity> page = this.selectPage(
                new Query<XiqujumuEntity>(params).getPage(),
                new EntityWrapper<XiqujumuEntity>()
        );
        return new PageUtils(page);
    }
    
    @Override
	public PageUtils queryPage(Map<String, Object> params, Wrapper<XiqujumuEntity> wrapper) {
		  Page<XiqujumuView> page =new Query<XiqujumuView>(params).getPage();
	        page.setRecords(baseMapper.selectListView(page,wrapper));
	    	PageUtils pageUtil = new PageUtils(page);
	    	return pageUtil;
 	}
    
	@Override
	public List<XiqujumuView> selectListView(Wrapper<XiqujumuEntity> wrapper) {
		return baseMapper.selectListView(wrapper);
	}

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


}

5.4  戏曲剧目Dao模块


package com.cl.dao;

import com.cl.entity.XiqujumuEntity;
import com.baomidou.mybatisplus.mapper.BaseMapper;
import java.util.List;
import java.util.Map;
import com.baomidou.mybatisplus.mapper.Wrapper;
import com.baomidou.mybatisplus.plugins.pagination.Pagination;

import org.apache.ibatis.annotations.Param;
import com.cl.entity.view.XiqujumuView;


/**
 * 戏曲剧目
 * 
 * @author 
 * @email 
 */
public interface XiqujumuDao extends BaseMapper<XiqujumuEntity> {
	
	List<XiqujumuView> selectListView(@Param("ew") Wrapper<XiqujumuEntity> wrapper);

	List<XiqujumuView> selectListView(Pagination page,@Param("ew") Wrapper<XiqujumuEntity> wrapper);
	
	XiqujumuView selectView(@Param("ew") Wrapper<XiqujumuEntity> wrapper);
	

}

6、论文目录结构

摘要... I

Abstract... II

1 绪论... 1
   1.1 项目简介... 1
   1.2 调查研究... 1
       1.2.1 研究背景及意义... 1
       1.2.2 国内外研究现状... 2
       1.2.3 研究主要内容... 2
   1.3 论文的章节安排... 3

2 系统相关技术介绍... 4
   2.1 Java语言... 4
   2.2 SpringBoot框架... 4
   2.3 Vue框架... 4
   2.4 MySQL数据库... 4

3 系统需求分析... 6
   3.1 可行性分析... 6
       3.1.1 技术可行性... 6
       3.1.2 经济可行性... 6
       3.1.3 操作可行性... 6
   3.2 系统功能需求... 6
       3.2.1 用户端功能需求... 6
       3.2.2 XX端功能需求... 6
       3.2.3 管理员端功能需求... 6
   3.3 系统性能需求... 6

4 系统总体设计... 7
   4.1 系统总体架构设计... 7
   4.2 系统的功能设计... 7
   4.3 数据库设计... 7
       4.3.1 概念设计E-R图... 7
       4.3.2 逻辑设计关系模式... 7
       4.3.3 数据库物理设计... 7

5 系统详细实现... 14
   5.1 系统实现环境... 14
   5.2 用户端... 14
       5.2.1 登录页面... 14
       5.2.2 注册页面... 14
       5.2.3 XXXX页面... 14
       5.2.4 XXXX页面... 14
       5.2.5 XXXX页面... 14
   5.3 XXXX端... 15
       5.3.1 XXXX页面... 15
       5.3.2 XXXX页面... 15
       5.3.3 XXXX页面... 15
       5.3.4 XXXX页面... 15
   5.4 管理端... 15
       5.4.1 用户管理页面... 15
       5.4.2 XXXX页面... 15
       5.4.3 XXXX页面... 16
       5.4.4 XXXX页面... 16

6 系统测试... 16
   6.1 测试目的... 16
   6.2 测试方法... 16
   6.3 测试用例... 16
       6.3.1 XXXX测试... 16
       6.3.2 XXXX测试... 16
   6.4 测试结果... 16

结论... 17

参考文献... 18

致谢... 19

更多源码:

计算机毕业设计选题1000套等你来!!!

7、源码获取

感谢大家的阅读,如有不懂的问题可以评论区交流或私聊!

喜欢文章可以点赞、收藏、关注、评论

下方联系方式获取源码

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2135933.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

百年病态集论的症结:3000年不识伪≌直线段

黄小宁 公元前1100年中国人商高同周公的一段对话谈到了勾股定理说明人类认识几何学的直线段起码已有3000多年。 直角三角形⊿的斜边c&#xff5e;水平直角边a&#xff0c;即c经旋转和均匀压缩变换可变为a&#xff5e;c。3000年不识伪≌直线段使数学认定a经刚体运动变为附着在c…

rk3399 的 HDMI 热插拔的问题

问题&#xff1a; 客户的3399 的板子上&#xff0c;烧写ubuntu 发现&#xff0c; 没有热插拔。 测试情况&#xff1a; 系统在第一次烧写完成之后&#xff0c;是有热插拔的&#xff0c;但是第二次启动就没有了。 还有一个情况&#xff0c;就是 &#xff0c;如果我一开始 上电的…

[论文精读]Polarized message-passing in graph neural networks

论文网址&#xff1a;Polarized message-passing in graph neural networks - ScienceDirect 论文代码&#xff1a;he-tiantian/PMP-GNNs&#xff1a;极化消息传递图神经网络的 Pytorch 实现&#xff0c;发表在 Artificial Intelligence&#xff0c;2024 年。 (github.com) 英…

红日靶场通关

初始准备 首先是网络配置&#xff0c;看教程来的&#xff0c;我配置完的效果如下 windows7&#xff1a;(内&#xff1a;192.168.52.143 / 外&#xff1a;192.168.154.136) windows2003&#xff1a;(内&#xff1a;192.168.52.141)windows2008:&#xff08;内&#xff1a;192.…

运算放大器选型的关键参数

上图中的顺序是从左上到右下进行选型&#xff0c;小信号看带宽&#xff0c;大信号看压摆率。一般选用电压反馈型的运放&#xff0c;但是涉及到高频特性的时候也会选择电流反馈型的运放。精密运放选用失调电压比较小的运放&#xff0c;一般失调电压在1mv左右。低功耗的情况下需要…

极越造车2.0:01销量回暖,07杀出血路,ASD抢跑FSD

‍‍‍作者 |张马也 编辑 |德新 9月13日&#xff0c;极越公布其第二款车型极越07上市48小时内&#xff0c;订单超过5000台。 对这家造车4年多的车企来说&#xff0c;这意味着新车取得了初步的成功。 懂车帝的数据显示&#xff0c;7月极越01销量1143台&#xff0c;8月销量则翻…

Linux 入门:简单的基础操作

“批判他人总是想的太简单 剖析自己总是想的太困难” 文章目录 前言Linux 入门&#xff1a;从基础操作到 WSL2 安装文章有误敬请斧正 不胜感恩&#xff01;1. 什么是 Linux&#xff1f;2. Linux 和其他系统有啥不同&#xff1f;3. Linux 的主要组成4. 常见 Linux 发行版5. 基本…

openstack之cinder介绍

概念 cinder 为虚拟机提供管理块存储服务。支持的文件系统&#xff1a;lvm、iscsi、nfs、san、RBD 组件构成及功能介绍 cinder api&#xff1a;在控制节点运行&#xff0c;管理服务的接口&#xff0c;被命令行、其他组件调用&#xff1b; cinder scheduler&#xff1a;类似n…

大数据新视界 --大数据大厂之Kafka消息队列实战:实现高吞吐量数据传输

&#x1f496;&#x1f496;&#x1f496;亲爱的朋友们&#xff0c;热烈欢迎你们来到 青云交的博客&#xff01;能与你们在此邂逅&#xff0c;我满心欢喜&#xff0c;深感无比荣幸。在这个瞬息万变的时代&#xff0c;我们每个人都在苦苦追寻一处能让心灵安然栖息的港湾。而 我的…

美国税收制度及SAP实施

1. 税制综述 美国是以直接税为主的国家,实行联邦、州和地方&#xff08;市、县&#xff09;三级征税制度&#xff0c;属于彻底的分税制国家。美国联邦税以个人所得税和企业所得税为其主要收入来源&#xff0c;州税以销售与使用税为其主要收入来源&#xff0c;地方税以财产税为…

UART 16550的使用

前言 本文从操作系统使用 16550 的角度来学习 16550。主要解析通用的串口寄存器的作用。 16550 串口由一系列寄存器控制串口行为。不同的具体设备寄存器的偏移不同&#xff0c;寄存器的长度可能不同。 例如&#xff0c;在 AXI UART 16550中&#xff0c;各寄存器长度都为 32 b…

overleaf如何下载论文的pdf

用overleaf写完英文论文后&#xff0c;要将论文保存为PDF格式 点击图片中的下载按钮 然后选择一个路径保存论文的PDF格式即可。

测试通用面试题大全

24年软件测试的发展如何&#xff1f; 1、IT行业还会继续升温&#xff0c;高质量人才需求相对还是短缺。 2、要求变高之后&#xff0c;很难再下降了&#xff0c;学历和经验。 3、功能测试之外的东西&#xff0c;接口、性能和自动化要掌握一点。 4、长远来看&#xff0c;软件…

Android Framework(五)WMS-窗口显示流程——窗口布局与计算

文章目录 relayoutWindow流程概览应用端处理——ViewRootImpl::setView -> relayoutWindowViewRootImpl::setViewViewRootImpl::performTraversalsViewRootImpl::relayoutWindow Surface的创建WindowManagerService::relayoutWindow了解容器类型和Buff类型的SurfaceBuff类型…

并发编程 - GCD的栅栏(dispatch_barrier_async)

引言 Grand Central Dispath&#xff08;GCD&#xff09;是苹果提供的强大工具&#xff0c;它几乎涵盖了多线程编程的所有方面。通过GCD&#xff0c;我们可以轻松地创建队列、管理线程&#xff0c;并以更优雅的方式处理并发任务。在前面的博客中&#xff0c;我们已经深入探讨了…

基于SpringBoot+Vue+MySQL的校园健康驿站管理系统

系统展示 用户前台界面 管理员后台界面 系统背景 本文设计并实现了一个基于SpringBoot后端、Vue前端与MySQL数据库的校园健康驿站管理系统。该系统旨在通过数字化手段&#xff0c;全面管理学生的健康信息&#xff0c;包括体温监测、疫苗接种记录、健康状况申报等&#xff0c;为…

【Canvas与表盘】绘制黄蓝两色简约表盘

【成图】 【代码】 <!DOCTYPE html> <html lang"utf-8"> <meta http-equiv"Content-Type" content"text/html; charsetutf-8"/> <head><title>黄蓝卡通手表</title><style type"text/css">…

【我的Android进阶之旅】解决CardView四个圆角有白边的问题

文章目录 一、问题描述二、分析CardView出现白边的原因三、如何解决这个问题?3.1 如何修复?3.2 为什么这样可以修复?3.3 示例代码3.4 总结一、问题描述 在实现一个RecycleView的Item时候,样式需要用到卡片式效果,于是想到用CardView来实现,但是最终发现运行出来的效果,…

(微服务项目)新闻头条——Day1

最近发生了很多事情&#xff0c;躺了一阵子&#xff0c;也是终于振作起来做自己的事情了.... 有的人追求精彩而活&#xff0c;而即使瘦若浮游&#xff0c;仍旧痴迷71种滋味&#xff0c;而有的人寿命明却装醉不得自由虚度自己的光阴&#xff0c;年华终究在最后一刻幡然醒悟&…

Android Studio新建工程(Java语言环境)

一、新建工程流程(java语言环境) 1、File->New->New Project 2、选择“Empty Views Activity” -> Next 3、创建项目名称/项目路径/语言环境 1&#xff09;项目名称&#xff1a;使用默认Name 或 修改Name 2) Package name&#xff1a;每个项目的这个名称唯一&…