springboot第二章---打造企業級微信點餐系統(4)--買家訂單01---實體類及dao

第一步:創建實體類(訂單主表及訂單詳情表)

OrderMaster.java

package com.fjz.vxsell.bean;

import com.fjz.vxsell.enums.OrderStatusEnums;
import com.fjz.vxsell.enums.PayStatusEnums;
import lombok.Data;
import org.hibernate.annotations.DynamicUpdate;

import javax.persistence.Entity;
import javax.persistence.Id;
import java.math.BigDecimal;
import java.util.Date;

/**
 * 訂單主表
 * @author 馮師兄
 * @date 2020-05-08 14:18
 */
@Entity
@Data
@DynamicUpdate
public class OrderMaster {

    /*訂單id*/
    @Id
    private String orderId;

    /*買家名字*/
    private String buyerName;

    /*買家電話*/
    private String buyerPhone;

    /*買家地址*/
    private String buyerAddress;

    /*買家微信id*/
    private String buyerOpenid;

    /*訂單總金額*/
    private BigDecimal orderAmount;

    /*訂單狀態,默認是新訂單爲0,實體類中最好不要出現=0,這裏用一個枚舉*/
    private Integer orderStatus = OrderStatusEnums.NEW.getCode();

    /*支付狀態,默認爲0 未支付*/
    private Integer payerStatus = PayStatusEnums.WAIT.getCode();

    /*創建時間*/
    private Date createTime;

    /*修改時間*/
    private Date updateTime;
}

創建枚舉 OrderStatusEnumsjava

package com.fjz.vxsell.enums;

import lombok.Getter;

/**
 * @author 馮師兄
 * @date 2020-05-08 14:29
 */
@Getter
public enum OrderStatusEnums {

    NEW(0,"新訂單"),
    FINISH(1,"訂單已完結"),
    CANCLE(2,"訂單已取消"),
    ;


    private Integer code;
    private String message;

    OrderStatusEnums(Integer code, String message) {
        this.code = code;
        this.message = message;
    }
}

PayStatusEnums.java

package com.fjz.vxsell.enums;

import lombok.Getter;

/**
 * @author 馮師兄
 * @date 2020-05-08 14:36
 */
@Getter
public enum PayStatusEnums {
    WAIT(0,"等待支付"),
    SUCCESS(1,"支付成功"),
    ;

    private Integer code;
    private String message;

    PayStatusEnums(Integer code, String message) {
        this.code = code;
        this.message = message;
    }
}

OrderDetail.java

package com.fjz.vxsell.bean;

import lombok.Data;
import org.hibernate.annotations.DynamicUpdate;

import javax.persistence.Entity;
import javax.persistence.Id;
import java.math.BigDecimal;
import java.security.PrivateKey;
import java.util.Date;

/**
 * 訂單詳情表
 * @author 馮師兄
 * @date 2020-05-08 14:44
 */
@Entity
@Data
@DynamicUpdate
public class OrderDetail {

    /*訂單詳情id*/
    @Id
    private String detailId;

    /*訂單id*/
    private String orderId;

    /*商品id*/
    private String productId;

    /*商品名稱*/
    private String productName;

    /*商品價格*/
    private BigDecimal productPrice;

    /*商品數量*/
    private Integer productQuantity;

    /*商品圖片*/
    private String productIcon;



}

第二步:創建repository:OrderMasterRepository.java

package com.fjz.vxsell.repository;

import com.fjz.vxsell.bean.OrderMaster;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
import org.springframework.data.jpa.repository.JpaRepository;

/**
 * @author 馮師兄
 * @date 2020-05-08 14:59
 */
public interface OrderMasterRepository extends JpaRepository<OrderMaster,String> {

    /**
     * 分頁查詢
     * 根據買家的openid查詢
     * @param buyerOpenid
     * @param pageable
     * @return
     */
    Page<OrderMaster> findByBuyerOpenid(String buyerOpenid, Pageable pageable);
}

測試:

package com.fjz.vxsell.repository;

import com.fjz.vxsell.bean.OrderMaster;
import org.junit.Assert;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.PageRequest;
import org.springframework.test.context.junit4.SpringRunner;

import java.math.BigDecimal;

import static org.junit.Assert.*;

@RunWith(SpringRunner.class)
@SpringBootTest
public class OrderMasterRepositoryTest {

    @Autowired
    private OrderMasterRepository orderMasterRepository;

    private final String Openid = "123456";

    /**
     * 測試保存
     */
    @Test
    public void saveTest() {
        OrderMaster orderMaster = new OrderMaster();
        orderMaster.setOrderId("004");
        orderMaster.setBuyerName("十三師兄");
        orderMaster.setBuyerPhone("15916574437");
        orderMaster.setBuyerAddress("北京房山");
        orderMaster.setBuyerOpenid(Openid);
        orderMaster.setOrderAmount(new BigDecimal(255.63));

        OrderMaster result = orderMasterRepository.save(orderMaster);
        Assert.assertNotNull(result);

    }

    /**
     * 分頁查詢
     */
    @Test
    public void findByBuyerOpenid() {
        PageRequest request = new PageRequest(0,2);
        Page<OrderMaster> page = orderMasterRepository.findByBuyerOpenid(Openid, request);
        System.out.println(page.getTotalElements());
        Assert.assertNotEquals(0, page.getTotalPages());
    }
}

OrderDetailRepository.java

package com.fjz.vxsell.repository;

import com.fjz.vxsell.bean.OrderDetail;
import org.springframework.data.jpa.repository.JpaRepository;

import java.util.List;

/**
 * @author 馮師兄
 * @date 2020-05-08 15:02
 */
public interface OrderDetailRepository extends JpaRepository<OrderDetail, String> {

    /**
     * 根據orderID查詢出所有的訂單詳情
     * @param orderId
     * @return
     */
    List<OrderDetail> findByOrderId(String orderId);
}

測試:

package com.fjz.vxsell.repository;

import com.fjz.vxsell.bean.OrderDetail;
import org.junit.Assert;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;

import java.math.BigDecimal;
import java.util.List;

import static org.junit.Assert.*;

@RunWith(SpringRunner.class)
@SpringBootTest
public class OrderDetailRepositoryTest {

    @Autowired
    private OrderDetailRepository orderDetailRepository;

    @Test
    public void saveTest(){
        OrderDetail orderDetail = new OrderDetail();
        orderDetail.setDetailId("000002");
        orderDetail.setOrderId("111111");
        orderDetail.setProductId("010101");
        orderDetail.setProductIcon("http://xxxx.jpg");
        orderDetail.setProductName("華爲");
        orderDetail.setProductPrice(new BigDecimal(35.3));
        orderDetail.setProductQuantity(50);

        OrderDetail result = orderDetailRepository.save(orderDetail);
        Assert.assertNotNull(result);
    }

    @Test
    public void findByOrderId() {
        List<OrderDetail> list =  orderDetailRepository.findByOrderId("111111");
        Assert.assertNotEquals(0, list.size());
    }
}

 

 

 

 

 

 

 

 

 

 

 

 

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章