基于Springboot+Vue的Java项目-电影院购票系统开发实战(附演示视频+源码+LW)

大家好!我是程序员衣一帆,感谢您阅读本文,欢迎一键三连哦。

💞当前专栏:Java毕业设计

精彩专栏推荐👇🏻👇🏻👇🏻

🎀 Python毕业设计
🌎微信小程序毕业设计

开发环境

开发语言:Java
框架:Springboot+Vue
JDK版本:JDK1.8
服务器:tomcat7
数据库:mysql 5.7
数据库工具:Navicat12
开发软件:eclipse/myeclipse/idea
Maven包:Maven3.3.9
浏览器:谷歌浏览器

演示视频

springboot274基于web的电影院购票系统录像

原版高清演示视频-编号274:
https://pan.quark.cn/s/5cda95b17ee0

源码下载地址:

https://download.csdn.net/download/2301_76953549/89099764

LW目录

【如需全文请按文末获取联系】
在这里插入图片描述
在这里插入图片描述

目录

  • 开发环境
  • 演示视频
  • 源码下载地址:
  • LW目录
  • 一、项目简介
  • 二、系统设计
    • 2.1软件功能模块设计
    • 2.2数据库设计
  • 三、系统项目部分截图
    • 3.1用户信息管理
    • 3.2电影信息管理
    • 3.3电影评价管理
    • 3.4新闻信息管理
  • 四、部分核心代码
    • 4.1 用户部分
  • 获取源码或论文

一、项目简介

电影院购票系统在对开发工具的选择上也很慎重,为了便于开发实现,选择的开发工具为Eclipse,选择的数据库工具为Mysql。以此搭建开发环境实现电影院购票系统的功能。其中管理员管理用户,新闻公告。
电影院购票系统是一款运用软件开发技术设计实现的应用系统,在信息处理上可以达到快速的目的,不管是针对数据添加,数据维护和统计,以及数据查询等处理要求,电影院购票系统都可以轻松应对。电影院购票系统是一款运用软件开发技术设计实现的应用系统,在信息处理上可以达到快速的目的,不管是针对数据添加,数据维护和统计,以及数据查询等处理要求,电影院购票系统都可以轻松应对。

二、系统设计

2.1软件功能模块设计

为了让系统的编码可以顺利进行,特意对本系统功能进行细分设计,设计的系统功能结构见下图。
在这里插入图片描述

2.2数据库设计

(1)下图是电影评价实体和其具备的属性。
在这里插入图片描述
(2)下图是电影订单实体和其具备的属性。
在这里插入图片描述
(3)下图是论坛实体和其具备的属性。
在这里插入图片描述
(4)下图是用户实体和其具备的属性。
在这里插入图片描述

(5)下图是电影实体和其具备的属性。
在这里插入图片描述

三、系统项目部分截图

3.1用户信息管理

如图5.1显示的就是用户信息管理页面,此页面提供给管理员的功能有:用户信息的查询管理,可以删除用户信息、修改用户信息、新增用户信息,
还进行了对用户名称的模糊查询的条件
在这里插入图片描述
在这里插入图片描述

3.2电影信息管理

如图5.2显示的就是电影信息管理页面,此页面提供给管理员的功能有:查看已发布的电影信息数据,修改电影信息,电影信息作废,即可删除,还进行了对电影信息名称的模糊查询 电影信息信息的类型查询等等一些条件。
在这里插入图片描述
在这里插入图片描述

3.3电影评价管理

如图5.3显示的就是电影评价管理页面,此页面提供给管理员的功能有:根据电影评价进行条件查询,还可以对电影评价进行新增、修改、查询操作等等。
在这里插入图片描述

在这里插入图片描述

3.4新闻信息管理

如图5.4显示的就是新闻信息管理页面,此页面提供给管理员的功能有:根据新闻信息进行新增、修改、查询操作等等。
在这里插入图片描述
在这里插入图片描述

四、部分核心代码

4.1 用户部分


