一、环境准备
1.idea 2022.2
2.jdk 8
3.maven
4.mysql 8.0.27
(以上只是基线包需求我能想到的环境准备,后期可能会添加)
5.我使用了gitee来作为我们软件工程实践小组的代码管理平台 项目开源网址:软件工程实践: 软件工程实践 (gitee.com)https://gitee.com/qc-wow-Aatrox/software-engineering-practice
二、maven统一依赖管理
每个模块都有各自的pom文件,同时父项目也有自己的pom文件,被所有子模块共用。可能存在的问题:子模块各自引入依赖,出现版本不同,大量重复等问题
解决方法:
1.将公用的依赖,抽象在父类pom中引入
2.公用依赖版本统一在父类pom中管理
3.子模块pom只引入各自需要的,尽量复用父类的版本
以下是我们小组项目中可能会用到的依赖
<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 http://maven.apache.org/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<modules>
<module>common</module>
<module>interface</module>
<module>service_provider</module>
<module>background</module>
<module>front</module>
</modules>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.7.3</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.rjgc.mall</groupId>
<artifactId>mall_parent</artifactId>
<version>1.0-SNAPSHOT</version>
<name>Archetype - mall_parent</name>
<url>http://maven.apache.org</url>
<packaging>pom</packaging>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.27</version>
<scope>runtime</scope>
</dependency>
<dependency>
<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>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
</dependency>
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.2.2</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
</dependency>
</dependencies>
<!-- 这里配置全局版本依赖管理 -->
<properties>
<java.version>1.8</java.version>
<com.alibaba.druid>1.2.8</com.alibaba.druid>
<com.alibaba.fastjson>1.2.76</com.alibaba.fastjson>
<com.qiniu.qiniu-java-sdk>7.7.0</com.qiniu.qiniu-java-sdk>
<com.github.pagehelper.pagehelper-spring-boot-starter>1.4.1
</com.github.pagehelper.pagehelper-spring-boot-starter>
</properties>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>${com.alibaba.druid}</version>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>${com.alibaba.fastjson}</version>
</dependency>
<dependency>
<groupId>com.qiniu</groupId>
<artifactId>qiniu-java-sdk</artifactId>
<version>${com.qiniu.qiniu-java-sdk}</version>
</dependency>
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper-spring-boot-starter</artifactId>
<version>${com.github.pagehelper.pagehelper-spring-boot-starter}</version>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
三、设计数据库表
为了统一表的数据格式,我们小组不需要让每一制作后端的人员自己设计数据库表,这样可能会让其他人不了解,所以要让一个人专门制作数据库表,与大家讨论就行了。
根据软件工程实践大作业基线需求包的描述
我从中抽出三个实体:商品、卖家、用户。
其次分析三个实体之间的关系:
1.商品与卖家之间存在所属关系,商品与卖家之间存在多对一关系,这里我选择将卖家的主键id放在商品中作为外键
2.商品与用户之间存在被购买关系,商品与用户之间属于多对一关系,这里我选择抽象出一个实体来记录用户与商品之间的交易行为
3.用户与卖家之间,我感觉其实是一个间接关系,是一个通过商品连接的关系,所以我没选择添加新的实体
接下来是我设计的数据库表(当然还有些属性我是为了接下来的挑战功能增加的,可能有疏忽,接下来还要更改)
商品表 goods:
卖家表 seller:
用户表 user:
用户交易行为表 trade_action: