当前位置:Gxlcms > 数据库问题 > SSM实战——秒杀系统之创建项目、管理依赖、设计数据库

SSM实战——秒杀系统之创建项目、管理依赖、设计数据库

时间:2021-07-01 10:21:17 帮助过:9人阅读

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/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>MySeckill</groupId> <artifactId>MySeckill</artifactId> <version>0.0.1-SNAPSHOT</version> <dependencies> <!-- 单元测试依赖:使用4.11版本,该版本提供基于注解的测试配置 --> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.11</version> <scope>test</scope> </dependency> <!-- 1:日志依赖:slf4j:日志的规范、接口 + logback:日志接口的实现 + 二者整合依赖包--> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-api</artifactId> <version>1.7.7</version> </dependency> <dependency> <groupId>ch.qos.logback</groupId> <artifactId>logback-core</artifactId> <version>1.1.1</version> </dependency> <!-- 实现slf4j接口并整合 --> <dependency> <groupId>ch.qos.logback</groupId> <artifactId>logback-classic</artifactId> <version>1.1.1</version> </dependency> <!-- 2:数据库依赖:mysql驱动 + c3p0连接池 --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.37</version> <scope>runtime</scope> </dependency> <dependency> <groupId>c3p0</groupId> <artifactId>c3p0</artifactId> <version>0.9.1.2</version> </dependency> <!-- 3:Mybatis相关依赖:mybatis自身依赖 + mybatis整合spring依赖 --> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.3.0</version> </dependency> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis-spring</artifactId> <version>1.2.3</version> </dependency> <!-- 4: Servlet web相关依赖--> <!-- 标签依赖 + jstl标签库 --> <dependency> <groupId>taglibs</groupId> <artifactId>standard</artifactId> <version>1.1.2</version> </dependency> <dependency> <groupId>jstl</groupId> <artifactId>jstl</artifactId> <version>1.2</version> </dependency> <!-- json处理工具:jackson依赖 --> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-databind</artifactId> <version>2.5.4</version> </dependency> <!-- servlet本身依赖 --> <dependency> <groupId>javax.servlet</groupId> <artifactId>javax.servlet-api</artifactId> <version>3.1.0</version> </dependency> <!-- 5:spring相关依赖 --> <!-- 1)spring核心依赖:core、beans、context --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-core</artifactId> <version>4.1.7.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-beans</artifactId> <version>4.1.7.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>4.1.7.RELEASE</version> </dependency> <!-- 2)spring dao层依赖:jdbc依赖 + 事务管理依赖 --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-jdbc</artifactId> <version>4.1.7.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-tx</artifactId> <version>4.1.7.RELEASE</version> </dependency> <!-- 3)spring web层依赖:web依赖 + mvc依赖 --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-web</artifactId> <version>4.1.7.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>4.1.7.RELEASE</version> </dependency> <!--4)spring测试依赖 --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-test</artifactId> <version>4.1.7.RELEASE</version> </dependency> </dependencies> <build /> </project>

 

二:项目分析

1:秒杀操作

秒杀操作其实就是对数据库库存的减操作,并记录这个动作以及结果。这个“减”+“记录”是原子的,所以需要事务来管理。

2:动作信息

用户执行秒杀操作,所需信息主要有:谁?什么时候?结果如何?

3:高并发瓶颈

整个秒杀过程归根结底就是对库存的“减”操作的执行。一个减操作,对应库存表一行商品记录的修改;多个用户秒杀这个商品,则对应多个对这行的操作。这些同时发起的对同一行的操作该如何安排顺序?

数据库本身采用行级锁来管理这些并发的操作:对同一行,某一时刻只能有一个事务操作它。

那么一旦事务多了起来,比如上万条秒杀操作该如何调度?这就是高并发的瓶颈所在。

 

三:功能实现

1:秒杀网址暴露

到了秒杀时间才开放秒杀网址

2:执行秒杀

3:秒杀后是信息查询

 

四:数据库设计

CREATE DATABASE seckill;

USE seckill;

CREATE TABLE seckill(
`seckill_id` BIGINT NOT NULL AUTO_INCREMENT COMMENT 商品库存id,
`name` VARCHAR(120) NOT NULL COMMENT 商品名称,
`number` INT NOT NULL COMMENT 库存数量,
`create_time` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT 创建时间,
`start_time` TIMESTAMP NOT NULL COMMENT 秒杀开启时间,
`end_time` TIMESTAMP NOT NULL COMMENT 秒杀结束时间,
PRIMARY KEY(seckill_id),
KEY idx_start_time(start_time),
KEY idx_end_time(end_time),
KEY idx_create_time(create_time)
)ENGINE=INNODB AUTO_INCREMENT=1000 DEFAULT CHARSET=utf8 COMMENT=秒杀库存表;

`success_killed`

CREATE TABLE success_killed(
`seckill_id` BIGINT NOT NULL COMMENT 秒杀商品id,
`user_phone` BIGINT NOT NULL COMMENT 用户手机号,
`state` TINYINT NOT NULL DEFAULT -1 COMMENT 状态标识:-1:无效 0:成功 1:已付款,2:已发货
`create_time` TIMESTAMP NOT NULL COMMENT 创建时间,
PRIMARY KEY(seckill_id,user_phone),/*联合主键*/
KEY ids_create_time(create_time)

)ENGINE=INNODB DEFAULT CHARSET = utf8 COMMENT=秒杀成功明细表;

 

SSM实战——秒杀系统之创建项目、管理依赖、设计数据库

标签:nod   utf8   fas   资源   tor   mybatis   创建时间   结束时间   结束   

人气教程排行