package com.controller;import java.io.File;
import java.math.BigDecimal;
import java.net.URL;
import java.text.SimpleDateFormat;
import com.alibaba.fastjson.JSONObject;
import java.util.*;
import org.springframework.beans.BeanUtils;
import javax.servlet.http.HttpServletRequest;
import org.springframework.web.context.ContextLoader;
import javax.servlet.ServletContext;
import com.service.TokenService;
import com.utils.*;
import java.lang.reflect.InvocationTargetException;import com.service.DictionaryService;
import org.apache.commons.lang3.StringUtils;
import com.annotation.IgnoreAuth;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.*;
import com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.baomidou.mybatisplus.mapper.Wrapper;
import com.entity.*;
import com.entity.view.*;
import com.service.*;
import com.utils.PageUtils;
import com.utils.R;
import com.alibaba.fastjson.*;/*** 电影订单* 后端接口* @author* @email
*/
@RestController
@Controller
@RequestMapping("/dianyingOrder")
public class DianyingOrderController {private static final Logger logger = LoggerFactory.getLogger(DianyingOrderController.class);@Autowiredprivate DianyingOrderService dianyingOrderService;@Autowiredprivate TokenService tokenService;@Autowiredprivate DictionaryService dictionaryService;//级联表service@Autowiredprivate DianyingService dianyingService;@Autowiredprivate YonghuService yonghuService;
@Autowired
private DianyingCommentbackService dianyingCommentbackService;/*** 后端列表*/@RequestMapping("/page")public R page(@RequestParam Map<String, Object> params, HttpServletRequest request){logger.debug("page方法:,,Controller:{},,params:{}",this.getClass().getName(),JSONObject.toJSONString(params));String role = String.valueOf(request.getSession().getAttribute("role"));if(false)return R.error(511,"永不会进入");else if("用户".equals(role))params.put("yonghuId",request.getSession().getAttribute("userId"));if(params.get("orderBy")==null || params.get("orderBy")==""){params.put("orderBy","id");}PageUtils page = dianyingOrderService.queryPage(params);//字典表数据转换List<DianyingOrderView> list =(List<DianyingOrderView>)page.getList();for(DianyingOrderView c:list){//修改对应字典表字段dictionaryService.dictionaryConvert(c, request);}return R.ok().put("data", page);}/*** 后端详情*/@RequestMapping("/info/{id}")public R info(@PathVariable("id") Long id, HttpServletRequest request){logger.debug("info方法:,,Controller:{},,id:{}",this.getClass().getName(),id);DianyingOrderEntity dianyingOrder = dianyingOrderService.selectById(id);if(dianyingOrder !=null){//entity转viewDianyingOrderView view = new DianyingOrderView();BeanUtils.copyProperties( dianyingOrder , view );//把实体数据重构到view中//级联表DianyingEntity dianying = dianyingService.selectById(dianyingOrder.getDianyingId());if(dianying != null){BeanUtils.copyProperties( dianying , view ,new String[]{ "id", "createTime", "insertTime", "updateTime"});//把级联的数据添加到view中,并排除id和创建时间字段view.setDianyingId(dianying.getId());}//级联表YonghuEntity yonghu = yonghuService.selectById(dianyingOrder.getYonghuId());if(yonghu != null){BeanUtils.copyProperties( yonghu , view ,new String[]{ "id", "createTime", "insertTime", "updateTime"});//把级联的数据添加到view中,并排除id和创建时间字段view.setYonghuId(yonghu.getId());}//修改对应字典表字段dictionaryService.dictionaryConvert(view, request);return R.ok().put("data", view);}else {return R.error(511,"查不到数据");}}/*** 后端保存*/@RequestMapping("/save")public R save(@RequestBody DianyingOrderEntity dianyingOrder, HttpServletRequest request){logger.debug("save方法:,,Controller:{},,dianyingOrder:{}",this.getClass().getName(),dianyingOrder.toString());String role = String.valueOf(request.getSession().getAttribute("role"));if(false)return R.error(511,"永远不会进入");else if("用户".equals(role))dianyingOrder.setYonghuId(Integer.valueOf(String.valueOf(request.getSession().getAttribute("userId"))));dianyingOrder.setInsertTime(new Date());dianyingOrder.setCreateTime(new Date());dianyingOrderService.insert(dianyingOrder);return R.ok();}/*** 后端修改*/@RequestMapping("/update")public R update(@RequestBody DianyingOrderEntity dianyingOrder, HttpServletRequest request){logger.debug("update方法:,,Controller:{},,dianyingOrder:{}",this.getClass().getName(),dianyingOrder.toString());String role = String.valueOf(request.getSession().getAttribute("role"));
//        if(false)
//            return R.error(511,"永远不会进入");
//        else if("用户".equals(role))
//            dianyingOrder.setYonghuId(Integer.valueOf(String.valueOf(request.getSession().getAttribute("userId"))));//根据字段查询是否有相同数据Wrapper<DianyingOrderEntity> queryWrapper = new EntityWrapper<DianyingOrderEntity>().eq("id",0);logger.info("sql语句:"+queryWrapper.getSqlSegment());DianyingOrderEntity dianyingOrderEntity = dianyingOrderService.selectOne(queryWrapper);if(dianyingOrderEntity==null){dianyingOrderService.updateById(dianyingOrder);//根据id更新return R.ok();}else {return R.error(511,"表中有相同数据");}}/*** 删除*/@RequestMapping("/delete")public R delete(@RequestBody Integer[] ids){logger.debug("delete:,,Controller:{},,ids:{}",this.getClass().getName(),ids.toString());dianyingOrderService.deleteBatchIds(Arrays.asList(ids));return R.ok();}/*** 批量上传*/@RequestMapping("/batchInsert")public R save( String fileName){logger.debug("batchInsert方法:,,Controller:{},,fileName:{}",this.getClass().getName(),fileName);try {List<DianyingOrderEntity> dianyingOrderList = new ArrayList<>();//上传的东西Map<String, List<String>> seachFields= new HashMap<>();//要查询的字段Date date = new Date();int lastIndexOf = fileName.lastIndexOf(".");if(lastIndexOf == -1){return R.error(511,"该文件没有后缀");}else{String suffix = fileName.substring(lastIndexOf);if(!".xls".equals(suffix)){return R.error(511,"只支持后缀为xls的excel文件");}else{URL resource = this.getClass().getClassLoader().getResource("static/upload/" + fileName);//获取文件路径File file = new File(resource.getFile());if(!file.exists()){return R.error(511,"找不到上传文件,请联系管理员");}else{List<List<String>> dataList = PoiUtil.poiImport(file.getPath());//读取xls文件dataList.remove(0);//删除第一行,因为第一行是提示for(List<String> data:dataList){//循环DianyingOrderEntity dianyingOrderEntity = new DianyingOrderEntity();
//                            dianyingOrderEntity.setDianyingOrderUuidNumber(data.get(0));                    //订单号 要改的
//                            dianyingOrderEntity.setDianyingId(Integer.valueOf(data.get(0)));   //电影 要改的
//                            dianyingOrderEntity.setYonghuId(Integer.valueOf(data.get(0)));   //用户 要改的
//                            dianyingOrderEntity.setDianyingOrderTruePrice(data.get(0));                    //实付价格 要改的
//                            dianyingOrderEntity.setDianyingOrderTypes(Integer.valueOf(data.get(0)));   //订单类型 要改的
//                            dianyingOrderEntity.setDianyingOrderPaymentTypes(Integer.valueOf(data.get(0)));   //支付类型 要改的
//                            dianyingOrderEntity.setBuyZuoweiNumber(data.get(0));                    //购买的座位 要改的
//                            dianyingOrderEntity.setBuyZuoweiTime(new Date(data.get(0)));          //订购日期 要改的
//                            dianyingOrderEntity.setInsertTime(date);//时间
//                            dianyingOrderEntity.setCreateTime(date);//时间dianyingOrderList.add(dianyingOrderEntity);//把要查询是否重复的字段放入map中//订单号if(seachFields.containsKey("dianyingOrderUuidNumber")){List<String> dianyingOrderUuidNumber = seachFields.get("dianyingOrderUuidNumber");dianyingOrderUuidNumber.add(data.get(0));//要改的}else{List<String> dianyingOrderUuidNumber = new ArrayList<>();dianyingOrderUuidNumber.add(data.get(0));//要改的seachFields.put("dianyingOrderUuidNumber",dianyingOrderUuidNumber);}}//查询是否重复//订单号List<DianyingOrderEntity> dianyingOrderEntities_dianyingOrderUuidNumber = dianyingOrderService.selectList(new EntityWrapper<DianyingOrderEntity>().in("dianying_order_uuid_number", seachFields.get("dianyingOrderUuidNumber")));if(dianyingOrderEntities_dianyingOrderUuidNumber.size() >0 ){ArrayList<String> repeatFields = new ArrayList<>();for(DianyingOrderEntity s:dianyingOrderEntities_dianyingOrderUuidNumber){repeatFields.add(s.getDianyingOrderUuidNumber());}return R.error(511,"数据库的该表中的 [订单号] 字段已经存在 存在数据为:"+repeatFields.toString());}dianyingOrderService.insertBatch(dianyingOrderList);return R.ok();}}}}catch (Exception e){return R.error(511,"批量插入数据异常,请联系管理员");}}/*** 前端列表*/@IgnoreAuth@RequestMapping("/list")public R list(@RequestParam Map<String, Object> params, HttpServletRequest request){logger.debug("list方法:,,Controller:{},,params:{}",this.getClass().getName(),JSONObject.toJSONString(params));// 没有指定排序字段就默认id倒序if(StringUtil.isEmpty(String.valueOf(params.get("orderBy")))){params.put("orderBy","id");}PageUtils page = dianyingOrderService.queryPage(params);//字典表数据转换List<DianyingOrderView> list =(List<DianyingOrderView>)page.getList();for(DianyingOrderView c:list)dictionaryService.dictionaryConvert(c, request); //修改对应字典表字段return R.ok().put("data", page);}/*** 前端详情*/@RequestMapping("/detail/{id}")public R detail(@PathVariable("id") Long id, HttpServletRequest request){logger.debug("detail方法:,,Controller:{},,id:{}",this.getClass().getName(),id);DianyingOrderEntity dianyingOrder = dianyingOrderService.selectById(id);if(dianyingOrder !=null){//entity转viewDianyingOrderView view = new DianyingOrderView();BeanUtils.copyProperties( dianyingOrder , view );//把实体数据重构到view中//级联表DianyingEntity dianying = dianyingService.selectById(dianyingOrder.getDianyingId());if(dianying != null){BeanUtils.copyProperties( dianying , view ,new String[]{ "id", "createDate"});//把级联的数据添加到view中,并排除id和创建时间字段view.setDianyingId(dianying.getId());}//级联表YonghuEntity yonghu = yonghuService.selectById(dianyingOrder.getYonghuId());if(yonghu != null){BeanUtils.copyProperties( yonghu , view ,new String[]{ "id", "createDate"});//把级联的数据添加到view中,并排除id和创建时间字段view.setYonghuId(yonghu.getId());}//修改对应字典表字段dictionaryService.dictionaryConvert(view, request);return R.ok().put("data", view);}else {return R.error(511,"查不到数据");}}/*** 前端保存*/@RequestMapping("/add")public R add(@RequestBody DianyingOrderEntity dianyingOrder, HttpServletRequest request){logger.debug("add方法:,,Controller:{},,dianyingOrder:{}",this.getClass().getName(),dianyingOrder.toString());String role = String.valueOf(request.getSession().getAttribute("role"));if("用户".equals(role)){DianyingEntity dianyingEntity = dianyingService.selectById(dianyingOrder.getDianyingId());if(dianyingEntity == null){return R.error(511,"查不到该物品");}// Double dianyingNewMoney = dianyingEntity.getDianyingNewMoney();if(false){}else if(dianyingEntity.getDianyingNewMoney() == null){return R.error(511,"物品价格不能为空");}//计算所获得积分Double buyJifen =0.0;Integer userId = (Integer) request.getSession().getAttribute("userId");YonghuEntity yonghuEntity = yonghuService.selectById(userId);if(yonghuEntity == null)return R.error(511,"用户不能为空");if(yonghuEntity.getNewMoney() == null)return R.error(511,"用户金额不能为空");double balance = yonghuEntity.getNewMoney() - dianyingEntity.getDianyingNewMoney()*(dianyingOrder.getBuyZuoweiNumber().split(",").length);//余额if(balance<0)return R.error(511,"余额不够支付");dianyingOrder.setDianyingOrderTypes(1); //设置订单状态为已支付dianyingOrder.setDianyingOrderTruePrice(dianyingEntity.getDianyingNewMoney()*(dianyingOrder.getBuyZuoweiNumber().split(",").length)); //设置实付价格dianyingOrder.setYonghuId(userId); //设置订单支付人iddianyingOrder.setDianyingOrderPaymentTypes(1);dianyingOrder.setInsertTime(new Date());dianyingOrder.setCreateTime(new Date());dianyingOrderService.insert(dianyingOrder);//新增订单yonghuEntity.setNewMoney(balance);//设置金额yonghuService.updateById(yonghuEntity);return R.ok();}else{return R.error(511,"您没有权限支付订单");}}/*** 退款*/@RequestMapping("/refund")public R refund(Integer id, HttpServletRequest request){logger.debug("refund方法:,,Controller:{},,id:{}",this.getClass().getName(),id);String role = String.valueOf(request.getSession().getAttribute("role"));if("用户".equals(role)){DianyingOrderEntity dianyingOrder = dianyingOrderService.selectById(id);Integer buyNumber = dianyingOrder.getBuyZuoweiNumber().split(",").length;Integer dianyingOrderPaymentTypes = dianyingOrder.getDianyingOrderPaymentTypes();Integer dianyingId = dianyingOrder.getDianyingId();if(dianyingId == null)return R.error(511,"查不到该物品");DianyingEntity dianyingEntity = dianyingService.selectById(dianyingId);if(dianyingEntity == null)return R.error(511,"查不到该物品");Double dianyingNewMoney = dianyingEntity.getDianyingNewMoney();if(dianyingNewMoney == null)return R.error(511,"物品价格不能为空");Integer userId = (Integer) request.getSession().getAttribute("userId");YonghuEntity yonghuEntity = yonghuService.selectById(userId);if(yonghuEntity == null)return R.error(511,"用户不能为空");if(yonghuEntity.getNewMoney() == null)return R.error(511,"用户金额不能为空");Double zhekou = 1.0;//判断是什么支付方式 1代表余额 2代表积分if(dianyingOrderPaymentTypes == 1){//余额支付//计算金额Double money = dianyingEntity.getDianyingNewMoney() * buyNumber  * zhekou;//计算所获得积分Double buyJifen = 0.0;yonghuEntity.setNewMoney(yonghuEntity.getNewMoney() + money); //设置金额}dianyingOrder.setDianyingOrderTypes(2);//设置订单状态为退款dianyingOrderService.updateById(dianyingOrder);//根据id更新yonghuService.updateById(yonghuEntity);//更新用户信息dianyingService.updateById(dianyingEntity);//更新订单中物品的信息return R.ok();}else{return R.error(511,"您没有权限退款");}}/*** 发货*/@RequestMapping("/deliver")public R deliver(Integer id){logger.debug("refund:,,Controller:{},,ids:{}",this.getClass().getName(),id.toString());DianyingOrderEntity  dianyingOrderEntity = new  DianyingOrderEntity();;dianyingOrderEntity.setId(id);dianyingOrderEntity.setDianyingOrderTypes(3);boolean b =  dianyingOrderService.updateById( dianyingOrderEntity);if(!b){return R.error("发货出错");}return R.ok();}/*** 收货*/@RequestMapping("/receiving")public R receiving(Integer id){logger.debug("refund:,,Controller:{},,ids:{}",this.getClass().getName(),id.toString());DianyingOrderEntity  dianyingOrderEntity = new  DianyingOrderEntity();dianyingOrderEntity.setId(id);dianyingOrderEntity.setDianyingOrderTypes(4);boolean b =  dianyingOrderService.updateById( dianyingOrderEntity);if(!b){return R.error("收货出错");}return R.ok();}/*** 评价*/@RequestMapping("/commentback")public R commentback(Integer id, String commentbackText,HttpServletRequest request){logger.debug("commentback方法:,,Controller:{},,id:{}",this.getClass().getName(),id);String role = String.valueOf(request.getSession().getAttribute("role"));if("用户".equals(role)){DianyingOrderEntity dianyingOrder = dianyingOrderService.selectById(id);if(dianyingOrder == null)return R.error(511,"查不到该订单");Integer dianyingId = dianyingOrder.getDianyingId();if(dianyingId == null)return R.error(511,"查不到该物品");DianyingCommentbackEntity dianyingCommentbackEntity = new DianyingCommentbackEntity();dianyingCommentbackEntity.setId(id);dianyingCommentbackEntity.setDianyingId(dianyingId);dianyingCommentbackEntity.setYonghuId((Integer) request.getSession().getAttribute("userId"));dianyingCommentbackEntity.setDianyingCommentbackText(commentbackText);dianyingCommentbackEntity.setReplyText(null);dianyingCommentbackEntity.setInsertTime(new Date());dianyingCommentbackEntity.setUpdateTime(null);dianyingCommentbackEntity.setCreateTime(new Date());dianyingCommentbackService.insert(dianyingCommentbackEntity);dianyingOrder.setDianyingOrderTypes(5);//设置订单状态为已评价dianyingOrderService.updateById(dianyingOrder);//根据id更新return R.ok();}else{return R.error(511,"您没有权限评价");}}}

获取源码或论文

如需对应的LW或源码,以及其他定制需求,也可以点我头像查看个人简介联系。

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

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

相关文章

【数据流图】用JointJs实现数据流图(二)

一、流图如何绑定绘制的元素&#xff1f; 通过打印JointJs生成的属性可知&#xff0c;id是不允许被覆盖修改的&#xff0c;但是cid可以。所以通过绑定元素的cid&#xff0c;可实现后续的操作&#xff0c;如查找元素、更改元素属性等。 1. 绑定cid方式示例 let textEle new …

vector实战

vector声明 初始化 获取数据 修改元素值 追加元素 遍历 定义二维的vector 二维vector遍历 #include <iostream> #include <vector>using namespace std;int main(){// vector 声明vector<string> name_vector;// vector 初始化vector<int> sco…

户外公园实景儿童剧本杀小程序系统开发搭建

户外公园实景儿童剧本杀小程序系统开发搭建涉及到的内容包括但不限于以下几个方面&#xff1a; 1. 项目规划&#xff1a;需要考虑场地的大小、设施的配置、剧本的设定等&#xff0c;这些都是开发前的必要考虑因素。 2. 平台开发&#xff1a;基于小程序开发户外公园实景儿童剧本…

Screeps工程化之数量控制模块

前言 将Screeps的代码进行模块化后&#xff0c;可以将各个功能进行分离&#xff0c;互相不影响&#xff0c;本文将会介绍Screeps中如何进行creep的数量控制来维持房间资源的平衡和发展。本文仅为作者本人的游戏思路&#xff0c;并不是最佳实践&#xff0c;如有更好的实现方法可…

十二届蓝桥杯Python组3月中/高级试题 第四题

** 十二届蓝桥杯Python组3月中/高级试题 第四题 ** 第四题&#xff08;难度系数 4&#xff0c;30 个计分点&#xff09; 编程实现&#xff1a; 给定一组包含n个&#xff08;n>3) 正整数数据&#xff0c;和一个正整数M&#xff0c;从这n个正整数中任意拿出两个数相 加&…

【概率论基础】 一篇文章缕清概率论常见概念关系

碎碎念&#xff1a;再写CSDN之前有一小段时间写数模公众号的经历&#xff0c;但是公众号看的人实在太少了&#xff0c;而且排版和公式、代码编辑都没有CSDN这么方便&#xff0c;所以坚持一算时间就没有更新了。公众号大多写的是概念性的基础&#xff0c;稍加修改搬到咱们的主战…

Git使用及相关问题

总结git中使用的问题 目录 1.git维护文件拷贝后unchanged 1.git维护文件拷贝后unchanged 文件权限不同&#xff0c;文件权限被修改&#xff0c;但内容未改变 命令行中使用git diff: diff --git a/compat/plan9/head b/compat/plan9/head old mode 100755 new mode 100644 主要…

Redis rehash 相关问题

前言 本文主要介绍 Redis Hash 表 rehash 相关的三个问题&#xff1a; 什么时候触发 rehashrehash 扩容扩多大rehash 如何执行 介绍的源码基于 Redis 5.0.8 版本&#xff0c;会删除一些不影响理解的部分。 什么时候触发 rehash Redis 用于判断是否触发 rehash 的函数是 _d…

‘pip‘ 不是内部或外部命令,也不是可运行的程序或批处理文件。

因为python13不支持 pip install cx_Oracle&#xff0c;卸载了python13&#xff0c;重新安装python10&#xff0c;导致cmd命令不识别 pip &#xff0c;和python10&#xff0c;(;༎ຶД༎ຶ) 记录一种临时方案 如果你的命令行界面&#xff08;cmd&#xff09;不识别pip命令&am…

如何挑选“好用”的工业APP

我们日常生活中每天都在使用各种生活类的APP,然而&#xff0c;当我们谈到工业APP时&#xff0c;很多人可能并不那么熟悉。工业APP&#xff0c;虽然不像生活类APP那样直接面向广大消费者&#xff0c;但在工业领域却扮演着至关重要的角色。 先简单认识下啥是工业APP? 工业APP是…

集成学习算法:AdaBoost原理详解以及基于adaboost的图像二分类代码实现

本文尽量从一个机器学习小白或是只对机器学习算法有一个大体浅显的视角入手&#xff0c;尽量通俗易懂的介绍清楚AdaBoost算法&#xff01; 一、AdaBoost简介 AdaBoost&#xff0c;是英文"Adaptive Boosting"&#xff08;自适应增强&#xff09;的缩写&#xff0c;由…

【退役之重学Java】关于缓存

一、为什么要用缓存 缓存嘛&#xff0c;对比计算机组成原理中的“高速缓存控制器”&#xff0c;就可以知道&#xff0c;缓存的存在是为了获取高性能&#xff0c;特别是在高并发场景下获取高性能。 二、缓存是如何获取高性能的 SQL的执行是非常消耗性能的有一些SQL经常是一样的…

【开发工具】使用Github pages、Hexo如何10分钟内快速生成个人博客网站

文章目录 一.准备工作1.安装git2.安装node安装 cnpm 3.使用 GitHub 创建仓库&#xff0c;并配置 GitHub Pages0.Github Pages是什么1. 在 GitHub 上创建一个新仓库2. 创建您的静态网站3. 启用 GitHub Pages4. 等待构建完成5. 访问您的网站 二. Hexo1.什么是Hexo2.安装Hexo1. 安…

分拣机器人也卷的飞起来了

导语 大家好&#xff0c;我是智能仓储物流技术研习社的社长&#xff0c;老K。专注分享智能仓储物流技术、智能制造等内容。 新书《智能物流系统构成与技术实践》 智能制造-话题精读 1、西门子、ABB、汇川&#xff1a;2024中国工业数字化自动化50强 2、完整拆解&#xff1a;智能…

解锁Swagger鉴权

在开发过程中&#xff0c;Swagger 是一个非常流行的 API 文档生成工具&#xff0c;它不仅可以帮助开发者设计、构建、记录 RESTful API&#xff0c;还能通过其交互式的 UI 改善前后端开发者的沟通效率。然而&#xff0c;在实际生产环境中&#xff0c;暴露未加保护的 API 文档可…

大数据基础工程技术团队4篇论文入选ICLR,ICDE,WWW

近日&#xff0c;由阿里云计算平台大数据基础工程技术团队主导的四篇时间序列相关论文分别被国际顶会ICLR2024、ICDE2024和WWW2024接收。 论文成果是阿里云与华东师范大学、浙江大学、南京大学等高校共同研发&#xff0c;涉及时间序列与智能运维结合的多个应用场景。包括基于P…

Android 蓝牙实战——蓝牙电话通话状态同步(二十四)

前面分析了蓝牙电话通话状态的广播,我们可以在蓝牙电话中实时监听蓝牙电话的状态,但如果是其他音乐类 APP 呢,在播放的时候也需要知道当前是否有通话正在进行,但是有完全没必要实时监听电话的状态,这就需要一个获取通话状态的方法。 一、通话状态处理 1、CallsManager …

MySQL学习笔记12——效率和优化

效率和优化 一、对查询语句进行调优1、查询分析语句2、优化查询方法 二、改进表设计以提高性能1、优化数据类型2、合理增加冗余字段以提高效率3、拆分表4、使用非空约束 三、如何充分利用系统资源1、优化系统资源配置2、如何利用系统资源来诊断问题 一、对查询语句进行调优 你…

vscode触发建议缓慢问题

说明 关于vscode上vite项目文件过多导致触发建议缓慢问题&#xff0c; 本人框架主要使用的技术是 vite vue3 ts tailwind eslint 项目初始阶段建议提示秒出&#xff0c;当项目文件过多时&#xff0c;建议延迟太高&#xff0c;即使是console代码片段也会过好几秒才出现 …

【R语言】边缘概率密度图

边缘概率密度图是一种在多变量数据分析中常用的图形工具&#xff0c;用于显示每个单独变量的概率密度估计。它通常用于散点图的边缘&#xff0c;以便更好地理解单个变量的分布情况&#xff0c;同时保留了散点图的相关性信息。 在边缘概率密度图中&#xff0c;每个变量的概率密度…