MP的开发流程-1

news2025/1/21 21:51:20

MP的开发流程

1、添加依赖

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.ma</groupId>
    <artifactId>product</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>product</name>
    <description>Demo project for Spring Boot</description>
    <properties>
        <java.version>1.8</java.version>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <spring-boot.version>2.6.13</spring-boot.version>
    </properties>
    <dependencies>
        <!-- 表现层 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!-- 业务层缓存 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
        </dependency>
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-pool2</artifactId>
        </dependency>
        <!--持久层 -->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.5.3.1</version>
        </dependency>
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid-spring-boot-starter</artifactId>
            <version>1.2.18</version>
        </dependency>
        <dependency>
            <groupId>com.mysql</groupId>
            <artifactId>mysql-connector-j</artifactId>
            <scope>runtime</scope>
        </dependency>
        <!--- 其它工具类 -->
        <dependency>  <!-- 支持热启动 -->
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <scope>runtime</scope>
            <optional>true</optional>
        </dependency>
        <dependency><!-- 简化值bean的编码 -->
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <!-- 单元测试 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>
    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-dependencies</artifactId>
                <version>${spring-boot.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.10.1</version>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                    <encoding>UTF-8</encoding>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <version>${spring-boot.version}</version>
                <configuration>
                    <mainClass>com.ma.ProductApplication</mainClass>
                    <skip>true</skip>
                </configuration>
                <executions>
                    <execution>
                        <id>repackage</id>
                        <goals>
                            <goal>repackage</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>
</project>

创建项目时添加一些要用到的配置

在这里插入图片描述

2、添加核心配置,一般建议使用yaml格式,对应的核心配置文件为resources/application.yml

# 默认使用服务器为tomcat
server:
    port: 8080
# 数据库连接池的配置
spring:
    datasource:
        type: com.alibaba.druid.pool.DruidDataSource
        driver-class-name: com.mysql.cj.jdbc.Driver
        url: jdbc:mysql:///test?serverTimezone=UTC
        username: root
        password: 10086

# 和连接池产品紧密相关的配置信息,一般参照旧有项目进行配置,如果没有则使用默认即可
    druid:
        max-active: 10
        min-idle: 3
#MP相关配置
mybatis-plus:
    mapper-location: classpath:mapper/*.com
    configuration:
        log-impl: org.apache.ibatis.logging.stdout.StdOutImpl

3、定义数据表

实际开发中,从上到下或者从下到上进行开发都可以,一般考虑采用一个方向最佳

在resource文件夹中创建包database创建schame.sql定义数据表:

create table if not exists tbl_product(
    id bigint primary key auto_increment,
    name varchar(32) not null,
    catalog_id bigint,
    price numeric(8,2),
    store_num int
)engine = innodb default charset utf8;

创建目录:

create table if not exists tbl_catalog(
    id bigint primary key auto_increment,
    name varchar(32) not null unique,
    memo varchar(100)
)engine = innodb default charset utf8;
  • 最近的一个面试热点是auto_increment的处理,例如auto_increment到达上限继续插入数据MySQL如何处理?

    在MySQL中,当自增字段(如使用auto_increment修饰的字段)达到上限后继续插入数据会发生以下情况:

    1. 达到上限后插入新数据会引发一个错误。MySQL会抛出异常并报告违反"Duplicate entry"约束错误,因为插入的值与已存在的记录具有相同的自增字段值。

    2. 自增字段的上限取决于其数据类型。例如,如果使用int数据类型,自增字段的上限为232-1(约为21亿)。如果使用`bigint`数据类型,自增字段的上限为264-1(非常大)。

    针对达到自增字段上限的情况,你可以考虑以下解决方案:

    1. 使用更大的数据类型:如果你预计可能到达自增字段上限,可以使用更大的数据类型来存储自增字段的值。例如,将int类型更改为bigint类型,这将使得自增字段的上限非常大,几乎可以无限地插入新的记录。
    ALTER TABLE your_table MODIFY column_name BIGINT AUTO_INCREMENT;
    
    1. 重新设置自增字段起始值:如果你的自增字段已经达到上限并且你不希望更改其数据类型,你可以通过重新设置自增字段的起始值来继续插入新数据。这样会自动将自增字段的值从指定的值开始递增。
    ALTER TABLE your_table AUTO_INCREMENT = new_starting_value;
    

    请注意,重新设置自增字段的起始值时,确保指定的新值不会与已存在的记录冲突。

    总之,在MySQL中,当自增字段达到上限时,会引发错误并报告违反重复约束。你可以通过更改数据类型或重新设置自增字段的起始值来解决这个问题。

  • 在互联网应用开发中针对类目的处理方法常见的有2种:

    • 如果可以确定三级分类,则创建类目大表、类目小表和产品表
    • 如果类目等级无法提前确定或者分类层数大于3,则考虑使用自关联的方式定义类目表
  • 一般在项目开发中定义表的时候,除了主键约束,其它约束一概不加

  • 在具体的项目实践中一般会预留部分列

4、使用MyBatisX插件针对表进行反向映射,生成对应的mapper接口、业务接口和对应的映射元文件

4.1、首先创建数据源

在这里插入图片描述

4.2、在DataSource窗口中右键点击数据表的名称执行MyBatisX

在这里插入图片描述

点击Next

在这里插入图片描述

5、检查反向映射生成的内容,如果有不合理的部分,则需要进行修改

在这里插入图片描述

MP针对注解提供的主键生成策略

  • AUTO:id自增
  • NONE: 不设置id生成策略
  • INPUT:用户手工输入id
  • ASSIGN_ID:雪花算法生成id
  • ASSIGN_UUID:以UUID生成算法作为id生成策略

雪花算法生成的是一个64bit大小的整数,一般用于分布式应用中,如果针对数据库进行了横切,如何保证id值的唯一性

  • 41bit的时间戳:用来记录时间戳,毫秒级
  • 10bit的工作机器id:用来记录工作机器id
  • 12bit的序列号:占用12bit,每个节点每毫秒0开始不断累加,最多可以累加到4095,一共可以产生4096个ID

ASSIGN_UUID

  • ASSIGN_UUID是自动生成一个不重复的、长度为32字符长的字符串,也能在分布式系统中使用

6、如果采用的是按需编程的方式进行开发,则下一步建议编写控制器,由控制类的定义过程中总结出业务类所需要的方法

RESTful是一种网络应用程序的设计风格和开发方式,基于HTTP,可以使用XML格式定义或JSON格式定义。RESTFUL适用于移动互联网厂商作为业务接口的场景,实现第三方OTT调用移动网络资源的功能,动作类型为新增、变更、删除所调用资源。

  • 如果查询则使用GET、如果新创建则POST、如果删除的DELETE、如果修改则PUT

  • get和post之间的区别

    GET和POST是HTTP协议中最常见的两种请求方法,它们在以下方面有所区别:

    1. 请求位置和数据传递:GET方法将请求参数附加在URL的末尾(查询字符串中),而POST方法将请求参数包含在请求的消息体中。GET请求的参数会显示在URL中,对于POST请求,参数不会直接显示在URL中。

    2. 安全性:GET请求是幂等的,即多次请求对于服务器的状态没有影响,不会产生副作用。POST请求可能会产生副作用,例如向服务器提交表单数据,更新数据库等。因此,POST请求相对于GET请求来说更具有安全性。

    3. 数据长度限制:由于GET请求的参数附加在URL上,URL的最大长度是有限制的。根据不同的浏览器和服务器配置,通常限制在几千个字符。POST请求的数据放在消息体中,没有像GET请求那样的长度限制。

    4. 可见性:GET请求的参数在URL中可见,作为查询字符串的一部分。POST请求的参数不会直接在URL中可见,不会被搜索引擎等索引。

    5. 缓存:GET请求默认可被缓存,而POST请求不可被缓存。GET请求适用于获取资源,且不会改变服务器状态,所以可以允许缓存。POST请求用于向服务器发送数据,可能会更新资源,不适合被缓存。

    6. 使用场景:GET请求适用于从服务器获取数据,例如获取网页、图片等资源。POST请求适用于向服务器提交数据,例如提交表单、上传文件等操作。

    需要注意的是,以上是一些常见的区别,但实际使用中可能还有其他因素需要考虑,例如某些安全性要求、服务器限制等。选择使用GET或POST方法时,要根据具体的场景和需求来进行决策。

  • http协议的请求流程以及不同版本的区别

    HTTP(Hypertext Transfer Protocol)是一种用于在Web上进行数据传输的协议。下面是HTTP协议的请求流程以及不同版本之间的主要区别:

    1. 请求流程:
    • 客户端发起一个HTTP请求到服务器的特定地址(URL)。
    • 请求包括一个方法(GET、POST、PUT等)、请求头(如Accept、Content-Type)和请求体(如POST请求中的表单数据)。
    • 服务器接收到请求后进行处理,可以返回相应的数据和状态码。
    • 客户端接收到服务器的响应后进行处理,可能是显示响应内容或者执行其他操作。
    1. HTTP/1.0和HTTP/1.1的区别:
    • 持久连接:HTTP/1.0默认使用非持久连接,即每个请求/响应后关闭连接,而HTTP/1.1默认使用持久连接,在同一连接上可以发送多个请求。这减少了每次请求的延迟和额外的连接开销。
    • 请求管道化:HTTP/1.1支持请求管道化,即在同一持久连接上可以同时发送多个请求,而HTTP/1.0不支持。这提高了请求响应的效率。
    • Host头字段:HTTP/1.1引入了Host头字段,用于指定请求的目标主机,可以支持一个服务器上的多个虚拟主机。
    • 错误处理:HTTP/1.1使用更多的状态码,如100 Continue、307 Temporary Redirect等。
    • 缓存和代理:HTTP/1.1引入了更多的缓存控制指令和代理机制,以提高缓存的效率和交互的安全性。
    1. HTTP/2的改进:
    • 二进制协议:HTTP/2使用二进制格式传输数据,取代了HTTP/1.x的文本格式,提高了传输效率和解析速度。
    • 多路复用:HTTP/2通过在同一连接上使用多个虚拟流来并发传输请求和响应,消除了HTTP/1.x中的队头阻塞问题,提高了并发性能。
    • 头部压缩:HTTP/2使用了HPACK算法对请求和响应的头部进行压缩,减少了传输的数据量。
    • 服务器推送:HTTP/2支持服务器主动推送,可以在客户端请求之前将相关资源一起发送给客户端,提高加载速度。
    • 优化了HTTP语义:HTTP/2优化了某些请求的语义,如将多个CSS文件合并为一个请求。

    总结起来,HTTP协议的请求流程包括客户端发起请求、服务器接收并处理请求、服务器返回响应、客户端接收响应。不同版本的HTTP协议在持久连接、请求管道化、Host头字段、错误处理、缓存和代理、二进制协议、多路复用、头部压缩和服务器推送等方面有不同的特点和改进。这些改进旨在提高性能、效率和安全性,以适应不断增长的Web应用需求。

  • http协议和https协议的区别

    HTTP(Hypertext Transfer Protocol)和HTTPS(Hypertext Transfer Protocol Secure)是两种用于在Web上进行数据传输的协议,它们之间存在以下主要区别:

    1. 安全性:
    • HTTP是明文传输协议,所有的通信内容都是以明文形式传输,容易被攻击者窃听、篡改或偷取敏感信息。
    • HTTPS使用SSL/TLS协议对通信进行加密和身份验证,保证通信的机密性和完整性,使得被传输的数据更加安全。
    1. 默认端口:
    • HTTP的默认端口是80,客户端发送请求时不需要明确指定端口号。
    • HTTPS的默认端口是443,客户端发送请求时需要明确指定端口号。
    1. 证书:
    • HTTP不需要证书验证,无法验证服务器的真实身份。
    • HTTPS使用数字证书对服务器进行身份验证,客户端可以验证服务器的真实性和合法性,确保通信与合法服务器建立连接。
    1. 加密:
    • HTTP不加密传输数据,容易被第三方截获和篡改,信息安全性无法得到保障。
    • HTTPS使用SSL/TLS协议进行数据加密和解密,确保传输过程中的敏感信息不被窃取或篡改。
    1. 性能开销:
    • HTTP没有加密和验证的过程,传输速度较快,性能开销相对较低。
    • HTTPS在通信过程中需要进行加密和解密的操作,会增加通信的开销,相对于HTTP而言性能稍低。

    总结起来,HTTP是一种不安全的明文传输协议,适用于一些对数据安全性要求不高的场景。而HTTPS通过加密和身份验证,保证了通信的机密性和完整性,适用于需要对敏感信息进行保护的场景。HTTPS在安全性上对比HTTP有明显优势,但在性能方面会存在一些开销。因此,在具体应用场景中需要根据安全性需求和性能要求来选择使用HTTP还是HTTPS。

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

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

相关文章

Java Design and development -- QQ chat

About ARTS - Complete one ARTS per week: ● Algorithm: Do at least one LeetCode algorithm per week Review: Read and comment on at least one technical article in English ● Tips: Learn at least one technical trick ● Share: Share a technical article with op…

#P0999. [NOIP2008普及组] 排座椅

题目描述 上课的时候总会有一些同学和前后左右的人交头接耳&#xff0c;这是令小学班主任十分头疼的一件事情。不过&#xff0c;班主任小雪发现了一些有趣的现象&#xff0c;当同学们的座次确定下来之后&#xff0c;只有有限的 DD 对同学上课时会交头接耳。 同学们在教室中坐…

不同情境下沟通有哪些可用的工具箱?

在不同情境下&#xff0c;沟通的工具箱可以包括以下几个方面&#xff1a; 面对面交流&#xff1a;面对面交流是最直接和有效的沟通方式。可以通过面对面的会议、面谈或小组讨论等方式进行沟通。面对面交流可以更好地传递情感和非语言信息&#xff0c;有助于建立信任和理解。 …

基于峰谷分时电价引导下的电动汽车充电负荷优化(matlab代码)

目录 1 主要内容 峰谷电价优化 电动汽车充电负荷变化 2 部分代码 3 程序结果 1 主要内容 该程序基本复现《基于峰谷分时电价引导下的电动汽车充电负荷优化》&#xff0c;代码主要做的是基于NSGA-II的电动汽车充电负荷优化&#xff0c;首先&#xff0c;在研究电动汽车用户充…

Spring声明式事务@Transactional的一些问题的测试及求证

1.Spring的声明式事务Transactional问题 前提&#xff1a;有两个方法&#xff0c;a方法对a表做修改操作&#xff0c;b方法对b表做修改操作 a方法调用b方法&#xff0c;然后a方法报错&#xff0c;伪代码如下 public void a() {//数据库修改操作CompensateLogDO compensateLogDO…

英文论文(sci)解读复现【NO.14】基于关注机制的葡萄叶片病害检测

此前出了目标检测算法改进专栏&#xff0c;但是对于应用于什么场景&#xff0c;需要什么改进方法对应与自己的应用场景有效果&#xff0c;并且多少改进点能发什么水平的文章&#xff0c;为解决大家的困惑&#xff0c;此系列文章旨在给大家解读发表高水平学术期刊中的 SCI论文&a…

【宝藏系列】STM32之C语言基础知识

【宝藏系列】STM32之C语言基础知识 文章目录 【宝藏系列】STM32之C语言基础知识1️⃣位操作2️⃣define宏定义3️⃣ifdef条件编译4️⃣extern变量声明5️⃣typedef类型别名 C语言是单片机开发中的必备基础知识&#xff0c;本文列举了部分 STM32 学习中比较常见的一些C语言基础知…

OAuth机制_web站点接入微软azure账号进行三方登录

文章目录 ⭐前言⭐微软三方登录流程&#x1f496; web站点获取微软账号流程&#x1f496; node封装微软登录接口&#x1f496; webapp 自定义code换token&#x1f496; 调用 Microsoft Graph API&#x1f496; 前端唤醒authlink进行登录回调逻辑 ⭐结束 ⭐前言 大家好&#xf…

React(1)——快速入门

一、React背景简介 官网和资料 英文官网: https://reactjs.org/中文官网: 快速入门 – React (docschina.org) 3、如果JS基础忘了及时查看文档&#xff1a;JavaScript - 学习 Web 开发 |多核 (mozilla.org) JavaScript - 标签 - 汤姆大叔 - 博客园 (cnblogs.com) 4、React…

day49-Todo List(待办事项列表)

50 天学习 50 个项目 - HTMLCSS and JavaScript day49-Todo List&#xff08;待办事项列表&#xff09; 效果 index.html <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" /><meta name"viewport" co…

缓存数据同步技术Canal

说明&#xff1a;缓存数据同步&#xff0c;以Redis为例&#xff0c;如何保证从Redis中取出来的数据与MySQL中的一致&#xff1f;在微服务架构下&#xff0c;通常可以用以下两种技术来实现&#xff1a; MQ&#xff1a;在修改数据的同时&#xff0c;发送一个消息修改缓存&#x…

SpringBoot月度员工绩效考核管理系统【附任务书|ppt|万字文档(LW)和搭建文档】

主要功能 员工登录&#xff1a; ①首页、个人中心&#xff1a;修改密码、个人信息管理等 ②公告信息管理、绩效指标管理、绩效考核管理 管理员登录&#xff1a; ①首页、个人中心&#xff1a;修改密码、个人信息管理等 ②公告信息管理、部门管理、岗位管理、员工管理、绩效指标…

神奇数学世界的魔力迷踪:破解3的幂次方之谜

本篇博客会讲解力扣“326. 3 的幂”的解题思路&#xff0c;这是题目链接。 昨天刚刚讲解完2的幂&#xff0c;今天就来看看3的幂。 思路1 3的幂不能像2的幂那样&#xff0c;直接看二进制中是否有且仅有一位为1&#xff0c;所以“2的幂”那道题中的前两种方法就失效了&#xff…

《MySQL 实战 45 讲》课程学习笔记(一)

基础架构&#xff1a;一条 SQL 查询语句是如何执行的&#xff1f; MySQL 的基本架构 MySQL 可以分为 Server 层和存储引擎层两部分。 Server 层 包括连接器、查询缓存、分析器、优化器、执行器&#xff1b;涵盖 MySQL 的大多数核心服务功能&#xff0c;以及所有的内置函数&…

【雕爷学编程】MicroPython动手做(18)——掌控板之声光传感器2

知识点&#xff1a;什么是掌控板&#xff1f; 掌控板是一块普及STEAM创客教育、人工智能教育、机器人编程教育的开源智能硬件。它集成ESP-32高性能双核芯片&#xff0c;支持WiFi和蓝牙双模通信&#xff0c;可作为物联网节点&#xff0c;实现物联网应用。同时掌控板上集成了OLED…

YOLOv5改进最新ICCV2023顶会LSKNet:大选择性卷积核的领域首次探索,助力小目标检测

YOLOv5改进最新ICCV2023顶会LSKNet:大选择性卷积核的领域首次探索,助力小目标检测 一、论文总结特征融合策略(即空间选择机制)二、代码部分,将LSKNet结构加入到YOLOv5中。论文:https://arxiv.org/pdf/2303.09030.pdf 代码https://github.com/zcablii/LSKNet/blob/main/mm…

【屏幕适配发展介绍 Objective-C语言】

一、接下来,我们花一天时间,给大家介绍这个屏幕适配 1.那么,屏幕适配,是什么意思啊 我们说,写程序的时候,我们有时候要做 1)系统适配 2)屏幕适配 1)系统适配:是指的你写的这个代码,在iOS6、iOS7、iOS8,在不同的iOS系统下,是不是运行的效果,一致吧 这个指的是…

【读书笔记】《太白金星有点烦》

哦吼&#xff01;这次开了一本轻松愉悦的书。 太白金星和观音分属于两个不同的部门&#xff0c;也有不同的领导&#xff0c;为了完成九九八十一难的策划而暂时合作。观音开始并瞧不上这个老头&#xff0c;对他极度欺瞒&#xff0c;但老头也不是任人揉捏的软柿子&#xff0c;给…

【雕爷学编程】MicroPython动手做(17)——掌控板之触摸引脚

知识点&#xff1a;什么是掌控板&#xff1f; 掌控板是一块普及STEAM创客教育、人工智能教育、机器人编程教育的开源智能硬件。它集成ESP-32高性能双核芯片&#xff0c;支持WiFi和蓝牙双模通信&#xff0c;可作为物联网节点&#xff0c;实现物联网应用。同时掌控板上集成了OLED…

Tailwind CSS:基础使用/vue3+ts+Tailwind

一、理解Tailwind 安装 - TailwindCSS中文文档 | TailwindCSS中文网 Installation - Tailwind CSS 1.1、词义 我们简单理解就是搭上CSS的顺风车&#xff0c;事半功倍。 1.2、Tailwind CSS有以下优势 1. 快速开发&#xff1a;Tailwind CSS 提供了一些现成的 class / 可复用…