一、环境搭建

这里可使用VMWare,也可以使用VirtualBox,以下以VirtualBox为例子:

1、安装 linux 虚拟机

  • 下载&安装 VirtualBox , 要开启CPU 虚拟化
  • https://www.virtualbox.org/ — 官方

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-QyJZXRRn-1632152535254)(C:/Users/PePe/AppData/Roaming/Typora/typora-user-images/image-20210920145625011.png)]

  • 下载&安装 Vagrant

    • https://app.vagrantup.com/boxes/search Vagrant 官方镜像仓库
    • https://www.vagrantup.com/downloads.html Vagrant 下载
  • 打开 window cmd 窗口,运行 Vagrant init centos/7,即可初始化一个 centos7 系统

    Vagrant init centos/7
    
  • 运行 vagrant up 即可启动虚拟机。系统 root 用户的密码是 vagrant

    vagrant up
    
  • vagrant 其他常用命令

    • vagrant ssh

      自动使用 vagrant 用户连接虚拟机

    • vagrant upload source [destination] [name|id]:

      上传文件

    • https://www.vagrantup.com/docs/cli/init.html Vagrant 命令行

  • 默认虚拟机的 ip 地址不是固定 ip,开发不方便

    • Vagrantfile文件一般会生成在用户文件夹下如:C:\Users\PePe

    • 修改 Vagrantfile,ip的设定根据如何ipconfig来对应虚拟机的ip地址范围

      config.vm.network "private_network", ip: "192.168.56.10"
      

      [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-HTIQMZDb-1632152535258)(C:/Users/PePe/AppData/Roaming/Typora/typora-user-images/image-20210920153803835.png)]

    • 这里的 ip 需要在物理机下使用 ipconfig 命令找到

      [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-N6T22LSi-1632152535259)(C:/Users/PePe/AppData/Roaming/Typora/typora-user-images/image-20210920153507993.png)]

    • 改为这个指定的子网地址

      重新使用 vagrant up 启动机器即可。然后再 vagrant ssh 连接机器

    • 默认只允许 ssh 登录方式,为了后来操作方便,文件上传等,我们可以配置允许账号密码登录

    Vagrant ssh # 进去系统之后
    vi /etc/ssh/sshd_config
    修改 PasswordAuthentication yes/no
    service sshd restart # 重启服务
    
    • 以后可以使用提供的 ssh 连接工具直接连接

    注意:VirtualBox 会与包括但不限于如下软件冲突,需要卸载这些软件,然后重启电脑;

    冲突的软件:红蜘蛛,360,净网大师(有可能)等

  • 修改 linux 的 yum 源

    • 备份原 yum 源

      mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup
      
    • 使用新 yum 源

      curl -o /etc/yum.repos.d/CentOS-Base.repo
      http://mirrors.163.com/.help/CentOS7-Base-163.repo
      
    • 生成缓存

      yum makecache
      

2、安装 docker

Docker 安装文档

https://docs.docker.com/install/linux/docker-ce/centos/

  • 卸载系统之前的 docker

    sudo yum remove docker \
                    docker-client \
                    docker-client-latest \
                    docker-common \
                    docker-latest \
                    docker-latest-logrotate \
                    docker-logrotate \
                    docker-engine
    
  • 安装 Docker-CE

    • 安装必须的依赖

      sudo yum install -y yum-utils \
              device-mapper-persistent-data \
              lvm2
      
    • 设置 docker repo 的 yum 位置

      sudo yum-config-manager \
              --add-repo \
              https://download.docker.com/linux/centos/docker-ce.repo
      
    • 安装 docker,以及 docker-cli

      sudo yum install docker-ce docker-ce-cli containerd.io
      
  • 启动 docker

    sudo systemctl start docker
    
  • 设置 docker 开机自启

    sudo systemctl enable docker
    
  • 测试 docker 常用命令,注意切换到 root 用户下

    https://docs.docker.com/engine/reference/commandline/docker/

  • 配置 docker 镜像加速

    • 阿里云,容器镜像服务

      针对 Docker 客户端版本大于 1.10.0 的用户

      可以通过修改 daemon 配置文件/etc/docker/daemon.json 来使用加速器

      sudo mkdir -p /etc/docker
      
      sudo tee /etc/docker/daemon.json <<-'EOF'
      {
      "registry-mirrors": ["https://82m9ar63.mirror.aliyuncs.com"]
      }
      EOF
      sudo systemctl daemon-reload
      sudo systemctl restart docker
      

  • 查询镜像

    docker images
    

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-QH8n3pmn-1632152535262)(C:/Users/PePe/AppData/Roaming/Typora/typora-user-images/image-20210920162534600.png)]

  • 查询容器

    docker ps
    

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-RcKvZj0b-1632152535264)(C:/Users/PePe/AppData/Roaming/Typora/typora-user-images/image-20210920162522823.png)]


3、docker 安装 mysql

  • 下载镜像文件

    docker pull mysql:5.7
    
  • 创建实例并启动

    docker run -p 3306:3306 --name mysql \
    -v /mydata/mysql/log:/var/log/mysql \
    -v /mydata/mysql/data:/var/lib/mysql \
    -v /mydata/mysql/conf:/etc/mysql \
    -e MYSQL_ROOT_PASSWORD=root \
    -d mysql:5.7
    
    • 参数说明

      -p 3306:3306:将容器的 3306 端口映射到主机的 3306 端口

      -v /mydata/mysql/conf:/etc/mysql:将配置文件夹挂载到主机

      -v /mydata/mysql/log:/var/log/mysql:将日志文件夹挂载到主机

      -v /mydata/mysql/data:/var/lib/mysql/:将配置文件夹挂载到主机

      -e MYSQL_ROOT_PASSWORD=root:初始化 root 用户的密码

    • MySQL 配置

      vi /mydata/mysql/conf/my.cnf
      
      [client]
      default-character-set=utf8
      
      [mysql]
      default-character-set=utf8
      
      [mysqld]
      init_connect='SET collation_connection = utf8_unicode_ci'
      init_connect='SET NAMES utf8'
      character-set-server=utf8
      collation-server=utf8_unicode_ci
      skip-character-set-client-handshake
      skip-name-resolve #跳过域名解析
      
    • 解决 MySQL 连接慢的问题

      #在配置文件中加入如下,并重启 mysql
      [mysqld]
      skip-name-resolve
      
      #skip-name-resolve:跳过域名解析
      
    • 重启容器

      docker ps -a #查看所有的containners
      

      [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-37m0gzym-1632152535265)(C:/Users/PePe/AppData/Roaming/Typora/typora-user-images/image-20210920160550686.png)]

      docker restart 容器id  #重启容器
      
  • 通过容器的 mysql 命令行工具连接

docker exec -it mysql mysql -uroot -proot
  • 通过sqlyog连接

在这里插入图片描述

  • 设置 root 远程访问
grant all privileges on *.* to 'root'@'%' identified by 'root' with grant option;

flush privileges;
  • 进入容器文件系统
docker exec -it mysql /bin/bash
  • 退出容器

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-aiHwwQkq-1632152535269)(C:/Users/PePe/AppData/Roaming/Typora/typora-user-images/image-20210920162334039.png)]

exit

4、docker 安装 redis

  • 下载镜像文件
docker pull redis
  • 创建实例并启动
mkdir -p /mydata/redis/conf

touch /mydata/redis/conf/redis.conf

#启动容器并内外映射
docker run -p 6379:6379 --name redis -v /mydata/redis/data:/data \
-v /mydata/redis/conf/redis.conf:/etc/redis/redis.conf \
-d redis redis-server /etc/redis/redis.conf

redis 自描述文件:https://raw.githubusercontent.com/antirez/redis/4.0/redis.conf

  • 使用 redis 镜像执行 redis-cli 命令连接
docker exec -it redis redis-cli

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-BHqaKHBL-1632152535270)(C:/Users/PePe/AppData/Roaming/Typora/typora-user-images/image-20210920162816281.png)]

  • 设置虚拟机重启后,会自动开启以上服务
sudo docker update mysql(服务名) --restart=always

---

## 5、开发环境统一

### ①Maven

apache-maven-3.3.9\conf\settings

​```xml
<!--配置阿里云镜像-->
<mirrors>
    <mirror>
        <id>nexus-aliyun</id>
        <mirrorOf>central</mirrorOf>
        <name>Nexus aliyun</name>
        <url>http://maven.aliyun.com/nexus/content/groups/public</url>
    </mirror>
</mirrors>

<!--配置 jdk1.8 编译项目-->
<profiles>
    <profile>
        <id>jdk-1.8</id>
        <activation>
            <activeByDefault>true</activeByDefault>
            <jdk>1.8</jdk>
        </activation>
        <properties>
            <maven.compiler.source>1.8</maven.compiler.source>
            <maven.compiler.target>1.8</maven.compiler.target>
            <maven.compiler.compilerVersion>1.8</maven.compiler.compilerVersion>
        </properties>
    </profile>
</profiles>

②Idea&VsCode

  • idea 安装 lombokmybatisx插件

  • Vscode 安装开发必备插件

    • Vetur —— 语法高亮、智能感知、Emmet 等包含格式化功能, Alt+Shift+F (格式化全文),Ctrl+K Ctrl+F(格式化选中代码,两个 Ctrl需要同时按着)
    • EsLint —— 语法纠错
    • Auto Close Tag —— 自动闭合 HTML/XML 标签
    • Auto Rename Tag —— 自动完成另一侧标签的同步修改
    • JavaScript(ES6) code snippets — — ES6 语 法 智 能 提 示 以 及 快 速 输 入 , 除 js 外 还 支持.ts,.jsx,.tsx,.html,.vue,省去了配置其支持各种包含 js 代码文件的时间
    • HTML CSS Support —— 让 html 标签上写 class 智能提示当前项目所支持的样式
    • HTML Snippets —— html 快速自动补全
    • Open in browser —— 浏览器快速打开
    • Live Server —— 以内嵌服务器方式打开
    • Chinese (Simplified) Language Pack for Visual Studio Code —— 中文语言包

③ 安装配置 git

  • 下载 git https://git-scm.com

  • 配置 git,进入 git bash

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-P1rNSHPa-1632152535271)(C:/Users/PePe/AppData/Roaming/Typora/typora-user-images/image-20210920165022510.png)]

    # 配置用户名
    git config --global user.name "username" #(名字)
    
    # 配置邮箱
    git config --global user.email "username@email.com" #(注册账号时用的邮箱)
    

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-u6kpUxaX-1632152535273)(C:/Users/PePe/AppData/Roaming/Typora/typora-user-images/image-20210920164948536.png)]

  • 配置 ssh 免密登录

    https://gitee.com/help/articles/4181#article-header0

    进入 git bash;使用:ssh-keygen -t rsa -C "xxxxx@xxxxx.com"命令。

    连续三次回车。
    一般用户目录(C:\Users\PePe\.ssh)下会有

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-fW0k0rqk-1632152535274)(C:/Users/PePe/AppData/Roaming/Typora/typora-user-images/image-20210920165247598.png)]

    或者 cat ~/.ssh/id_rsa.pub
    登录进入 gitee,在设置里面找到 SSH KEY 将.pub文件的内容粘贴进去

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-GWhA08vM-1632152535275)(C:/Users/PePe/AppData/Roaming/Typora/typora-user-images/image-20210920165505143.png)]

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-kpBjZ5Zn-1632152535276)(C:/Users/PePe/AppData/Roaming/Typora/typora-user-images/image-20210920165438437.png)]

    使用 ssh -T git@gitee.com 测试是否成功即可

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Doufobzm-1632152535277)(C:/Users/PePe/AppData/Roaming/Typora/typora-user-images/image-20210920165532034.png)]

    Git+码云教程 https://gitee.com/help/articles/4104



6、创建项目微服务

  • 从 gitee 初始化一个项目

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-4CrAMSfl-1632152535279)(C:/Users/PePe/AppData/Roaming/Typora/typora-user-images/image-20210920171649645.png)]

商品服务、仓储服务、订单服务、优惠券服务、用户服务

  • 共同

    • web、openfeign
    • 每一个服务,包名 com.achang.achangmall.xxx(product/order/ware/coupon/member)
    • 模块名:achangmall-coupon
  • 创建各个微服务项目

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-XAhO52Pf-1632152535280)(C:/Users/PePe/AppData/Roaming/Typora/typora-user-images/image-20210920175314205.png)]

    • 了解人人开源项目,快速搭建后台脚手架
    • 修改代码调整为我们的业务逻辑
    • 创建各个微服务以及数据库
  • 进行git提交忽略,在.gitignore文件中

**/mvnw.*
**/mvnw
**/mvnw.cmd
**/.mvn

**/target/
**/.gitignore
  • 进行提交上传操作后

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-jWo6EIfB-1632152535281)(C:/Users/PePe/AppData/Roaming/Typora/typora-user-images/image-20210920175529563.png)]


7、初始化数据库

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-N9tX4yu1-1632152535282)(C:/Users/PePe/AppData/Roaming/Typora/typora-user-images/image-20210920181629416.png)]

  • achangmall-oms.sql
drop table if exists oms_order;
drop table if exists oms_order_item;
drop table if exists oms_order_operate_history;
drop table if exists oms_order_return_apply;
drop table if exists oms_order_return_reason;
drop table if exists oms_order_setting;
drop table if exists oms_payment_info;
drop table if exists oms_refund_info;

/*==============================================================*/
/* Table: oms_order                                             */
/*==============================================================*/
create table oms_order
(
   id                   bigint not null auto_increment comment 'id',
   member_id            bigint comment 'member_id',
   order_sn             char(32) comment '订单号',
   coupon_id            bigint comment '使用的优惠券',
   create_time          datetime comment 'create_time',
   member_username      varchar(200) comment '用户名',
   total_amount         decimal(18,4) comment '订单总额',
   pay_amount           decimal(18,4) comment '应付总额',
   freight_amount       decimal(18,4) comment '运费金额',
   promotion_amount     decimal(18,4) comment '促销优化金额(促销价、满减、阶梯价)',
   integration_amount   decimal(18,4) comment '积分抵扣金额',
   coupon_amount        decimal(18,4) comment '优惠券抵扣金额',
   discount_amount      decimal(18,4) comment '后台调整订单使用的折扣金额',
   pay_type             tinyint comment '支付方式【1->支付宝;2->微信;3->银联; 4->货到付款;】',
   source_type          tinyint comment '订单来源[0->PC订单;1->app订单]',
   status               tinyint comment '订单状态【0->待付款;1->待发货;2->已发货;3->已完成;4->已关闭;5->无效订单】',
   delivery_company     varchar(64) comment '物流公司(配送方式)',
   delivery_sn          varchar(64) comment '物流单号',
   auto_confirm_day     int comment '自动确认时间(天)',
   integration          int comment '可以获得的积分',
   growth               int comment '可以获得的成长值',
   bill_type            tinyint comment '发票类型[0->不开发票;1->电子发票;2->纸质发票]',
   bill_header          varchar(255) comment '发票抬头',
   bill_content         varchar(255) comment '发票内容',
   bill_receiver_phone  varchar(32) comment '收票人电话',
   bill_receiver_email  varchar(64) comment '收票人邮箱',
   receiver_name        varchar(100) comment '收货人姓名',
   receiver_phone       varchar(32) comment '收货人电话',
   receiver_post_code   varchar(32) comment '收货人邮编',
   receiver_province    varchar(32) comment '省份/直辖市',
   receiver_city        varchar(32) comment '城市',
   receiver_region      varchar(32) comment '区',
   receiver_detail_address varchar(200) comment '详细地址',
   note                 varchar(500) comment '订单备注',
   confirm_status       tinyint comment '确认收货状态[0->未确认;1->已确认]',
   delete_status        tinyint comment '删除状态【0->未删除;1->已删除】',
   use_integration      int comment '下单时使用的积分',
   payment_time         datetime comment '支付时间',
   delivery_time        datetime comment '发货时间',
   receive_time         datetime comment '确认收货时间',
   comment_time         datetime comment '评价时间',
   modify_time          datetime comment '修改时间',
   primary key (id)
);

alter table oms_order comment '订单';

/*==============================================================*/
/* Table: oms_order_item                                        */
/*==============================================================*/
create table oms_order_item
(
   id                   bigint not null auto_increment comment 'id',
   order_id             bigint comment 'order_id',
   order_sn             char(32) comment 'order_sn',
   spu_id               bigint comment 'spu_id',
   spu_name             varchar(255) comment 'spu_name',
   spu_pic              varchar(500) comment 'spu_pic',
   spu_brand            varchar(200) comment '品牌',
   category_id          bigint comment '商品分类id',
   sku_id               bigint comment '商品sku编号',
   sku_name             varchar(255) comment '商品sku名字',
   sku_pic              varchar(500) comment '商品sku图片',
   sku_price            decimal(18,4) comment '商品sku价格',
   sku_quantity         int comment '商品购买的数量',
   sku_attrs_vals       varchar(500) comment '商品销售属性组合(JSON)',
   promotion_amount     decimal(18,4) comment '商品促销分解金额',
   coupon_amount        decimal(18,4) comment '优惠券优惠分解金额',
   integration_amount   decimal(18,4) comment '积分优惠分解金额',
   real_amount          decimal(18,4) comment '该商品经过优惠后的分解金额',
   gift_integration     int comment '赠送积分',
   gift_growth          int comment '赠送成长值',
   primary key (id)
);

alter table oms_order_item comment '订单项信息';

/*==============================================================*/
/* Table: oms_order_operate_history                             */
/*==============================================================*/
create table oms_order_operate_history
(
   id                   bigint not null auto_increment comment 'id',
   order_id             bigint comment '订单id',
   operate_man          varchar(100) comment '操作人[用户;系统;后台管理员]',
   create_time          datetime comment '操作时间',
   order_status         tinyint comment '订单状态【0->待付款;1->待发货;2->已发货;3->已完成;4->已关闭;5->无效订单】',
   note                 varchar(500) comment '备注',
   primary key (id)
);

alter table oms_order_operate_history comment '订单操作历史记录';

/*==============================================================*/
/* Table: oms_order_return_apply                                */
/*==============================================================*/
create table oms_order_return_apply
(
   id                   bigint not null auto_increment comment 'id',
   order_id             bigint comment 'order_id',
   sku_id               bigint comment '退货商品id',
   order_sn             char(32) comment '订单编号',
   create_time          datetime comment '申请时间',
   member_username      varchar(64) comment '会员用户名',
   return_amount        decimal(18,4) comment '退款金额',
   return_name          varchar(100) comment '退货人姓名',
   return_phone         varchar(20) comment '退货人电话',
   status               tinyint(1) comment '申请状态[0->待处理;1->退货中;2->已完成;3->已拒绝]',
   handle_time          datetime comment '处理时间',
   sku_img              varchar(500) comment '商品图片',
   sku_name             varchar(200) comment '商品名称',
   sku_brand            varchar(200) comment '商品品牌',
   sku_attrs_vals       varchar(500) comment '商品销售属性(JSON)',
   sku_count            int comment '退货数量',
   sku_price            decimal(18,4) comment '商品单价',
   sku_real_price       decimal(18,4) comment '商品实际支付单价',
   reason               varchar(200) comment '原因',
   description述         varchar(500) comment '描述',
   desc_pics            varchar(2000) comment '凭证图片,以逗号隔开',
   handle_note          varchar(500) comment '处理备注',
   handle_man           varchar(200) comment '处理人员',
   receive_man          varchar(100) comment '收货人',
   receive_time         datetime comment '收货时间',
   receive_note         varchar(500) comment '收货备注',
   receive_phone        varchar(20) comment '收货电话',
   company_address      varchar(500) comment '公司收货地址',
   primary key (id)
);

alter table oms_order_return_apply comment '订单退货申请';

/*==============================================================*/
/* Table: oms_order_return_reason                               */
/*==============================================================*/
create table oms_order_return_reason
(
   id                   bigint not null auto_increment comment 'id',
   name                 varchar(200) comment '退货原因名',
   sort                 int comment '排序',
   status               tinyint(1) comment '启用状态',
   create_time          datetime comment 'create_time',
   primary key (id)
);

alter table oms_order_return_reason comment '退货原因';

/*==============================================================*/
/* Table: oms_order_setting                                     */
/*==============================================================*/
create table oms_order_setting
(
   id                   bigint not null auto_increment comment 'id',
   flash_order_overtime int comment '秒杀订单超时关闭时间(分)',
   normal_order_overtime int comment '正常订单超时时间(分)',
   confirm_overtime     int comment '发货后自动确认收货时间(天)',
   finish_overtime      int comment '自动完成交易时间,不能申请退货(天)',
   comment_overtime     int comment '订单完成后自动好评时间(天)',
   member_level         tinyint(2) comment '会员等级【0-不限会员等级,全部通用;其他-对应的其他会员等级】',
   primary key (id)
);

alter table oms_order_setting comment '订单配置信息';

/*==============================================================*/
/* Table: oms_payment_info                                      */
/*==============================================================*/
create table oms_payment_info
(
   id                   bigint not null auto_increment comment 'id',
   order_sn             char(32) comment '订单号(对外业务号)',
   order_id             bigint comment '订单id',
   alipay_trade_no      varchar(50) comment '支付宝交易流水号',
   total_amount         decimal(18,4) comment '支付总金额',
   subject              varchar(200) comment '交易内容',
   payment_status       varchar(20) comment '支付状态',
   create_time          datetime comment '创建时间',
   confirm_time         datetime comment '确认时间',
   callback_content     varchar(4000) comment '回调内容',
   callback_time        datetime comment '回调时间',
   primary key (id)
);

alter table oms_payment_info comment '支付信息表';

/*==============================================================*/
/* Table: oms_refund_info                                       */
/*==============================================================*/
create table oms_refund_info
(
   id                   bigint not null auto_increment comment 'id',
   order_return_id      bigint comment '退款的订单',
   refund               decimal(18,4) comment '退款金额',
   refund_sn            varchar(64) comment '退款交易流水号',
   refund_status        tinyint(1) comment '退款状态',
   refund_channel       tinyint comment '退款渠道[1-支付宝,2-微信,3-银联,4-汇款]',
   refund_content       varchar(5000),
   primary key (id)
);

alter table oms_refund_info comment '退款信息';

  • achangmall-pms.sql
drop table if exists pms_attr;
drop table if exists pms_attr_attrgroup_relation;
drop table if exists pms_attr_group;
drop table if exists pms_brand;
drop table if exists pms_category;
drop table if exists pms_category_brand_relation;
drop table if exists pms_comment_replay;
drop table if exists pms_product_attr_value;
drop table if exists pms_sku_images;
drop table if exists pms_sku_info;
drop table if exists pms_sku_sale_attr_value;
drop table if exists pms_spu_comment;
drop table if exists pms_spu_images;
drop table if exists pms_spu_info;
drop table if exists pms_spu_info_desc;

/*==============================================================*/
/* Table: pms_attr                                              */
/*==============================================================*/
create table pms_attr
(
   attr_id              bigint not null auto_increment comment '属性id',
   attr_name            char(30) comment '属性名',
   search_type          tinyint comment '是否需要检索[0-不需要,1-需要]',
   icon                 varchar(255) comment '属性图标',
   value_select         char(255) comment '可选值列表[用逗号分隔]',
   attr_type            tinyint comment '属性类型[0-销售属性,1-基本属性,2-既是销售属性又是基本属性]',
   enable               bigint comment '启用状态[0 - 禁用,1 - 启用]',
   catelog_id           bigint comment '所属分类',
   show_desc            tinyint comment '快速展示【是否展示在介绍上;0-否 1-是】,在sku中仍然可以调整',
   primary key (attr_id)
);

alter table pms_attr comment '商品属性';

/*==============================================================*/
/* Table: pms_attr_attrgroup_relation                           */
/*==============================================================*/
create table pms_attr_attrgroup_relation
(
   id                   bigint not null auto_increment comment 'id',
   attr_id              bigint comment '属性id',
   attr_group_id        bigint comment '属性分组id',
   attr_sort            int comment '属性组内排序',
   primary key (id)
);

alter table pms_attr_attrgroup_relation comment '属性&属性分组关联';

/*==============================================================*/
/* Table: pms_attr_group                                        */
/*==============================================================*/
create table pms_attr_group
(
   attr_group_id        bigint not null auto_increment comment '分组id',
   attr_group_name      char(20) comment '组名',
   sort                 int comment '排序',
   descript             varchar(255) comment '描述',
   icon                 varchar(255) comment '组图标',
   catelog_id           bigint comment '所属分类id',
   primary key (attr_group_id)
);

alter table pms_attr_group comment '属性分组';

/*==============================================================*/
/* Table: pms_brand                                             */
/*==============================================================*/
create table pms_brand
(
   brand_id             bigint not null auto_increment comment '品牌id',
   name                 char(50) comment '品牌名',
   logo                 varchar(2000) comment '品牌logo地址',
   descript             longtext comment '介绍',
   show_status          tinyint comment '显示状态[0-不显示;1-显示]',
   first_letter         char(1) comment '检索首字母',
   sort                 int comment '排序',
   primary key (brand_id)
);

alter table pms_brand comment '品牌';

/*==============================================================*/
/* Table: pms_category                                          */
/*==============================================================*/
create table pms_category
(
   cat_id               bigint not null auto_increment comment '分类id',
   name                 char(50) comment '分类名称',
   parent_cid           bigint comment '父分类id',
   cat_level            int comment '层级',
   show_status          tinyint comment '是否显示[0-不显示,1显示]',
   sort                 int comment '排序',
   icon                 char(255) comment '图标地址',
   product_unit         char(50) comment '计量单位',
   product_count        int comment '商品数量',
   primary key (cat_id)
);

alter table pms_category comment '商品三级分类';

/*==============================================================*/
/* Table: pms_category_brand_relation                           */
/*==============================================================*/
create table pms_category_brand_relation
(
   id                   bigint not null auto_increment,
   brand_id             bigint comment '品牌id',
   catelog_id           bigint comment '分类id',
   brand_name           varchar(255),
   catelog_name         varchar(255),
   primary key (id)
);

alter table pms_category_brand_relation comment '品牌分类关联';

/*==============================================================*/
/* Table: pms_comment_replay                                    */
/*==============================================================*/
create table pms_comment_replay
(
   id                   bigint not null auto_increment comment 'id',
   comment_id           bigint comment '评论id',
   reply_id             bigint comment '回复id',
   primary key (id)
);

alter table pms_comment_replay comment '商品评价回复关系';

/*==============================================================*/
/* Table: pms_product_attr_value                                */
/*==============================================================*/
create table pms_product_attr_value
(
   id                   bigint not null auto_increment comment 'id',
   spu_id               bigint comment '商品id',
   attr_id              bigint comment '属性id',
   attr_name            varchar(200) comment '属性名',
   attr_value           varchar(200) comment '属性值',
   attr_sort            int comment '顺序',
   quick_show           tinyint comment '快速展示【是否展示在介绍上;0-否 1-是】',
   primary key (id)
);

alter table pms_product_attr_value comment 'spu属性值';

/*==============================================================*/
/* Table: pms_sku_images                                        */
/*==============================================================*/
create table pms_sku_images
(
   id                   bigint not null auto_increment comment 'id',
   sku_id               bigint comment 'sku_id',
   img_url              varchar(255) comment '图片地址',
   img_sort             int comment '排序',
   default_img          int comment '默认图[0 - 不是默认图,1 - 是默认图]',
   primary key (id)
);

alter table pms_sku_images comment 'sku图片';

/*==============================================================*/
/* Table: pms_sku_info                                          */
/*==============================================================*/
create table pms_sku_info
(
   sku_id               bigint not null auto_increment comment 'skuId',
   spu_id               bigint comment 'spuId',
   sku_name             varchar(255) comment 'sku名称',
   sku_desc             varchar(2000) comment 'sku介绍描述',
   catalog_id           bigint comment '所属分类id',
   brand_id             bigint comment '品牌id',
   sku_default_img      varchar(255) comment '默认图片',
   sku_title            varchar(255) comment '标题',
   sku_subtitle         varchar(2000) comment '副标题',
   price                decimal(18,4) comment '价格',
   sale_count           bigint comment '销量',
   primary key (sku_id)
);

alter table pms_sku_info comment 'sku信息';

/*==============================================================*/
/* Table: pms_sku_sale_attr_value                               */
/*==============================================================*/
create table pms_sku_sale_attr_value
(
   id                   bigint not null auto_increment comment 'id',
   sku_id               bigint comment 'sku_id',
   attr_id              bigint comment 'attr_id',
   attr_name            varchar(200) comment '销售属性名',
   attr_value           varchar(200) comment '销售属性值',
   attr_sort            int comment '顺序',
   primary key (id)
);

alter table pms_sku_sale_attr_value comment 'sku销售属性&值';

/*==============================================================*/
/* Table: pms_spu_comment                                       */
/*==============================================================*/
create table pms_spu_comment
(
   id                   bigint not null auto_increment comment 'id',
   sku_id               bigint comment 'sku_id',
   spu_id               bigint comment 'spu_id',
   spu_name             varchar(255) comment '商品名字',
   member_nick_name     varchar(255) comment '会员昵称',
   star                 tinyint(1) comment '星级',
   member_ip            varchar(64) comment '会员ip',
   create_time          datetime comment '创建时间',
   show_status          tinyint(1) comment '显示状态[0-不显示,1-显示]',
   spu_attributes       varchar(255) comment '购买时属性组合',
   likes_count          int comment '点赞数',
   reply_count          int comment '回复数',
   resources            varchar(1000) comment '评论图片/视频[json数据;[{type:文件类型,url:资源路径}]]',
   content              text comment '内容',
   member_icon          varchar(255) comment '用户头像',
   comment_type         tinyint comment '评论类型[0 - 对商品的直接评论,1 - 对评论的回复]',
   primary key (id)
);

alter table pms_spu_comment comment '商品评价';

/*==============================================================*/
/* Table: pms_spu_images                                        */
/*==============================================================*/
create table pms_spu_images
(
   id                   bigint not null auto_increment comment 'id',
   spu_id               bigint comment 'spu_id',
   img_name             varchar(200) comment '图片名',
   img_url              varchar(255) comment '图片地址',
   img_sort             int comment '顺序',
   default_img          tinyint comment '是否默认图',
   primary key (id)
);

alter table pms_spu_images comment 'spu图片';

/*==============================================================*/
/* Table: pms_spu_info                                          */
/*==============================================================*/
create table pms_spu_info
(
   id                   bigint not null auto_increment comment '商品id',
   spu_name             varchar(200) comment '商品名称',
   spu_description      varchar(1000) comment '商品描述',
   catalog_id           bigint comment '所属分类id',
   brand_id             bigint comment '品牌id',
   weight               decimal(18,4),
   publish_status       tinyint comment '上架状态[0 - 下架,1 - 上架]',
   create_time          datetime,
   update_time          datetime,
   primary key (id)
);

alter table pms_spu_info comment 'spu信息';

/*==============================================================*/
/* Table: pms_spu_info_desc                                     */
/*==============================================================*/
create table pms_spu_info_desc
(
   spu_id               bigint not null comment '商品id',
   decript              longtext comment '商品介绍',
   primary key (spu_id)
);

alter table pms_spu_info_desc comment 'spu信息介绍';



  • achangmall_sms.sql
drop table if exists sms_coupon;
drop table if exists sms_coupon_history;
drop table if exists sms_coupon_spu_category_relation;
drop table if exists sms_coupon_spu_relation;
drop table if exists sms_home_adv;
drop table if exists sms_home_subject;
drop table if exists sms_home_subject_spu;
drop table if exists sms_member_price;
drop table if exists sms_seckill_promotion;
drop table if exists sms_seckill_session;
drop table if exists sms_seckill_sku_notice;
drop table if exists sms_seckill_sku_relation;
drop table if exists sms_sku_full_reduction;
drop table if exists sms_sku_ladder;
drop table if exists sms_spu_bounds;

/*==============================================================*/
/* Table: sms_coupon                                            */
/*==============================================================*/
create table sms_coupon
(
    id                   bigint not null auto_increment comment 'id',
    coupon_type          tinyint(1) comment '优惠卷类型[0->全场赠券;1->会员赠券;2->购物赠券;3->注册赠券]',
    coupon_img           varchar(2000) comment '优惠券图片',
    coupon_name          varchar(100) comment '优惠卷名字',
    num                  int comment '数量',
    amount               decimal(18,4) comment '金额',
    per_limit            int comment '每人限领张数',
    min_point            decimal(18,4) comment '使用门槛',
    start_time           datetime comment '开始时间',
    end_time             datetime comment '结束时间',
    use_type             tinyint(1) comment '使用类型[0->全场通用;1->指定分类;2->指定商品]',
    note                 varchar(200) comment '备注',
    publish_count        int(11) comment '发行数量',
    use_count            int(11) comment '已使用数量',
    receive_count        int(11) comment '领取数量',
    enable_start_time    datetime comment '可以领取的开始日期',
    enable_end_time      datetime comment '可以领取的结束日期',
    code                 varchar(64) comment '优惠码',
    member_level         tinyint(1) comment '可以领取的会员等级[0->不限等级,其他-对应等级]',
    publish              tinyint(1) comment '发布状态[0-未发布,1-已发布]',
    primary key (id)
);

alter table sms_coupon comment '优惠券信息';

/*==============================================================*/
/* Table: sms_coupon_history                                    */
/*==============================================================*/
create table sms_coupon_history
(
    id                   bigint not null auto_increment comment 'id',
    coupon_id            bigint comment '优惠券id',
    member_id            bigint comment '会员id',
    member_nick_name     varchar(64) comment '会员名字',
    get_type             tinyint(1) comment '获取方式[0->后台赠送;1->主动领取]',
    create_time          datetime comment '创建时间',
    use_type             tinyint(1) comment '使用状态[0->未使用;1->已使用;2->已过期]',
    use_time             datetime comment '使用时间',
    order_id             bigint comment '订单id',
    order_sn             bigint comment '订单号',
    primary key (id)
);

alter table sms_coupon_history comment '优惠券领取历史记录';

/*==============================================================*/
/* Table: sms_coupon_spu_category_relation                      */
/*==============================================================*/
create table sms_coupon_spu_category_relation
(
    id                   bigint not null auto_increment comment 'id',
    coupon_id            bigint comment '优惠券id',
    category_id          bigint comment '产品分类id',
    category_name        varchar(64) comment '产品分类名称',
    primary key (id)
);

alter table sms_coupon_spu_category_relation comment '优惠券分类关联';

/*==============================================================*/
/* Table: sms_coupon_spu_relation                               */
/*==============================================================*/
create table sms_coupon_spu_relation
(
    id                   bigint not null auto_increment comment 'id',
    coupon_id            bigint comment '优惠券id',
    spu_id               bigint comment 'spu_id',
    spu_name             varchar(255) comment 'spu_name',
    primary key (id)
);

alter table sms_coupon_spu_relation comment '优惠券与产品关联';

/*==============================================================*/
/* Table: sms_home_adv                                          */
/*==============================================================*/
create table sms_home_adv
(
    id                   bigint not null auto_increment comment 'id',
    name                 varchar(100) comment '名字',
    pic                  varchar(500) comment '图片地址',
    start_time           datetime comment '开始时间',
    end_time             datetime comment '结束时间',
    status               tinyint(1) comment '状态',
    click_count          int comment '点击数',
    url                  varchar(500) comment '广告详情连接地址',
    note                 varchar(500) comment '备注',
    sort                 int comment '排序',
    publisher_id         bigint comment '发布者',
    auth_id              bigint comment '审核者',
    primary key (id)
);

alter table sms_home_adv comment '首页轮播广告';

/*==============================================================*/
/* Table: sms_home_subject                                      */
/*==============================================================*/
create table sms_home_subject
(
    id                   bigint not null auto_increment comment 'id',
    name                 varchar(200) comment '专题名字',
    title                varchar(255) comment '专题标题',
    sub_title            varchar(255) comment '专题副标题',
    status               tinyint(1) comment '显示状态',
    url                  varchar(500) comment '详情连接',
    sort                 int comment '排序',
    img                  varchar(500) comment '专题图片地址',
    primary key (id)
);

alter table sms_home_subject comment '首页专题表【jd首页下面很多专题,每个专题链接新的页面,展示专题商品信息】';

/*==============================================================*/
/* Table: sms_home_subject_spu                                  */
/*==============================================================*/
create table sms_home_subject_spu
(
    id                   bigint not null auto_increment comment 'id',
    name                 varchar(200) comment '专题名字',
    subject_id           bigint comment '专题id',
    spu_id               bigint comment 'spu_id',
    sort                 int comment '排序',
    primary key (id)
);

alter table sms_home_subject_spu comment '专题商品';

/*==============================================================*/
/* Table: sms_member_price                                      */
/*==============================================================*/
create table sms_member_price
(
    id                   bigint not null auto_increment comment 'id',
    sku_id               bigint comment 'sku_id',
    member_level_id      bigint comment '会员等级id',
    member_level_name    varchar(100) comment '会员等级名',
    member_price         decimal(18,4) comment '会员对应价格',
    add_other            tinyint(1) comment '可否叠加其他优惠[0-不可叠加优惠,1-可叠加]',
    primary key (id)
);

alter table sms_member_price comment '商品会员价格';

/*==============================================================*/
/* Table: sms_seckill_promotion                                 */
/*==============================================================*/
create table sms_seckill_promotion
(
    id                   bigint not null auto_increment comment 'id',
    title                varchar(255) comment '活动标题',
    start_time           datetime comment '开始日期',
    end_time             datetime comment '结束日期',
    status               tinyint comment '上下线状态',
    create_time          datetime comment '创建时间',
    user_id              bigint comment '创建人',
    primary key (id)
);

alter table sms_seckill_promotion comment '秒杀活动';

/*==============================================================*/
/* Table: sms_seckill_session                                   */
/*==============================================================*/
create table sms_seckill_session
(
    id                   bigint not null auto_increment comment 'id',
    name                 varchar(200) comment '场次名称',
    start_time           datetime comment '每日开始时间',
    end_time             datetime comment '每日结束时间',
    status               tinyint(1) comment '启用状态',
    create_time          datetime comment '创建时间',
    primary key (id)
);

alter table sms_seckill_session comment '秒杀活动场次';

/*==============================================================*/
/* Table: sms_seckill_sku_notice                                */
/*==============================================================*/
create table sms_seckill_sku_notice
(
    id                   bigint not null auto_increment comment 'id',
    member_id            bigint comment 'member_id',
    sku_id               bigint comment 'sku_id',
    session_id           bigint comment '活动场次id',
    subcribe_time        datetime comment '订阅时间',
    send_time            datetime comment '发送时间',
    notice_type          tinyint(1) comment '通知方式[0-短信,1-邮件]',
    primary key (id)
);

alter table sms_seckill_sku_notice comment '秒杀商品通知订阅';

/*==============================================================*/
/* Table: sms_seckill_sku_relation                              */
/*==============================================================*/
create table sms_seckill_sku_relation
(
    id                   bigint not null auto_increment comment 'id',
    promotion_id         bigint comment '活动id',
    promotion_session_id bigint comment '活动场次id',
    sku_id               bigint comment '商品id',
    seckill_price        decimal comment '秒杀价格',
    seckill_count        decimal comment '秒杀总量',
    seckill_limit        decimal comment '每人限购数量',
    seckill_sort         int comment '排序',
    primary key (id)
);

alter table sms_seckill_sku_relation comment '秒杀活动商品关联';

/*==============================================================*/
/* Table: sms_sku_full_reduction                                */
/*==============================================================*/
create table sms_sku_full_reduction
(
    id                   bigint not null auto_increment comment 'id',
    sku_id               bigint comment 'spu_id',
    full_price           decimal(18,4) comment '满多少',
    reduce_price         decimal(18,4) comment '减多少',
    add_other            tinyint(1) comment '是否参与其他优惠',
    primary key (id)
);

alter table sms_sku_full_reduction comment '商品满减信息';

/*==============================================================*/
/* Table: sms_sku_ladder                                        */
/*==============================================================*/
create table sms_sku_ladder
(
    id                   bigint not null auto_increment comment 'id',
    sku_id               bigint comment 'spu_id',
    full_count           int comment '满几件',
    discount             decimal(4,2) comment '打几折',
    price                decimal(18,4) comment '折后价',
    add_other            tinyint(1) comment '是否叠加其他优惠[0-不可叠加,1-可叠加]',
    primary key (id)
);

alter table sms_sku_ladder comment '商品阶梯价格';

/*==============================================================*/
/* Table: sms_spu_bounds                                        */
/*==============================================================*/
create table sms_spu_bounds
(
    id                   bigint not null auto_increment comment 'id',
    spu_id               bigint,
    grow_bounds          decimal(18,4) comment '成长积分',
    buy_bounds           decimal(18,4) comment '购物积分',
    work                 tinyint(1) comment '优惠生效情况[1111(四个状态位,从右到左);0 - 无优惠,成长积分是否赠送;1 - 无优惠,购物积分是否赠送;2 - 有优惠,成长积分是否赠送;3 - 有优惠,购物积分是否赠送【状态位0:不赠送,1:赠送】]',
    primary key (id)
);

alter table sms_spu_bounds comment '商品spu积分设置';
  • achangmall_ums.sql
drop table if exists ums_growth_change_history;
drop table if exists ums_integration_change_history;
drop table if exists ums_member;
drop table if exists ums_member_collect_spu;
drop table if exists ums_member_collect_subject;
drop table if exists ums_member_level;
drop table if exists ums_member_login_log;
drop table if exists ums_member_receive_address;
drop table if exists ums_member_statistics_info;

/*==============================================================*/
/* Table: ums_growth_change_history                             */
/*==============================================================*/
create table ums_growth_change_history
(
    id                   bigint not null auto_increment comment 'id',
    member_id            bigint comment 'member_id',
    create_time          datetime comment 'create_time',
    change_count         int comment '改变的值(正负计数)',
    note                 varchar(0) comment '备注',
    source_type          tinyint comment '积分来源[0-购物,1-管理员修改]',
    primary key (id)
);

alter table ums_growth_change_history comment '成长值变化历史记录';

/*==============================================================*/
/* Table: ums_integration_change_history                        */
/*==============================================================*/
create table ums_integration_change_history
(
    id                   bigint not null auto_increment comment 'id',
    member_id            bigint comment 'member_id',
    create_time          datetime comment 'create_time',
    change_count         int comment '变化的值',
    note                 varchar(255) comment '备注',
    source_tyoe          tinyint comment '来源[0->购物;1->管理员修改;2->活动]',
    primary key (id)
);

alter table ums_integration_change_history comment '积分变化历史记录';

/*==============================================================*/
/* Table: ums_member                                            */
/*==============================================================*/
create table ums_member
(
    id                   bigint not null auto_increment comment 'id',
    level_id             bigint comment '会员等级id',
    username             char(64) comment '用户名',
    password             varchar(64) comment '密码',
    nickname             varchar(64) comment '昵称',
    mobile               varchar(20) comment '手机号码',
    email                varchar(64) comment '邮箱',
    header               varchar(500) comment '头像',
    gender               tinyint comment '性别',
    birth                date comment '生日',
    city                 varchar(500) comment '所在城市',
    job                  varchar(255) comment '职业',
    sign                 varchar(255) comment '个性签名',
    source_type          tinyint comment '用户来源',
    integration          int comment '积分',
    growth               int comment '成长值',
    status               tinyint comment '启用状态',
    create_time          datetime comment '注册时间',
    primary key (id)
);

alter table ums_member comment '会员';

/*==============================================================*/
/* Table: ums_member_collect_spu                                */
/*==============================================================*/
create table ums_member_collect_spu
(
    id                   bigint not null comment 'id',
    member_id            bigint comment '会员id',
    spu_id               bigint comment 'spu_id',
    spu_name             varchar(500) comment 'spu_name',
    spu_img              varchar(500) comment 'spu_img',
    create_time          datetime comment 'create_time',
    primary key (id)
);

alter table ums_member_collect_spu comment '会员收藏的商品';

/*==============================================================*/
/* Table: ums_member_collect_subject                            */
/*==============================================================*/
create table ums_member_collect_subject
(
    id                   bigint not null auto_increment comment 'id',
    subject_id           bigint comment 'subject_id',
    subject_name         varchar(255) comment 'subject_name',
    subject_img          varchar(500) comment 'subject_img',
    subject_urll         varchar(500) comment '活动url',
    primary key (id)
);

alter table ums_member_collect_subject comment '会员收藏的专题活动';

/*==============================================================*/
/* Table: ums_member_level                                      */
/*==============================================================*/
create table ums_member_level
(
    id                   bigint not null auto_increment comment 'id',
    name                 varchar(100) comment '等级名称',
    growth_point         int comment '等级需要的成长值',
    default_status       tinyint comment '是否为默认等级[0->不是;1->是]',
    free_freight_point   decimal(18,4) comment '免运费标准',
    comment_growth_point int comment '每次评价获取的成长值',
    priviledge_free_freight tinyint comment '是否有免邮特权',
    priviledge_member_price tinyint comment '是否有会员价格特权',
    priviledge_birthday  tinyint comment '是否有生日特权',
    note                 varchar(255) comment '备注',
    primary key (id)
);

alter table ums_member_level comment '会员等级';

/*==============================================================*/
/* Table: ums_member_login_log                                  */
/*==============================================================*/
create table ums_member_login_log
(
    id                   bigint not null auto_increment comment 'id',
    member_id            bigint comment 'member_id',
    create_time          datetime comment '创建时间',
    ip                   varchar(64) comment 'ip',
    city                 varchar(64) comment 'city',
    login_type           tinyint(1) comment '登录类型[1-web,2-app]',
    primary key (id)
);

alter table ums_member_login_log comment '会员登录记录';

/*==============================================================*/
/* Table: ums_member_receive_address                            */
/*==============================================================*/
create table ums_member_receive_address
(
    id                   bigint not null auto_increment comment 'id',
    member_id            bigint comment 'member_id',
    name                 varchar(255) comment '收货人姓名',
    phone                varchar(64) comment '电话',
    post_code            varchar(64) comment '邮政编码',
    province             varchar(100) comment '省份/直辖市',
    city                 varchar(100) comment '城市',
    region               varchar(100) comment '区',
    detail_address       varchar(255) comment '详细地址(街道)',
    areacode             varchar(15) comment '省市区代码',
    default_status       tinyint(1) comment '是否默认',
    primary key (id)
);

alter table ums_member_receive_address comment '会员收货地址';

/*==============================================================*/
/* Table: ums_member_statistics_info                            */
/*==============================================================*/
create table ums_member_statistics_info
(
    id                   bigint not null auto_increment comment 'id',
    member_id            bigint comment '会员id',
    consume_amount       decimal(18,4) comment '累计消费金额',
    coupon_amount        decimal(18,4) comment '累计优惠金额',
    order_count          int comment '订单数量',
    coupon_count         int comment '优惠券数量',
    comment_count        int comment '评价数',
    return_order_count   int comment '退货数量',
    login_count          int comment '登录次数',
    attend_count         int comment '关注数量',
    fans_count           int comment '粉丝数量',
    collect_product_count int comment '收藏的商品数量',
    collect_subject_count int comment '收藏的专题活动数量',
    collect_comment_count int comment '收藏的评论数量',
    invite_friend_count  int comment '邀请的朋友数量',
    primary key (id)
);

alter table ums_member_statistics_info comment '会员统计信息';
  • achangmall_wms.sql
DROP TABLE IF EXISTS `undo_log`;

CREATE TABLE `undo_log` (
    `id` bigint(20) NOT NULL AUTO_INCREMENT,
    `branch_id` bigint(20) NOT NULL,
    `xid` varchar(100) NOT NULL,
    `context` varchar(128) NOT NULL,
    `rollback_info` longblob NOT NULL,
    `log_status` int(11) NOT NULL,
    `log_created` datetime NOT NULL,
    `log_modified` datetime NOT NULL,
    `ext` varchar(100) DEFAULT NULL,
    PRIMARY KEY (`id`),
    UNIQUE KEY `ux_undo_log` (`xid`,`branch_id`) USING BTREE
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

/*Data for the table `undo_log` */

/*Table structure for table `wms_purchase` */

DROP TABLE IF EXISTS `wms_purchase`;

CREATE TABLE `wms_purchase` (
    `id` bigint(20) NOT NULL AUTO_INCREMENT,
    `assignee_id` bigint(20) DEFAULT NULL,
    `assignee_name` varchar(255) DEFAULT NULL,
    `phone` char(13) DEFAULT NULL,
    `priority` int(4) DEFAULT NULL,
    `status` int(4) DEFAULT NULL,
    `ware_id` bigint(20) DEFAULT NULL,
    `amount` decimal(18,4) DEFAULT NULL,
    `create_time` datetime DEFAULT NULL,
    `update_time` datetime DEFAULT NULL,
    PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='采购信息';

/*Data for the table `wms_purchase` */

/*Table structure for table `wms_purchase_detail` */

DROP TABLE IF EXISTS `wms_purchase_detail`;

CREATE TABLE `wms_purchase_detail` (
    `id` bigint(20) NOT NULL AUTO_INCREMENT,
    `purchase_id` bigint(20) DEFAULT NULL COMMENT '采购单id',
    `sku_id` bigint(20) DEFAULT NULL COMMENT '采购商品id',
    `sku_num` int(11) DEFAULT NULL COMMENT '采购数量',
    `sku_price` decimal(18,4) DEFAULT NULL COMMENT '采购金额',
    `ware_id` bigint(20) DEFAULT NULL COMMENT '仓库id',
    `status` int(11) DEFAULT NULL COMMENT '状态[0新建,1已分配,2正在采购,3已完成,4采购失败]',
    PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

/*Data for the table `wms_purchase_detail` */

/*Table structure for table `wms_ware_info` */

DROP TABLE IF EXISTS `wms_ware_info`;

CREATE TABLE `wms_ware_info` (
    `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',
    `name` varchar(255) DEFAULT NULL COMMENT '仓库名',
    `address` varchar(255) DEFAULT NULL COMMENT '仓库地址',
    `areacode` varchar(20) DEFAULT NULL COMMENT '区域编码',
    PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='仓库信息';

/*Data for the table `wms_ware_info` */

/*Table structure for table `wms_ware_order_task` */

DROP TABLE IF EXISTS `wms_ware_order_task`;

CREATE TABLE `wms_ware_order_task` (
    `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',
    `order_id` bigint(20) DEFAULT NULL COMMENT 'order_id',
    `order_sn` varchar(255) DEFAULT NULL COMMENT 'order_sn',
    `consignee` varchar(100) DEFAULT NULL COMMENT '收货人',
    `consignee_tel` char(15) DEFAULT NULL COMMENT '收货人电话',
    `delivery_address` varchar(500) DEFAULT NULL COMMENT '配送地址',
    `order_comment` varchar(200) DEFAULT NULL COMMENT '订单备注',
    `payment_way` tinyint(1) DEFAULT NULL COMMENT '付款方式【 1:在线付款 2:货到付款】',
    `task_status` tinyint(2) DEFAULT NULL COMMENT '任务状态',
    `order_body` varchar(255) DEFAULT NULL COMMENT '订单描述',
    `tracking_no` char(30) DEFAULT NULL COMMENT '物流单号',
    `create_time` datetime DEFAULT NULL COMMENT 'create_time',
    `ware_id` bigint(20) DEFAULT NULL COMMENT '仓库id',
    `task_comment` varchar(500) DEFAULT NULL COMMENT '工作单备注',
    PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='库存工作单';

/*Data for the table `wms_ware_order_task` */

/*Table structure for table `wms_ware_order_task_detail` */

DROP TABLE IF EXISTS `wms_ware_order_task_detail`;

CREATE TABLE `wms_ware_order_task_detail` (
    `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',
    `sku_id` bigint(20) DEFAULT NULL COMMENT 'sku_id',
    `sku_name` varchar(255) DEFAULT NULL COMMENT 'sku_name',
    `sku_num` int(11) DEFAULT NULL COMMENT '购买个数',
    `task_id` bigint(20) DEFAULT NULL COMMENT '工作单id',
    `ware_id` bigint(20) DEFAULT NULL COMMENT '仓库id',
    `lock_status` int(1) DEFAULT NULL COMMENT '1-已锁定  2-已解锁  3-扣减',
    PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='库存工作单';

/*Data for the table `wms_ware_order_task_detail` */

/*Table structure for table `wms_ware_sku` */

DROP TABLE IF EXISTS `wms_ware_sku`;

CREATE TABLE `wms_ware_sku` (
    `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',
    `sku_id` bigint(20) DEFAULT NULL COMMENT 'sku_id',
    `ware_id` bigint(20) DEFAULT NULL COMMENT '仓库id',
    `stock` int(11) DEFAULT NULL COMMENT '库存数',
    `sku_name` varchar(200) DEFAULT NULL COMMENT 'sku_name',
    `stock_locked` int(11) DEFAULT '0' COMMENT '锁定库存',
    PRIMARY KEY (`id`),
    KEY `sku_id` (`sku_id`) USING BTREE,
    KEY `ware_id` (`ware_id`) USING BTREE
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='商品库存';

/*Data for the table `wms_ware_sku` */

/*!40101 SET SQL_MODE=@OLD_SQL_MODE */;
/*!40014 SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS */;
/*!40014 SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS */;
/*!40111 SET SQL_NOTES=@OLD_SQL_NOTES */;

8、快速搭建后台管理系统

https://gitee.com/renrenio

在码云上搜索人人开源,我们使用renren-fastrenren-fast-vue项目

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-GEzldbpI-1632152535284)(C:/Users/PePe/AppData/Roaming/Typora/typora-user-images/image-20210920182702068.png)]

git clone https://gitee.com/renrenio/renren-fast.git
git clone https://gitee.com/renrenio/renren-fast-vue.git

下载到了桌面,我们把renren-fast移动到我们的项目文件夹(删掉.git文件),而renren-fast-vue是用VSCode打开的(后面再弄)

在idea(root)项目里的pom.xml添加一个
<modules>
    <module>gulimall-coupon</module>
    <module>gulimall-member</module>
    <module>gulimall-order</module>
    <module>gulimall-product</module>
    <module>gulimall-ware</module>

    <module>renren-fast</module> #添加人人后台项目
</modules>

然后打开renren-fast/db/mysql.sql,复制全部,在sqlyog中创建库achangmall_admin,粘贴以下的内容执行。

然后修改项目里renren-fast中的application.yml,修改application-dev.yml中的数库库的

url: jdbc:mysql://192.168.109.101:3306/achangmall_admin?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai
username: root
password: root

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-drUqzBW3-1632152535285)(C:/Users/PePe/AppData/Roaming/Typora/typora-user-images/image-20210920190623780.png)]

启动“achangmall_admin”,然后访问“http://localhost:8080/renren-fast/

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Ws5F4zWF-1632152535286)(C:/Users/PePe/AppData/Roaming/Typora/typora-user-images/image-20210920190632212.png)]


安装node.js,并且安装仓库

npm config set registry http://registry.npm.taobao.org/

npm install #在下载的前端项目根目录下
npm run dev #启动前端项目

如果上面不行可以采用

npm install -g cnpm --registry=https://registry.npm.taobao.org
cnpm install node-sass --save
npm run dev #启动前端项目

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-OTAAww7V-1632152535287)(C:/Users/PePe/AppData/Roaming/Typora/typora-user-images/image-20210920212607450.png)]

浏览器输入localhost:8001 就可以看到内容了,登录账号admin 密码admin

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-PgvHUi22-1632152535289)(C:/Users/PePe/AppData/Roaming/Typora/typora-user-images/image-20210920212658119.png)]


9、代码生成器

git clone https://gitee.com/renrenio/renren-generator.git

然后将该项目放置到“achangmall”的跟路径下,然后添加该Module,并且提交到github上

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ZthivmW3-1632152535290)(C:/Users/PePe/AppData/Roaming/Typora/typora-user-images/image-20210920213304230.png)]

  • 修改配置

renren-generator/src/main/resources/generator.properties

mainPath=com.achang
#包名
package=com.achang.achangmall
moduleName=product
#作者
author=achang
#Email
email=995931576@qq.com
#表前缀(类名不会包含表前缀)
tablePrefix=pms_

application.yml

# mysql
spring:
  datasource:
    type: com.alibaba.druid.pool.DruidDataSource
    #MySQL配置
    driverClassName: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://192.168.109.101:3306/achangmall-pms?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=Asia/Shanghai
    username: root
    password: root
  • 运行“renren-generator”

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-AKq04Cri-1632152535290)(C:/Users/PePe/AppData/Roaming/Typora/typora-user-images/image-20210920213557924.png)]

访问:http://localhost:80/

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-l2rxobSn-1632152535292)(C:/Users/PePe/AppData/Roaming/Typora/typora-user-images/image-20210920213902441.png)]

选择所有的表,然后点击“生成代码”,将下载的“renren.zip”,解压后取出main文件夹,放置到“achangmall-product”项目的main目录中。

下面的几个module,也采用同样的方式来操作。


但是针对于“undo_log”,存在一个问题

在项目上右击(在项目上右击很重要)new modules— maven—然后在name上输入achangmall-common

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-qttT0j9B-1632152535293)(C:/Users/PePe/AppData/Roaming/Typora/typora-user-images/image-20210920222456578.png)]

在pom.xml中也自动添加了<module>gulimall-common</module>

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-rmKVHZsB-1632152535294)(C:/Users/PePe/AppData/Roaming/Typora/typora-user-images/image-20210920222520705.png)]

在common项目的pom.xml(我们把每个微服务里公共的类和依赖放到common里。)中添加

<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-boot-starter</artifactId>
    <version>3.4.1</version>
</dependency>
<dependency>
    <groupId>org.projectlombok</groupId>
    <artifactId>lombok</artifactId>
    <version>1.18.20</version>
</dependency>
<dependency>
    <groupId>org.apache.httpcomponents</groupId>
    <artifactId>httpcore</artifactId>
    <version>4.4.14</version>
</dependency>
<dependency>
    <groupId>commons-lang</groupId>
    <artifactId>commons-lang</artifactId>
    <version>2.6</version>
</dependency>

然后在product项目中的pom.xml中加入下面内容

<dependency>
    <groupId>com.achang.achangmall</groupId>
    <artifactId>achangmall-common</artifactId>
    <version>0.0.1-SNAPSHOT</version>
</dependency>

renren-fast----utils包下的Query和PageUtils、R、Constant复制到common项目的java/com.achang.common.utils下

把@RequiresPermissions这些注解掉,因为是shiro的

复制renren-fast中的xss包粘贴到common的java/com.achang.common目录下。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-kxe9XKfp-1632152535295)(C:/Users/PePe/AppData/Roaming/Typora/typora-user-images/image-20210920222718454.png)]

还复制了exception文件夹,对应的位置关系自己观察一下就行

注释掉product项目下类中的//import org.apache.shiro.authz.annotation.RequiresPermissions;,他是shiro的东西

注释renren-generator\src\main\resources\template/Controller中所有的

# @RequiresPermissions。
# import org.apache.shiro.authz.annotation.RequiresPermissions;

总之什么报错就去renren-fast里面找。


  • 测试与整合商品服务里的mybatisplus

在common的pom.xml中导入

<!-- 数据库驱动 https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>8.0.17</version>
</dependency>
<!--tomcat里一般都带-->
<dependency>
    <groupId>javax.servlet</groupId>
    <artifactId>servlet-api</artifactId>
    <version>2.5</version>
    <scope>provided</scope>  # Tomcat有带,所以provided
</dependency>

删掉common里xss/xssfiler和XssHttpServletRequestWrapper

  • 在product项目的resources目录下新建application.yml
spring:
  datasource:
    password: root
    username: root
    url: jdbc:mysql://192.168.109.101:3306/achangmall-pms?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai
    driver-class-name: com.mysql.jdbc.Driver


# MapperScan
# sql映射文件位置
mybatis-plus:
  mapper-locations: classpath:/mapper/**/*.xml
  global-config:
    db-config:
      id-type: auto

然后在主启动类上加上注解@MapperScan()

@MapperScan("com.achang.achangmall.product.dao")
@SpringBootApplication
public class gulimallProductApplication {
    public static void main(String[] args) {
        SpringApplication.run(gulimallProductApplication.class, args);
    }

}

然后去测试,先通过下面方法给数据库添加内容

@SpringBootTest
class AchangmallProductApplicationTests {

    @Autowired
    private BrandService brandService;

    @Test
    void contextLoads() {
        BrandEntity brandEntity = new BrandEntity();
        brandEntity.setName("苹果");
        brandService.save(brandEntity);
    }

}

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-vYp56M8c-1632152535296)(C:/Users/PePe/AppData/Roaming/Typora/typora-user-images/image-20210920225552684.png)]

  • coupon

重新打开generator逆向工程,修改generator.properties

# 主目录 
mainPath=com.achang
#包名
package=com.achang.achangmall
moduleName=coupon
#作者
author=achang
#Email
email=995931576@qq.com
#表前缀(类名不会包含表前缀)
tablePrefix=sms_

修改yml数据库信息
# mysql
spring:
  datasource:
    type: com.alibaba.druid.pool.DruidDataSource
    #MySQL配置
    driverClassName: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://192.168.109.101:3306/achangmall_sms?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=Asia/Shanghai
    username: root
    password: root


mybatis-plus:
  mapper-locations: classpath:/mapper/**/*.xml
  global-config:
    db-config:
      id-type: auto
      logic-delete-value: 1
      logic-not-delete-value: 0

server:
  port: 7000

启动生成RenrenApplication.java,运行后去浏览器80端口查看,同样让他一页全显示后选择全部后生成。生成后解压复制到coupon项目对应目录下。让coupon也依赖于common,修改pom.xml

<dependency>
    <groupId>com.achang.achangmall</groupId>
    <artifactId>achangmall-common</artifactId>
    <version>0.0.1-SNAPSHOT</version>
</dependency>

resources下src包先删除

添加application.yml
spring:
  datasource:
    password: root
    username: root
    url: jdbc:mysql://192.168.109.101:3306/achangmall_sms?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai
    driver-class-name: com.mysql.jdbc.Driver


mybatis-plus:
  mapper-locations: classpath:/mapper/**/*.xml
  global-config:
    db-config:
      id-type: auto
      logic-delete-value: 1
      logic-not-delete-value: 0

运行gulimallCouponApplication.java

http://localhost:7000/coupon/coupon/list

{"msg":"success","code":0,"page":{"totalCount":0,"pageSize":10,"totalPage":0,"currPage":1,"list":[]}}
  • member
重新使用代码生成器生成ums

模仿上面修改下面两个配置
代码生成器里:
spring:
  datasource:
    type: com.alibaba.druid.pool.DruidDataSource
    #MySQL配置
    driverClassName: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://192.168.109.101:3306/achangmall_ums?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=Asia/Shanghai
    username: root
    password: root


mainPath=com.achang
package=com.achang.achangmall
moduleName=member
author=achang
email=995931576@qq.com
#表前缀(类名不会包含表前缀)
tablePrefix=ums_

重启RenrenApplication.java,然后同样去浏览器获取压缩包解压到对应member项目目录

member也导入依赖
<dependency>
    <groupId>com.achang.achangmall</groupId>
    <artifactId>achangmall-common</artifactId>
    <version>0.0.1-SNAPSHOT</version>
</dependency>

同样新建application.yml
spring:
  datasource:
    password: root
    username: root
    url: jdbc:mysql://192.168.109.101:3306/achangmall_ums?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai
    driver-class-name: com.mysql.jdbc.Driver


mybatis-plus:
  mapper-locations: classpath:/mapper/**/*.xml
  global-config:
    db-config:
      id-type: auto
      logic-delete-value: 1
      logic-not-delete-value: 0

server:
  port: 8000
  • order
修改代码生成器
spring:
  datasource:
    type: com.alibaba.druid.pool.DruidDataSource
    #MySQL配置
    driverClassName: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://192.168.109.101:3306/achangmall-oms?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=Asia/Shanghai
    username: root
    password: root

mainPath=com.achang
package=com.achang.achangmall
moduleName=order
author=achang
email=995931576@qq.com
tablePrefix=oms_


运行RenrenApplication.java重新生成后去下载解压放置。
application.yml

spring:
  datasource:
    password: root
    username: root
    url: jdbc:mysql://192.168.109.101:3306/achangmall-oms?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai
    driver-class-name: com.mysql.jdbc.Driver


mybatis-plus:
  mapper-locations: classpath:/mapper/**/*.xml
  global-config:
    db-config:
      id-type: auto
      logic-delete-value: 1
      logic-not-delete-value: 0
      
server:
  port: 9000

在pom.xml添加
<dependency>
    <groupId>com.achang.achangmall</groupId>
    <artifactId>achangmall-common</artifactId>
    <version>0.0.1-SNAPSHOT</version>
</dependency>

启动gulimallOrderApplication.java

http://localhost:9000/order/order/list
{"msg":"success","code":0,"page":{"totalCount":0,"pageSize":10,"totalPage":0,"currPage":1,"list":[]}}
  • ware
修改代码生成器
jdbc:mysql://192.168.1.103:3306/gulimall_wms?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=Asia/Shanghai

#代码生成器,配置信息

mainPath=com.yxj
package=com.yxj.gulimall
moduleName=ware
author=yxj
email=xxx@qq.com
tablePrefix=wms_

运行RenrenApplication.java重新生成后去下载解压放置。

application.yml

spring:
  datasource:
    username: root
    password: root
    url: jdbc:mysql://192.168.1.103:3306/gulimall_wms?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=Asia/Shanghai
    driver-class-name: com.mysql.cj.jdbc.Driver


mybatis-plus:
  mapper-locations: classpath:/mapper/**/*.xml
  global-config:
    db-config:
      id-type: auto
      logic-delete-value: 1
      logic-not-delete-value: 0
      
server:
  port: 11000

在pom.xml添加
<dependency>
    <groupId>com.atguigu.gulimall</groupId>
    <artifactId>gulimall-common</artifactId>
    <version>0.0.1-SNAPSHOT</version>
</dependency>

启动gulimallWareApplication.java
http://localhost:11000/ware/wareinfo/list
{"msg":"success","code":0,"page":{"totalCount":0,"pageSize":10,"totalPage":0,"currPage":1,"list":[]}}

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Em3UCqI9-1632152535297)(C:/Users/PePe/AppData/Roaming/Typora/typora-user-images/image-20210920233656400.png)]

报错用Byte类型代替=


Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