日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

枚举中文转数字并easyexcel导入(读取Read)数据至数据库,用监听器解决导入关联多表的问题

發布時間:2024/3/26 数据库 44 豆豆
生活随笔 收集整理的這篇文章主要介紹了 枚举中文转数字并easyexcel导入(读取Read)数据至数据库,用监听器解决导入关联多表的问题 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

以下內容皆為本人學習過程中的所學的知識,全根據自己所學思路來寫的。

大致流程如下:

一、創建實體類,注意有一個是導入的模板實體模型類(CustomManageAndCustomerInformationReadVO),有一個是這個模塊的主表實體(CustomManage),模塊主表實體才會連接到數據庫的數據,而模板實體模型類是導入所要求有的字段,并且哪個字段在哪一列從0開始。

二、在controller層調用ExcelUtils工具類下的customerInformationReadExcel()方法。
三、進入ExcelUtils工具類編寫customerInformationReadExcel()方法,其中需要調用到CustomManageListener()監聽器也可稱之為解析器。

四、導入的難點就在于監聽器的編寫,如若導入的數據屬于一張表還不難,重點是我這次做的是多表的,需要進行連表操作,調用其他表的mapper和service。不會做就覺得難。做了覺得也還行不是特別難,就像地上本沒有路走的人多了也就成了路。監聽器中調用了公共枚舉中文轉數字的方法。

五、進入公共枚舉類,編寫中文轉數字的getEnumNum()方法,實現中文獲取數字,導入,(從excel中導入數據至數據庫)。

1.創建實體類,注意有一個是導入的模板實體模型類(CustomManageAndCustomerInformationReadVO),有一個是這個模塊的主表實體(CustomManage),模塊主表實體才會連接到數據庫的數據,而模板實體模型類是導入所要求有的字段,并且哪個字段在哪一列從0開始。

package com.theiavis.workcloud.project.sale.bean;import java.io.Serializable; import java.util.Date;import com.alibaba.excel.annotation.ExcelIgnore; import com.alibaba.excel.annotation.ExcelProperty; import com.baomidou.mybatisplus.annotation.IdType; import com.baomidou.mybatisplus.annotation.TableId; import com.fasterxml.jackson.annotation.JsonFormat; import com.fasterxml.jackson.annotation.JsonIgnoreProperties; import com.theiavis.workcloud.common.entity.BaseEntity; import io.swagger.annotations.ApiModel; import io.swagger.annotations.ApiModelProperty; import lombok.*; import lombok.experimental.Accessors; import org.springframework.web.bind.annotation.ModelAttribute;/*** custom_manage :*/ @Data @Accessors(chain=true) @AllArgsConstructor @NoArgsConstructor @ApiModel("客戶管理對象") public class CustomManage extends BaseEntity implements Serializable {private static final long serialVersionUID = 1L;/*** 主鍵 : id,*/@ExcelIgnore@TableId(value = "id", type = IdType.AUTO)private Integer id;/*** sale_time, 銷售時間,kpi關聯,需拆分-年*/@ExcelIgnore@ExcelProperty(value = {"年份"}, index = 0)@ApiModelProperty(value = "銷售時間-年", required = true)private String saleTimeYear;/*** sale_time, 銷售時間,kpi關聯,需拆分-月*/@ExcelIgnore@ExcelProperty(value = {"所屬月份"}, index = 1)@ApiModelProperty(value = "銷售時間-月", required = true)private String saleTimeMonth;/*** proj_num, project-》projo_num,創建時間與項目表關聯*/@ExcelIgnore@ExcelProperty(value = {"創建時間與項目表關聯"}, index = 2)@ApiModelProperty(value = "創建時間與項目表關聯", required = true)private String projNum;/*** follow_id, 跟進人標識user->user_id*/@ExcelIgnore@ExcelProperty(value = {"跟進人標識user->user_id"}, index = 3)@ApiModelProperty(value = "跟進人標識user->user_id", required = true)private String followId;/*** create_id, 創建人標識user->user_id*/@ExcelIgnore@ExcelProperty(value = {"創建人標識user->user_id"}, index = 4)@ApiModelProperty(value = "創建人標識user->user_id", required = true)private String createId;/*** company, 對接公司名稱*/@ExcelIgnore@ExcelProperty(value = {"公司名稱"}, index = 5)@ApiModelProperty(value = "對接公司名稱", required = true)private String company;/*** custom_type, 客戶類型(0、商業公司1、政府2、地產商3、規劃院)*/@ExcelIgnore@ExcelProperty(value = {"客戶類型(0、商業公司1、政府2、地產商3、規劃院)"}, index = 6)@ApiModelProperty(value = "客戶類型(0、商業公司1、政府2、地產商3、規劃院)", required = true)private String customType;/*** city, 客戶所在城市*/@ExcelIgnore@ExcelProperty(value = {"客戶所在城市"}, index = 7)@ApiModelProperty(value = "客戶所在城市", required = true)private String city;/*** custom_department, 客戶所在部門*/@ExcelIgnore@ExcelProperty(value = {"客戶所在部門"}, index = 8)@ApiModelProperty(value = "客戶所在部門", required = true)private String customDepartment;/*** contact, 聯系人名字(全稱)*/@ExcelIgnore@ExcelProperty(value = {"聯系人名字(全稱)"}, index = 9)@ApiModelProperty(value = "聯系人名字(全稱)", required = true)private String contact;/*** mobile, 聯系人電話*/@ExcelIgnore@ExcelProperty(value = {"聯系人電話"}, index = 10)@ApiModelProperty(value = "聯系人電話", required = true)private String mobile;/*** email, 聯系人郵箱*/@ExcelIgnore@ExcelProperty(value = {"聯系人郵箱"}, index = 11)@ApiModelProperty(value = "聯系人郵箱", required = true)private String email;/*** custom_source, 新舊客戶類型(0.移交客戶1.新客戶)*/@ExcelIgnore@ExcelProperty(value = {"新舊客戶類型(0.移交客戶1.新客戶)"}, index = 12)@ApiModelProperty(value = "新舊客戶類型(0.移交客戶1.新客戶)", required = true)private String customSource;/*** custom_id, 客戶id*/@ExcelIgnore@ExcelProperty(value = {"客戶id"}, index = 13)@ApiModelProperty(value = "客戶id", required = false)private String customId;/*** permit_code, 權限碼*/@ExcelIgnore@ExcelProperty(value = {"權限碼"}, index = 14)@ApiModelProperty(value = "權限碼", required = true)private String permitCode;/*** dept_id, 部門id*/@ExcelIgnore// @ExcelProperty(value = {"部門id"}, index = 15)@ApiModelProperty(value = "部門id", required = true)private Integer deptId;/*** agreement_id, proj_agreement->id合同標識*/@ExcelIgnore// @ExcelProperty(value = {"id合同標識"}, index = 16)@ApiModelProperty(value = "id合同標識", required = false)private Integer agreementId;/*** creat_Time, create_Time創建時間*/@ExcelIgnore@ExcelProperty(value = {"create_Time創建時間"}, index = 17)@ApiModelProperty(value = "create_Time創建時間", required = false)@JsonFormat(pattern = "yyyy-MM-dd", timezone = "GMT+8")private Date createTime;/*** is_delete, 是否刪除*/@ExcelIgnore@ExcelProperty(value = {"是否刪除0.否1.是"}, index = 18)@ApiModelProperty(value = "是否刪除0.否1.是", required = true)private String isDelete;} package com.theiavis.workcloud.project.sale.vo;import com.alibaba.excel.annotation.ExcelIgnore; import com.alibaba.excel.annotation.ExcelProperty; import com.baomidou.mybatisplus.annotation.TableField; import com.fasterxml.jackson.annotation.JsonFormat; import com.fasterxml.jackson.annotation.JsonIgnore; import io.swagger.annotations.ApiModelProperty; import lombok.AllArgsConstructor; import lombok.Data; import lombok.NoArgsConstructor; import lombok.experimental.Accessors;import java.util.Date;/*** 根據"客戶信息導入模板"批量導入* @author xql*/ @Data //@Accessors(chain=true) @AllArgsConstructor @NoArgsConstructor public class CustomManageAndCustomerInformationReadVO {/*** stage, 商機尋找(0.商機線索,1.在談項目 2.簽約項目 3.已歸檔項目4.前期介入5.項目報價6.關鍵人物接觸7.方案匯報8.方案階段9.投標階段10.合同階段11.項目暫停)*/@ApiModelProperty(value = "商機尋找(0.商機線索,1.在談項目 2.簽約項目 3.已歸檔項目4.前期介入5.項目報價6.關鍵人物接觸7.方案匯報8.方案階段9.投標階段10.合同階段11.項目暫停)", required = true)@ExcelProperty(value = "所屬階段", index = 0)private String stage;/*** sale_time, 銷售時間,kpi關聯,需拆分-年*/@ExcelProperty(value = "年份", index = 1)private String saleTimeYear;/*** sale_time, 銷售時間,kpi關聯,需拆分-月*/@ExcelProperty(value = "所屬月份", index = 2)private String saleTimeMonth;/*** 客戶來源*/@ExcelProperty(value = "客戶來源", index = 3)@TableField(exist = false)@ApiModelProperty(value = "客戶來源", required = true)private String source;/*** company, 對接公司名稱*/@ExcelProperty(value = "公司名稱", index = 4)private String company;/*** 項目名 項目名稱*/@ExcelProperty(value = "項目名稱", index = 5)private String projName;/*** 項目地址*/@ExcelProperty(value = "項目地址", index = 6)@TableField(exist = false)@ApiModelProperty(value = "項目地址", required = true)private String address;/*** 項目類型*/@ExcelProperty(value = "項目類型", index = 7)@TableField(exist = false)@ApiModelProperty(value = "項目類型(項目類型(0、數字大屏1、數字沙盤2、數字展項3、數字展廳4、CIM 5、VRXR 6:其他)", required = true)private String projectType;/*** custom_type, 客戶類型(0、商業公司1、政府2、地產商3、規劃院)*/@ExcelProperty(value = "客戶類型", index = 8)@ApiModelProperty(value = "客戶類型(0、商業公司1、政府2、地產商3、規劃院)", required = true)private String customType;/*** city, 客戶所在城市*/@ExcelProperty(value = {"客戶所在城市"}, index = 9)@ApiModelProperty(value = "客戶所在城市", required = true)private String city;/*** custom_department, 客戶所在部門*/@ExcelProperty(value = {"客戶所屬部門"}, index = 10)@ApiModelProperty(value = "客戶所在部門", required = true)private String customDepartment;/*** contact, 聯系人名字(全稱)*/@ExcelProperty(value = "聯系人", index = 11)private String contact;/*** email, 聯系人郵箱*/@ExcelProperty(value = {"聯系人郵箱"}, index = 12)@ApiModelProperty(value = "聯系人郵箱", required = true)private String email;/*** mobile, 聯系人電話*/@ExcelProperty(value = "聯系人電話", index = 13)private String mobile;/*** follow_id, 跟進人名稱*/@ExcelProperty(value = "跟進人", index = 14)private String followName;/*** 跟進結果*/@ExcelProperty(value = "跟進結果", index = 15)@TableField(exist = false)@ApiModelProperty(value = "跟進結果", required = true)private String followResult;/*** 失敗原因*/@ExcelProperty(value = "失敗原因", index = 16)@TableField(exist = false)@ApiModelProperty(value = "失敗原因", required = true)private String followFailResult;/*** 計劃開始時間*/@TableField(exist = false)@ExcelProperty(value = "計劃開始時間(yyyy/mm/dd)", index = 17)@JsonIgnoreprivate Date planStartTime;/*** proj_need, 項目需求*/@TableField(exist = false)@ExcelProperty(value = "項目需求", index = 18)@ApiModelProperty(value = "項目需求", required = true)private String projNeed;/*** 計劃結束時間*/@TableField(exist = false)@ExcelProperty(value = "計劃結束時間(yyyy/mm/dd)", index = 19)@JsonIgnoreprivate Date planEndTime;/*** custom_source, 新舊客戶類型(0.移交客戶1.新客戶)*/@TableField(exist = false)@ExcelProperty(value = "新舊客戶類型", index = 20)private String customSource;/*** product_count, 產品數量*/@TableField(exist = false)@ExcelProperty(value = "產品數量", index = 21)@ApiModelProperty(value = "產品數量", required = true)private String productCount;/*** contract_cash, 預計合同金額*/@TableField(exist = false)@ExcelProperty(value = "預計合同金額(萬元)", index = 22)@ApiModelProperty(value = "預計合同金額", required = true)private String contractCash;/*** place_contract, 是否簽訂合同(0.未簽約1.已簽約)*/@TableField(exist = false)@ExcelProperty(value = "是否簽訂保密協議", index = 23)@ApiModelProperty(value = "是否簽訂保密協議(0.未簽約1.已簽約)", required = true)private String placeContract;/*** effect_pj, 是否當地影響力(0.否1.是)*/@TableField(exist = false)@ExcelProperty(value = "是否當地影響力", index = 24)@ApiModelProperty(value = "是否當地影響力(0.否1.是)", required = true)private String effectPj;/*** 項目進度*/@TableField(exist = false)@ExcelProperty(value = "項目進度",index = 25)@ApiModelProperty(value = "項目進度(0:前期介入1:項目報價2:關鍵人物接觸3:方案制作階段4:方案匯報5:DEMO制作6:投標階段7:簽約階段8:項目站廳)", required = true)private String projProgress;/*** star, 項目星級(數字標識1-5)*/@TableField(exist = false)@ExcelProperty(value = "項目靠譜程度",index = 26)@ApiModelProperty(value = "項目靠譜程度", required = true)private String star;/*** contract_cash_count, 合同金額*/@TableField(exist = false)@ExcelProperty(value = "合同金額(萬元)",index = 27)@ApiModelProperty(value = "合同金額", required = true)private String contractCashCount;/*** realcontract_cash, 合同實際金額*/@TableField(exist = false)@ExcelProperty(value = "合同實際金額(萬元)",index = 28)@ApiModelProperty(value = "合同實際金額", required = true)private String realcontractCash;/*** contract_mode, 合同模式(0.分期付款1.背靠背式2:賒賬)*/@TableField(exist = false)@ExcelProperty(value = "合同模式",index = 29)@ApiModelProperty(value = "合同模式(0.分期付款1.背靠背式2:賒賬)", required = true)private String contractMode;/*** intexamine_time, 初驗收時間*/@TableField(exist = false)@ExcelProperty(value = "初驗收時間(yyyy/mm/dd)",index =30)@ApiModelProperty(value = "初驗收時間", required = true)private Date intexamineTime;/*** init_cash, 初步收入金額*/@TableField(exist = false)@ExcelProperty(value = "初步收入金額(萬元)",index =31)@ApiModelProperty(value = "初步收入金額", required = true)private String initCash;/*** endexamine_time, 最終驗收時間*/@TableField(exist = false)@ExcelProperty(value = "最終驗收時間(yyyy/mm/dd)",index =32)@ApiModelProperty(value = "最終驗收時間", required = true)private Date endexamineTime;/*** end_cash, 最終金額*/@TableField(exist = false)@ExcelProperty(value = "最終金額(萬元)",index =33)@ApiModelProperty(value = "最終金額", required = true)private String endCash;/*** receive_cash_time, 收款最終時間*/@TableField(exist = false)@ExcelProperty(value = "收款日期(yyyy/mm/dd)",index =34)@ApiModelProperty(value = "收款最終時間", required = true)private Date receiveCashTime;/*** contract_deposit, 合同預付款(定金)*/@TableField(exist = false)@ExcelProperty(value = "預付款(萬元)",index =35)@ApiModelProperty(value = "合同預付款(定金)", required = true)private String contractDeposit;/*** proj_state, 項目狀態(0項目進行中/1暫停項目/2催款中/3已完成需催款/4已清項目)*/@TableField(exist = false)@ExcelProperty(value = "項目狀態",index =36)@ApiModelProperty(value = "項目狀態(0項目進行中/1暫停項目/2催款中/3已完成需催款/4已清項目)", required = true)private String projState;/*** back_cash, 回款跟催狀態(1.催款中2.已完成催款3.已清項目4.異常5.拖款)*/@TableField(exist = false)@ExcelProperty(value = "回款跟催階段",index =37)@ApiModelProperty(value = "回款跟催狀態(0. 正在催款 1. 常規(預計三個月內收款 ) 2. 異常(預計超半年催款) 3.拖款(預計3~6個月回款))", required = true)private String backCash;/*** market_commision, 市場提成系數*/@TableField(exist = false)@ExcelProperty(value = "市場提成系數",index =38)@ApiModelProperty(value = "市場提成系數", required = true)private String marketCommision;/*** commision_month, 市場提成月數*/@TableField(exist = false)@ExcelProperty(value = "市場提成月份",index =39)@ApiModelProperty(value = "市場提成月數", required = true)private String commisionMonth;/*** feedback, 具體反饋(0.成果質量1.服務態度2.過程技術配合3.時間配合4.交付時間)*/@TableField(exist = false)@ExcelProperty(value = "具體反饋",index =40)@ApiModelProperty(value = "具體反饋(0.成果質量1.服務態度2.過程技術配合3.時間配合4.交付時間)", required = true)private String feedback;/*** remark, 備注(項目注意事宜)*/@TableField(exist = false)@ExcelProperty(value = "備注",index =41)@ApiModelProperty(value = "備注(項目注意事宜)", required = true)private String remark;/*** detail_need,詳細需求*/@TableField(exist = false)@ExcelProperty(value = "詳細需求",index =42)@ApiModelProperty(value = "詳細需求", required = true)private String detailNeed;}

2.在controller層調用ExcelUtils工具類下的customerInformationReadExcel()方法。

/*** 根據客戶信息導入模板批量導入** @param* @return* @throws Exception*/@PreAuthorize("hasPermit('sale:client')")@RequestMapping(value = "/customerInformationReadExcel", method = RequestMethod.POST, produces = "application/octet-stream")@ApiOperation(value = "客戶信息導入(按照模板導入)", tags = {"銷售模塊", "客戶信息導入(按照模板導入)"})public Result customerInformationReadExcel(@RequestPart @RequestParam(value = "file", required = false) MultipartFile file)throws Exception {try {ExcelUtils.customerInformationReadExcel(file.getInputStream());return Result.success(ResultCode.成功, ResultCode.成功.getCode());} catch (Exception e) {return Result.error(ResultCode.失敗.getMsg(), ResultCode.失敗.getCode(), null);}}

3.進入ExcelUtils工具類編寫customerInformationReadExcel()方法,其中需要調用到CustomManageListener()監聽器也可稱之為解析器。

/*** 根據客戶信息導入模板批量導入* @param inputStream*/public static void customerInformationReadExcel(InputStream inputStream) {EasyExcel.read(inputStream, CustomManageAndCustomerInformationReadVO.class,new CustomManageListener()).registerConverter(new LocalDateTimeConverter()).sheet().doRead();}

4.導入的難點就在于監聽器的編寫,如若導入的數據屬于一張表還不難,重點是我這次做的是多表的,需要進行連表操作,調用其他表的mapper和service。不會做就覺得難。做了覺得也還行不是特別難,就像地上本沒有路走的人多了也就成了路。監聽器中調用了公共枚舉中文轉數字的方法。

package com.theiavis.workcloud.project.sale.enums;import com.alibaba.excel.context.AnalysisContext; import com.alibaba.excel.exception.ExcelDataConvertException; import com.alibaba.excel.read.listener.ReadListener; import com.alibaba.excel.util.ListUtils; import com.alibaba.excel.util.StringUtils; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.theiavis.security.jwt.UserOperator; import com.theiavis.workcloud.project.agreement.bean.ProjAgreement; import com.theiavis.workcloud.project.agreement.mapper.ProjAgreementMapper; import com.theiavis.workcloud.project.agreement.service.IProjAgreementService; import com.theiavis.workcloud.project.dingtalk.bean.User; import com.theiavis.workcloud.project.dingtalk.mapper.UserMapper; import com.theiavis.workcloud.project.proj.VO.proj.ProjIdOutputVo; import com.theiavis.workcloud.project.proj.VO.proj.ProjInsertVO; import com.theiavis.workcloud.project.proj.bean.Project; import com.theiavis.workcloud.project.proj.mapper.ProjectMapper; import com.theiavis.workcloud.project.proj.service.ProjectService; import com.theiavis.workcloud.project.sale.bean.CustomManage; import com.theiavis.workcloud.project.sale.mapper.CustomManageMapper; import com.theiavis.workcloud.project.sale.service.ICustomManageService; import com.theiavis.workcloud.project.sale.vo.CustomManageAndCustomerExportVO; import com.theiavis.workcloud.project.sale.vo.CustomManageAndCustomerInformationReadVO; import lombok.NoArgsConstructor; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.context.annotation.Lazy; import org.springframework.stereotype.Component; import org.springframework.transaction.annotation.Transactional;import javax.annotation.PostConstruct; import java.util.List; import java.util.logging.Logger;@Slf4j @Component public class CustomManageListener implements ReadListener<CustomManageAndCustomerInformationReadVO> {private static final Logger logger = Logger.getLogger(CustomManageListener.class.getName());/*** 每隔5條存儲數據庫,實際使用中可以100條,然后清理list ,方便內存回收*/private static final int BATCH_COUNT = 100;/*** 緩存的數據*/private List<CustomManageAndCustomerInformationReadVO> cachedDataList = ListUtils.newArrayListWithExpectedSize(BATCH_COUNT);@AutowiredICustomManageService iCustomManageService;//相當于注冊到spring的一個bean@AutowiredUserOperator userOperator;@AutowiredUserMapper userMapper;//相當于注冊到spring的一個bean@AutowiredIProjAgreementService iProjAgreementService;//相當于注冊到spring的一個bean@AutowiredProjectService projectService;//相當于注冊到spring的一個bean//把他自身的類實例化,并定義成靜態類public static CustomManageListener customManageListener;@PostConstructpublic void init(){//當前指針去指向這個類的對象,因為spring容器里面有相同的對象customManageListener =this;}/*** 這個每一條數據解析都會來調用** @param customManageAndCustomerInformationReadVO one row value. Is is same as {@link AnalysisContext#readRowHolder()}* @param analysisContext*/@Transactional(rollbackFor = Exception.class)@Overridepublic void invoke(CustomManageAndCustomerInformationReadVO customManageAndCustomerInformationReadVO, AnalysisContext analysisContext) {logger.info("解析到一條數據:{}");cachedDataList.add(customManageAndCustomerInformationReadVO);// 達到BATCH_COUNT了,需要去存儲一次數據庫,防止數據幾萬條數據在內存,容易OOMif (cachedDataList.size() >= BATCH_COUNT) {saveData();// 存儲完成清理 listcachedDataList = ListUtils.newArrayListWithExpectedSize(BATCH_COUNT);}}@Transactional(rollbackFor = Exception.class)public void saveData() {cachedDataList.stream().forEach(i->{logger.info("{}條數據,開始存儲數據庫!");try { // String 數字=StatusEnum.getEnumNum("錯誤","Source"); // User createId=customManageListener.userMapper.selectOne(new QueryWrapper<User>().groupBy("user_id").like("name",i.getCreaterName()));//查詢出的結果絕對有一個用selectOne()方法(如若有多條數據就會報錯),QueryWrapper<User>()方法是MybatisPlus函數的用法,實現查詢的對象封裝操作類。groupBy()分組,like()模糊查詢。根據followId(也就是user_id)查詢對應的followName。主表中沒有followName,只有followId,所以在user表(userMapper)中查詢對應的name。User followId=customManageListener.userMapper.selectOne(new QueryWrapper<User>().groupBy("user_id").like("name",i.getFollowName()));//鏈式編程。數據存在主表(custom_manage)中CustomManage customManage=new CustomManage().setFollowId(followId.getUserId()!=null?followId.getUserId():null).setSaleTimeYear(i.getSaleTimeYear()).setSaleTimeMonth(i.getSaleTimeMonth()).setCompany(i.getCompany()).setCustomType(StatusEnum.getEnumNum(i.getCustomType(),"CustomType")).setCity(i.getCity()).setCustomDepartment(i.getCustomDepartment()).setContact(i.getContact()).setEmail(i.getEmail()).setMobile(i.getMobile()).setCustomSource(StatusEnum.getEnumNum(i.getCustomSource(),"CustomSource"));if (StringUtils.isNotBlank(i.getProjName())){//數據存儲在project次表中ProjIdOutputVo projIdOutputVo =customManageListener.projectService.insertProj(new ProjInsertVO().setProjName(i.getProjName()));//數據存儲在proj_agreement次表中int projAgreementId=customManageListener.iProjAgreementService.addProjAgreement(new ProjAgreement().setStage(StatusEnum.getEnumNum(i.getStage(),"Stage")).setSource(StatusEnum.getEnumNum( i.getSource(),"Source")).setAddress(i.getAddress()).setProjectType(StatusEnum.getEnumNum( i.getProjectType(),"ProjectType")).setFollowResult(StatusEnum.getEnumNum( i.getFollowResult(),"FollowResult")).setFollowFailResult(i.getFollowFailResult()).setPlanStartTime(i.getPlanStartTime()).setProjNeed(i.getProjNeed()).setPlanEndTime(i.getPlanEndTime()).setProductCount(i.getProductCount()).setContractCash(i.getContractCash()).setPlaceContract(StatusEnum.getEnumNum(i.getPlaceContract(),"PlaceContract")).setEffectPj(StatusEnum.getEnumNum(i.getEffectPj(),"EffectPj")).setProjProgress(StatusEnum.getEnumNum(i.getProjProgress(),"ProjProgress")).setStar(i.getStar()).setContractCashCount(i.getContractCashCount()).setRealcontractCash(i.getRealcontractCash()).setContractMode(StatusEnum.getEnumNum(i.getContractMode(),"ContractMode")).setIntexamineTime(i.getIntexamineTime()).setInitCash(i.getInitCash()).setEndexamineTime(i.getEndexamineTime()).setEndCash(i.getEndCash()).setReceiveCashTime(i.getReceiveCashTime()).setContractDeposit(i.getContractDeposit()).setProjState(StatusEnum.getEnumNum(i.getProjState(),"ProjState")).setBackCash(StatusEnum.getEnumNum(i.getBackCash(),"BackCash")).setMarketCommision(i.getMarketCommision()).setCommisionMonth(i.getCommisionMonth()).setFeedback(StatusEnum.getEnumNum(i.getFeedback(),"Feedback")).setRemark(i.getRemark()).setDetailNeed(i.getDetailNeed()));customManageListener.iCustomManageService.addCustomManage(customManage.setProjNum(projIdOutputVo.getProjNum()).setAgreementId(projAgreementId));//指定到靜態的Usermapper注入的對象}} catch (Exception e) {e.printStackTrace();}});logger.info("存儲數據庫成功!");}/*** 在轉換異常 獲取其他異常下會調用本接口。拋出異常則停止讀取。如果這里不拋出異常則 繼續讀取下一行。* // * @param exception // * @param context* @throws Exception*/ // @Override // public void onException(Exception exception, AnalysisContext context) { // log.error("解析失敗,但是繼續解析下一行:{}", exception.getMessage()); // // 如果是某一個單元格的轉換異常 能獲取到具體行號 // // 如果要獲取頭的信息 配合invokeHeadMap使用 // if (exception instanceof ExcelDataConvertException) { // ExcelDataConvertException excelDataConvertException = (ExcelDataConvertException)exception; // log.error("第{}行,第{}列解析異常,數據為:{}", excelDataConvertException.getRowIndex(), // excelDataConvertException.getColumnIndex(), excelDataConvertException.getCellData()); // } // }@Overridepublic void doAfterAllAnalysed(AnalysisContext analysisContext) {// 這里也要保存數據,確保最后遺留的數據也存儲到數據庫saveData();logger.info("所有數據解析完成!");} }

5.進入公共枚舉類,編寫中文轉數字的getEnumNum()方法,實現中文獲取數字,導入,(從excel中導入數據至數據庫)。

package com.theiavis.workcloud.project.sale.enums;import com.baomidou.mybatisplus.annotation.EnumValue; import com.fasterxml.jackson.annotation.JsonValue; import lombok.Getter; import lombok.NoArgsConstructor;/**** @author lyh and xql*/ @NoArgsConstructor @Getter public enum StatusEnum {/*** 客戶來源(頁面名稱從0開始) 項目信息來源(數據庫名稱從1開始)*/信息("Source","0"),公司轉交("Source","1"),自我開拓("Source","2"),合作客戶轉介紹("Source","3"),絲路分公司("Source","4"),展會信息("Source","5"),協會資源轉換("Source","6"),其他渠道("Source","7"),/*** 項目類型 頁面字段與數據庫不符*/數字大屏("ProjectType","0"),數字沙盤("ProjectType","1"),數字展項("ProjectType","2"),數字展廳("ProjectType","3"),CIM("ProjectType","4"),VRXR("ProjectType","5"),其他("ProjectType","6"),/*** 客戶類型*/商業公司("CustomType","0"),政府("CustomType","1"),地產商("CustomType","2"),規劃院("CustomType","3"),/*** 跟進結果*/成功("FollowResult","0"),失敗("FollowResult","1"),跟進中("FollowResult","2"),/*** 新舊客戶類型*/移交客戶("CustomSource","0"),新客戶("CustomSource","1"),/*** 是否簽訂保密協議*/未簽約("PlaceContract","0"),已簽約("PlaceContract","1"),/*** 是否當地影響力*/否("EffectPj","0"),是("EffectPj","1"),/*** 項目進度*/前期介入("ProjProgress","0"),項目報價("ProjProgress","1"),關鍵人物接觸("ProjProgress","2"),方案制作階段("ProjProgress","3"),方案匯報("ProjProgress","4"),DEMO制作("ProjProgress","5"),投標階段("ProjProgress","6"),簽約階段("ProjProgress","7"),/*** 合同模式*/背靠背("ContractMode","0"),分期付款("ContractMode","1"),賒銷("ContractMode","2"),/*** 項目狀態*/項目進行中("ProjState","0"),暫停項目("ProjState","1"),催款中("ProjState","2"),已完成需催款("ProjState","3"),已清項目("ProjState","4"),/*** 回款跟催階段*/正在催款("BackCash","0"),常規("BackCash","1"),異常("BackCash","2"),拖款("BackCash","3"),/*** 具體反饋*/成果質量("Feedback","0"),服務態度("Feedback","1"),過程技術配合("Feedback","2"),時間配合("Feedback","3"),交付時間("Feedback","4"),/*** 所處階段,所屬階段*/商機線索("Stage","0"),在談項目("Stage","1"),簽約項目("Stage","2"),已歸檔("Stage","3"),/*** 狀態*/新領取("Status","0"),占用("Status","1"),新歸還("Status","2"),空閑("Status","3"),接收中("Status","4"),/*** 資產類型0筆記本1顯示器2ipad3AR/VA設備4相機5鼠標6其他*/筆記本("Type","0"),顯示器("Type","1"),ipad("Type","2"),AR或VA設備("Type","3"),相機("Type","4"),鼠標("Type","5"),其他設備("Type","6"),/*** 申報視圖的申報狀態*/未申報("DeclareStatus","0"),已申報("DeclareStatus","1"),;/*** 字段 (英文)*/@EnumValueprivate String key;/*** 屬性 (數字)*/@JsonValueprivate String value;StatusEnum(String key, String value) {this.value = value;this.key = key;}public String getKey() {return key;}public String getValue() {return value;}/*** 數字獲取中文,導出,從數據庫中導出數據至excel* @param key 英文,對應bean的字段名* @param value 數字,對應數據庫的0123的標識注釋* @return*/public static String getEnum(String key,String value){//用數組存放這些屬性(也就是枚舉的值)StatusEnum[] applicationStateEnums = values();//循環判斷key和value是否相等,相等就返回枚舉中對應的中文namefor (StatusEnum itemEnum : applicationStateEnums) {if (itemEnum.key.equals(key) && itemEnum.value.equals(value)) {if (key.equals("Source")&&value!=null){return itemEnum.name().replace("信息","400信息");}else{return itemEnum.name();}}}return null;}/*** 中文獲取數字,導入,從excel中導入數據至數據庫中* @param name 中文,枚舉中有定義,對應模板的下拉選項* @param key 英文,對應bean的字段名* @return*/public static String getEnumNum(String name,String key){//用數組存放這些屬性(也就是枚舉的值)StatusEnum[] applicationStateEnums = values();//循環判斷name和key是否相等,相等就返回枚舉中對應的數字valuefor (StatusEnum itemEnum : applicationStateEnums) {if (key.equals("Source")&& name.equals("400信息")){return "0";}if (itemEnum.name().equals(name)&& itemEnum.key.equals(key)) {return itemEnum.value;}}return null;}}

6.進入主表的mappe進行連表操作,需要用到的字段都要在前面標明是哪個表里的什么字段as別名是什么,進行連表的字段還需在主表也就是本模塊的實體類中標注注解此字段不在本表中,不然導出的數據會出現有些字段無數據。

<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.theiavis.workcloud.project.sale.mapper.CustomManageMapper"><!-- 通用設置 --><!-- 通用查詢列 --><sql id="Base_Column_List">a.id,a.sale_time_year,a.sale_time_month,a.proj_num,a.follow_id,a.create_id,a.company,a.custom_type,a.city,a.custom_department,a.contact,a.mobile,a.email,a.custom_source,a.custom_id,a.permit_code,a.dept_id,a.agreement_id,a.create_time,a.is_delete</sql><select id="findCustomManageByAll" resultType="com.theiavis.workcloud.project.sale.vo.CustomManageAndProjectVO">SELECT<include refid="Base_Column_List"/>,a.custom_type as CustomType,b.proj_name,f.name as follow_name,d.name as creater_name,c.stage,c.source as Source,c.address,c.project_type,c.follow_result,c.follow_fail_result,c.plan_start_time,c.proj_need,c.plan_end_time,c.product_count,c.contract_cash,c.place_contract,c.effect_pj,c.proj_progress,c.star,c.contract_cash_count,c.realcontract_cash,c.contract_mode,c.intexamine_time,c.init_cash,c.endexamine_time,c.end_cash,c.receive_cash_time,c.contract_deposit,c.proj_state,c.back_cash,c.market_commision,c.commision_month,c.feedback,c.remark,c.detail_need,d.avatar as creater_avatar,f.avatar as follow_avatar<include refid="Condition"/></select><sql id="Condition">FROM custom_manage AS aLEFT JOIN project b On b.proj_num=a.proj_numLEFT JOIN proj_agreement c ON c.id =a.agreement_idLEFT JOIN user d On d.user_id=a.create_idLEFT JOIN user f On f.user_id=a.follow_idwhere<if test="customManage!=null and customManage.id !=null and customManage.id !=''">a.id =#{customManage.id}and</if><if test="customManage!=null and customManage.stage !=null and customManage.stage !=''">c.stage likeCONCAT('%',#{customManage.stage}, '%') and</if><if test="customManage!=null and customManage.company !=null and customManage.company !=''">a.company likeCONCAT('%',#{customManage.company}, '%') or</if><if test="customManage!=null and customManage.projName !=null and customManage.projName !=''">b.proj_name likeCONCAT('%',#{customManage.projName}, '%') and</if><if test="customManage!=null and customManage.saleTimeYear !=null and customManage.saleTimeYear !=''">a.sale_time_year likeCONCAT('%',#{customManage.saleTimeYear}, '%') and</if><if test="customManage!=null and customManage.saleTimeMonth !=null and customManage.saleTimeMonth !=''">a.sale_time_month likeCONCAT('%',#{customManage.saleTimeMonth}, '%') and</if><if test="customManage!=null and customManage.followId !=null and customManage.followId !=''">a.follow_id =#{customManage.followId} and</if><if test="customManage!=null and customManage.createId !=null and customManage.createId !=''">a.create_id =#{customManage.createId} and</if><if test="customManage!=null and customManage.userId !=null and customManage.userId !=''">(a.create_id =#{customManage.userId} or a.follow_id = #{customManage.userId}) and</if>a.is_delete=0 and a.idOrder By a.create_time Desc</sql>

總結

以上是生活随笔為你收集整理的枚举中文转数字并easyexcel导入(读取Read)数据至数据库,用监听器解决导入关联多表的问题的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

www.久久免费视频 | 日韩国产欧美在线视频 | 欧亚日韩精品一区二区在线 | 91精品在线免费观看视频 | 又黄又爽又刺激的视频 | 中文字幕在线影视资源 | 欧美极品一区二区三区 | 成人啊 v| 丁香六月婷婷开心婷婷网 | 婷婷精品国产一区二区三区日韩 | 国产精品高清免费在线观看 | 婷婷在线播放 | 久久免费黄色大片 | 色播激情五月 | 国产色婷婷精品综合在线手机播放 | 国产精品久久一区二区无卡 | 中文字幕亚洲欧美日韩2019 | 亚洲国产精品99久久久久久久久 | 美女网站黄在线观看 | 在线精品观看国产 | 日韩在线观看视频在线 | 欧美调教网站 | 亚洲深夜影院 | 成人黄色av免费在线观看 | 成人在线视频你懂的 | 蜜桃视频精品 | 国产精品短视频 | 精品影院一区二区久久久 | 国产精品普通话 | www.久久色| 色婷婷精品大在线视频 | 福利区在线观看 | 区一区二区三在线观看 | 久久精品久久99精品久久 | 免费福利在线视频 | 国产精品一区专区欧美日韩 | 欧美影片 | 日韩av电影网站在线观看 | 国产精品综合久久 | 国产精品亚洲精品 | 国产精品免费观看国产网曝瓜 | 狠狠狠色丁香综合久久天下网 | 久久天天躁夜夜躁狠狠躁2022 | 国产伦精品一区二区三区高清 | 午夜视频免费在线观看 | 国产96在线 | 成人在线观看你懂的 | 精品国产一区二区三区久久 | 亚洲视频免费视频 | 欧美污在线观看 | 超碰97人人爱 | 久久久久激情 | 国产精品久久久久影院日本 | 久久久久网址 | 亚洲欧美日韩精品一区二区 | 中文字幕免费在线看 | 97超在线 | 日韩高清av在线 | 成人av电影在线 | 中字幕视频在线永久在线观看免费 | 国产精品 欧美 日韩 | 蜜臀久久99精品久久久无需会员 | 久久99精品一区二区三区三区 | 日本视频不卡 | 黄色毛片在线观看 | 色五月激情五月 | 久久久精品成人 | 久久久久一区 | 久久国产a | 在线观看日本高清mv视频 | 久久精品视频在线播放 | 久久视影 | 免费a v在线 | 夜夜婷婷| 久艹视频在线免费观看 | 免费av网址在线观看 | 麻豆一区二区三区视频 | 亚洲韩国一区二区三区 | 国产一级片在线播放 | 99久久爱 | 97人人爽 | 在线黄色国产电影 | 亚洲精品视频免费在线观看 | 亚洲成人精品 | 美女在线免费观看视频 | 亚洲精品男人的天堂 | 欧美午夜理伦三级在线观看 | 精品一二三四五区 | 亚洲人成在线观看 | 欧美二区在线播放 | 国产精品一区二区免费视频 | 91中文字幕在线播放 | 欧美一区二区伦理片 | 一区二区三区日韩在线 | 国产成人精品三级 | 99热这里是精品 | 黄色录像av | 日本xxxx.com | 久久久91精品国产一区二区三区 | 一级黄色片在线免费观看 | 成人一级视频在线观看 | 在线视频亚洲 | 亚洲精品乱码久久久久久 | 精品免费久久久久久 | 69久久久| 五月婷婷激情 | 国产手机视频在线播放 | 成人精品福利 | 国产精品毛片一区视频播 | 日韩欧美xx | 91精品播放 | 久久久高清视频 | 国产网红在线观看 | 天堂在线成人 | 一区二区视频播放 | 免费国产在线观看 | 国产精品网红直播 | 少妇高潮流白浆在线观看 | 亚洲精品国产拍在线 | 国模一二三区 | 国产精品视频专区 | a久久久久久 | 午夜久久久精品 | 一级一片免费看 | 中文字幕在线高清 | 国产手机在线 | 国产成人一区二区在线观看 | 欧美日韩在线第一页 | 欧美日韩免费一区 | 成人久久亚洲 | 久久人人精品 | 91精品啪在线观看国产81旧版 | 国产一区在线视频 | 四虎永久免费在线观看 | 欧美精品xxx| 久久精品在线视频 | 国产黄色片久久久 | 一级黄视频| 九九交易行官网 | 国产精品久久久久久久久蜜臀 | 日本精品视频免费 | 久一久久 | 色综合久久五月天 | 九热精品| 视频一区在线免费观看 | 欧美日韩精品在线播放 | 国产精品一区二区三区视频免费 | 日韩精品一卡 | 欧美成人91| 中文字幕在线免费观看视频 | 国产精品1区2区3区在线观看 | 久久狠狠干 | 久草在线视频中文 | 精品av在线播放 | 五月婷婷综合久久 | 丝袜美女在线观看 | 久草视频在线播放 | 国产不卡av在线播放 | 国内精品久久久久久久影视简单 | 久草在线视频看看 | 亚洲午夜精品一区 | 999精品| 久久理论电影网 | 黄色性av | 精品视频久久 | 六月丁香综合网 | 五月天婷婷丁香花 | 亚洲午夜久久久久久久久 | 日韩免费观看高清 | 国产高清不卡一区二区三区 | 国产高清精品在线 | 久久久国产视频 | 婷婷亚洲综合五月天小说 | 亚洲午夜精品久久久久久久久久久久 | 99视频国产精品 | 久草在线免费资源 | 欧美日本三级 | 91在线精品观看 | 在线看一区二区 | 国产视频精品视频 | 中文字幕久久久精品 | 在线免费观看麻豆视频 | 国产涩图 | 在线免费黄色片 | 国产成人一二三 | 色综合久久中文字幕综合网 | 久久免费观看视频 | 在线а√天堂中文官网 | 99精品毛片 | 99国内精品久久久久久久 | 日韩在线观看视频在线 | 丝袜美女在线观看 | 日日婷婷夜日日天干 | 婷婷中文字幕 | 久久五月天婷婷 | 日本婷婷色 | 欧美精品一区二区免费 | 欧美成人免费在线 | 国产视频一区在线播放 | 欧美一区免费观看 | 亚洲一二三在线 | 亚洲第一成网站 | 在线视频欧美日韩 | 亚洲免费高清视频 | 国产精品观看 | 97视频免费在线看 | 久草资源在线观看 | 中文在线a天堂 | 日韩欧美在线影院 | 亚洲国产日韩av | 一区二区三区在线观看免费 | 亚洲精品91天天久久人人 | 波多野结衣在线观看一区 | 五月天色婷婷丁香 | 中文乱幕日产无线码1区 | 国产69精品久久99的直播节目 | 天天操天天谢 | 三级黄色三级 | av电影一区二区三区 | 亚洲天天 | 天天干天天爽 | 精品国产一区二区三区蜜臀 | 视频一区在线播放 | 在线精品视频免费播放 | 国产成人免费网站 | 激情综合色播五月 | 欧美日韩国产一区二 | 99精品视频在线观看 | 久久免费av电影 | 久久福利影视 | 国产日产精品一区二区三区四区的观看方式 | av网站免费在线 | 九九视频在线观看视频6 | 亚洲美女视频在线 | 三日本三级少妇三级99 | 久热爱 | 国产啊v在线观看 | 天天干天天做 | 久久五月天婷婷 | 精品久久久久久亚洲综合网站 | 91看片网址 | 一级α片免费看 | 99re久久资源最新地址 | 欧美二区视频 | 爱爱av网站 | 欧美日韩破处 | 亚洲视频99 | 天天·日日日干 | 91久久精品一区二区三区 | 久久爱992xxoo | 久久综合色天天久久综合图片 | adc在线观看| 欧美伦理电影一区二区 | 国产性xxxx | 91精品一区二区三区久久久久久 | 成人免费观看视频网站 | 国产精品久久在线观看 | 黄网av在线| 久久99精品久久只有精品 | 久久久久免费精品 | 日韩高清免费在线 | 色99网| 成人黄色在线电影 | 福利视频导航网址 | 欧美精品免费在线 | 激情欧美在线观看 | 欧美在线你懂的 | 国产在线观看 | 色综合久久88色综合天天 | 欧洲在线免费视频 | 亚洲免费av一区二区 | 九九免费观看全部免费视频 | 天天操天天射天天爱 | 97视频免费观看 | 国产精品福利在线观看 | 狠狠婷婷 | 免费观看黄 | 国产免费高清视频 | 久久亚洲专区 | 日本中文一区二区 | 四虎影视精品永久在线观看 | 欧美激情h| 天天草天天 | 99免费看片 | av一级片在线观看 | 国产小视频免费在线网址 | 久久久99精品免费观看 | 成人在线观看资源 | 久久精品久久精品久久 | 丰满少妇对白在线偷拍 | 日韩高清在线看 | 亚洲精品视频偷拍 | 免费试看一区 | 99久久99久久精品 | 精品福利片 | 亚洲资源在线观看 | 久久免费成人精品视频 | 97精品国自产拍在线观看 | 国产精品九九久久久久久久 | 狠狠干五月天 | 一区二区观看 | 免费欧美高清视频 | 亚洲成av片人久久久 | 99国产精品一区 | 国产日本亚洲高清 | 国产涩涩在线观看 | 成片免费观看视频 | 亚洲黄色在线免费观看 | 青青河边草免费视频 | 91禁在线看 | 久久精品中文字幕少妇 | 精品国产欧美一区二区 | 欧洲亚洲女同hd | 波多野结衣一区二区 | 99久久99久久综合 | 91伊人久久大香线蕉蜜芽人口 | 久久夜色精品国产欧美乱极品 | 三级动图| 一级黄色片在线播放 | 天天综合成人网 | 97色资源| 欧美孕妇与黑人孕交 | 婷婷色站 | 亚洲撸撸 | 最近日韩中文字幕中文 | 一二三四精品 | 国产一区精品在线观看 | 成人精品久久久 | 91刺激视频| 九九精品久久久 | 国产91在线看 | 国产精品视频专区 | 最新日韩视频在线观看 | 福利一区二区在线 | 色综合久 | 2018亚洲男人天堂 | av无限看| 天天干天天干天天干天天干天天干天天干 | 日韩大片免费观看 | 51久久夜色精品国产麻豆 | 国内精品久久久久久久久久久久 | 最新av观看 | 亚洲 综合 精品 | 天天操天天色天天 | 国产区精品 | 亚洲五月六月 | 黄色av三级在线 | 最新午夜| 亚洲九九九在线观看 | 波多野结衣在线中文字幕 | 亚洲精品午夜国产va久久成人 | 91av在线免费观看 | 国产麻豆精品久久一二三 | 精品国产一区二区三区av性色 | 一级黄视频 | 日本中文字幕观看 | www.com.日本一级| 天天综合五月天 | 日本三级吹潮在线 | 99精品影视| 69久久夜色精品国产69 | 日本亚洲国产 | 一级黄色免费 | 日本韩国精品在线 | 欧美另类色图 | 欧美一区二区三区激情视频 | 日韩色高清 | 日韩视频www| 黄色在线观看污 | 日日夜夜综合网 | 蜜臀一区二区三区精品免费视频 | 香蕉视频网址 | 日韩在线第一 | 国产一区二区网址 | 国产精品久久99综合免费观看尤物 | 天天想夜夜操 | 久草视频免费在线播放 | 久久久亚洲网站 | 国产麻豆精品久久 | 伊人伊成久久人综合网站 | 天天干天天干天天干天天干天天干天天干 | 国产做爰视频 | 91视频啊啊啊 | 日韩在线第一区 | 国产又粗又猛又黄视频 | 天天操天天操 | 国产精品一区二区久久精品爱微奶 | 色视频网页 | 91在线看视频免费 | 日产中文字幕 | 2021国产在线 | 97精品国产一二三产区 | 97在线资源| 午夜精品一区二区三区在线播放 | 精品久久一区二区三区 | 国产成人久久精品77777综合 | 午夜精品视频免费在线观看 | 福利区在线观看 | 热久久精品在线 | 精品国产自在精品国产精野外直播 | 天天艹天天| 99久久久国产精品美女 | 综合亚洲视频 | 最近日本中文字幕 | www.人人草 | 色在线最新 | 国产黄色免费在线观看 | 三级黄免费看 | 在线看成人 | 亚洲一区视频在线播放 | 色婷婷狠狠五月综合天色拍 | 久久久久久久久久久成人 | 亚洲精品乱码久久久久久蜜桃不爽 | 久久综合狠狠综合久久狠狠色综合 | 久久国产精品久久久 | 国产一区在线免费观看 | 91精品一区二区三区蜜臀 | 久久精品中文字幕 | 成 人 黄 色视频免费播放 | 麻豆精品视频在线观看免费 | 成人三级视频 | 99日韩精品| 青青草在久久免费久久免费 | 五月丁香| 色五月成人 | 夜夜狠狠 | 色av色av色av | av一级免费 | 日韩一区二区三免费高清在线观看 | 波多野结衣精品 | 最新国产精品拍自在线播放 | 成人毛片a | 国产精品久久久电影 | 懂色av一区二区在线播放 | 97超碰免费在线观看 | 91女神的呻吟细腰翘臀美女 | 五月天婷婷免费视频 | 中文字幕永久在线 | 欧美国产日韩激情 | 美国av大片 | 久久草草影视免费网 | 欧美一二三在线 | 国产亚洲精品久久久网站好莱 | 中文字幕国产一区二区 | 91尤物在线播放 | 久艹在线播放 | 成人黄色电影视频 | 色婷婷综合成人av | 美州a亚洲一视本频v色道 | 国产精品亚| 欧美另类人妖 | 青青草国产成人99久久 | 国产精品精品视频 | 日韩午夜电影 | 国产亚洲精品bv在线观看 | 精品国产伦一区二区三区观看体验 | 在线观看免费国产小视频 | 精品一区 在线 | 天堂网一区二区三区 | 99视频在线免费观看 | 国产自在线观看 | 精品成人国产 | 丁香婷婷综合激情五月色 | 黄色录像av | 国产电影一区二区三区四区 | 国产免费叼嘿网站免费 | 国产91在线 | 美洲 | 狠狠色丁香婷婷综合视频 | 久久精品免费看 | av福利第一导航 | 精品国产aⅴ麻豆 | 国产一级视频在线观看 | 午夜电影 电影 | 日本公妇色中文字幕 | 欧美日韩高清在线观看 | 成人97视频一区二区 | 国产成人av网 | 国偷自产中文字幕亚洲手机在线 | 精品国产乱码久久久久 | 欧美精品一区在线 | 黄色免费网 | 欧美另类一二三四区 | 在线天堂中文www视软件 | 九九久久国产精品 | 日日夜夜中文字幕 | 日韩欧美不卡 | 亚洲精品视频免费在线观看 | 中文不卡视频在线 | 高清免费av在线 | 欧美成人999 | 91在线免费播放 | 亚洲综合欧美激情 | 五月天六月丁香 | 久草91视频 | 欧美日韩久久不卡 | 久久精品永久免费 | 亚州精品视频 | 91av在线视频免费观看 | 日韩网站中文字幕 | 国产高清一区二区 | www.亚洲精品 | 欧美天堂视频在线 | 国产黄a三级三级三级三级三级 | 亚洲年轻女教师毛茸茸 | 久久综合色婷婷 | 激情五月看片 | 亚洲精品国偷自产在线91正片 | ,午夜性刺激免费看视频 | 国产精品美女久久久免费 | 九色在线视频 | 久久免费公开视频 | 五月婷婷综合在线 | 日韩精品视频在线观看网址 | 精品亚洲国产视频 | 色黄久久久久久 | 91福利在线观看 | 久久第四色 | 国产亚洲精品成人av久久影院 | 国产成人精品av久久 | 久久久久久久久久久久99 | 人人揉人人揉人人揉人人揉97 | 最新国产精品拍自在线播放 | 久草视频国产 | 久久久久久久久久久影院 | 欧美精品亚洲精品 | 精品国产一区二区三区日日嗨 | 中文字幕av电影下载 | 成人影视免费 | 久久久亚洲麻豆日韩精品一区三区 | 久久成人国产 | 美女久久久久久久久久 | 国产日韩欧美在线一区 | 日本视频不卡 | 丁香视频五月 | 欧洲一区精品 | 91精品一区二区三区蜜臀 | 在线看片中文字幕 | 免费亚洲电影 | 96久久| 成人午夜精品福利免费 | 精品视频专区 | 中文字幕欲求不满 | 成人一区不卡 | 天天操夜夜逼 | 成人国产精品久久久春色 | 丁香六月婷婷激情 | av资源中文字幕 | 一区二区影视 | av线上看| 天天艹天天爽 | 欧美精品久久久久性色 | 外国av网| 久久久久久久久久久久久国产精品 | 国产 成人 久久 | 2017狠狠干 | 欧美成人日韩 | 麻豆网站免费观看 | 黄色aaaaa| 成人国产精品免费观看 | 国产成a人亚洲精v品在线观看 | 日韩理论电影在线观看 | 91精品国产麻豆国产自产影视 | 久久av电影 | 欧美性直播 | 91在线资源 | 久久免费的精品国产v∧ | 国产精品久久久久久久久久直播 | 中文字幕资源在线 | 欧美日韩视频一区二区三区 | 一本一本久久a久久精品综合小说 | 日日躁夜夜躁xxxxaaaa | 四虎国产永久在线精品 | 久久黄色成人 | 欧美日韩伦理一区 | 欧美日韩综合在线 | 免费精品视频在线观看 | 91麻豆精品国产91久久久无需广告 | av在线精品 | 免费在线黄色av | 婷婷 中文字幕 | 国产精品美女网站 | 国产精品毛片一区视频播不卡 | 欧美色图亚洲图片 | 日韩精品91偷拍在线观看 | 国产在线观看国语版免费 | 91九色网站| 日韩欧美一区视频 | 亚洲国产成人在线播放 | 欧美久久久久久久久久久久 | 免费看网站在线 | 999久久久久久久久久久 | 国产在线精品一区二区不卡了 | 草在线| 成人黄色电影视频 | a视频免费| 国产午夜三级一区二区三 | 国产精品v欧美精品v日韩 | 五月婷香蕉久色在线看 | 久草免费手机视频 | 麻豆系列在线观看 | 精品福利视频在线 | 97超碰人人网 | 国产精品欧美在线 | 欧美成人精品欧美一级乱 | 亚洲精品在线网站 | 日日碰狠狠躁久久躁综合网 | 国产一区免费视频 | 国产精品免费观看视频 | 日日干视频 | 一区二区视频播放 | 欧美精品三级在线观看 | 国产原创在线视频 | 黄色免费观看视频 | 美女网站视频一区 | 日韩中文在线视频 | 97精品欧美91久久久久久 | 成年人免费看的视频 | 久久精品一区八戒影视 | 亚洲欧美综合精品久久成人 | 99视频精品 | 在线中文字幕电影 | 久久999精品 | 五月婷婷综合在线 | 天天插日日射 | 婷婷综合成人 | 在线视频福利 | 国产精品视频内 | 99久久精品国产欧美主题曲 | 青青河边草免费观看完整版高清 | 婷婷丁香国产 | 天天插天天操天天干 | 欧美一二三区播放 | 久久手机免费观看 | 久久精品九色 | 日韩精品欧美一区 | 91完整版观看 | 伊人天天| 久久久麻豆精品一区二区 | 96视频免费在线观看 | 久久这里有精品 | 亚洲狠狠婷婷综合久久久 | 欧美日韩不卡一区二区三区 | av黄色成人 | 久久久国产精品人人片99精片欧美一 | 蜜臀久久99精品久久久无需会员 | 国产精品高潮在线观看 | 日韩免费在线视频观看 | 欧美一级在线 | 成年人看片| 中文字幕精品在线 | 97在线公开视频 | 国产成人精品亚洲日本在线观看 | 免费视频xnxx com | 久草视频免费在线播放 | 亚洲黄色片一级 | 国产精品嫩草影院9 | 欧美日韩另类视频 | 欧美日韩国产高清视频 | 国产视频一区精品 | 亚洲aaa级| 91丨九色丨蝌蚪丨老版 | 中午字幕在线观看 | 又色又爽的网站 | 久久精品香蕉 | 国色天香第二季 | 久久久精品一区二区三区 | 色婷av | 日本精品视频在线观看 | 久久久福利视频 | 激情综合啪啪 | 嫩草av在线 | 国产日产精品一区二区三区四区 | 日韩精品免费在线观看 | 久久久免费观看完整版 | 国产精品2区 | 在线看片一区 | 天天天色 | 精选久久 | 色综合天天| 91精品色| 色天天中文 | 青青河边草手机免费 | 免费a级大片 | 五月激情亚洲 | 中文字幕永久在线 | 在线免费av播放 | 黄污污网站 | 欧洲精品一区二区 | 久久精品免费电影 | 97免费在线观看视频 | 欧美一区中文字幕 | 亚洲aⅴ一区二区三区 | 四虎海外影库www4hu | 成年人在线看视频 | 久久福利小视频 | 久久综合五月 | 999久久久久久久久6666 | 天堂av中文字幕 | 欧美日韩视频免费看 | 国产精品久久久久一区二区三区 | 精品一区二三区 | 午夜av网站 | av综合av| 国产又粗又硬又爽视频 | 亚洲一区二区观看 | 免费观看黄| 二区三区在线视频 | 成人一级在线观看 | 亚洲视频1| 91大神精品视频在线观看 | 久久久网站 | 一级成人网| 日本精品xxxx| 胖bbbb搡bbbb擦bbbb | 日韩精品一区二区三区免费视频观看 | 中文在线天堂资源 | 日韩在线观看免费 | 久久热亚洲 | 久久久久成人精品免费播放动漫 | 免费观看的av网站 | 在线观看免费 | 在线成人性视频 | 四虎成人网 | 午夜久久视频 | 亚洲欧美观看 | 国产高清视频在线观看 | 成人小视频免费在线观看 | 成人91免费视频 | 国产精品久久久久久久久久了 | 欧美成年黄网站色视频 | 国产色婷婷精品综合在线手机播放 | av手机版| 国产精品 日韩精品 | 日韩网站在线免费观看 | 国产免费视频一区二区裸体 | 精产嫩模国品一二三区 | 成人av片在线观看 | 日本久久中文 | 中文字幕一区二区三区在线播放 | a极黄色片 | 成人黄色毛片 | 五月婷婷黄色 | 日韩精品综合在线 | 91av蜜桃| 国产真实精品久久二三区 | 精品视频在线观看 | 中文伊人 | 成人黄色大片 | 久久久穴 | 国内精品在线一区 | 国精产品999国精产 久久久久 | 久久五月天色综合 | 五月激情丁香图片 | 成人久久网 | 国产色拍拍拍拍在线精品 | 91插插影库 | 中文在线a天堂 | 99久久久久免费精品国产 | 玖玖视频精品 | 久久网站免费 | 中文字幕之中文字幕 | 少妇超碰在线 | 欧美一区二区在线刺激视频 | 亚洲高清91 | 黄污网 | 91中文字幕 | 国产精品久久久久婷婷二区次 | 91av大全| 亚洲精品国产日韩 | 日日爽夜夜爽 | 韩国在线视频一区 | 欧美一级专区免费大片 | 69国产在线观看 | 青青草国产精品视频 | 国产不卡免费av | 亚洲视频久久久 | 精品产品国产在线不卡 | 国产精品手机视频 | 99视频在线观看免费 | 看片网站黄色 | 欧美乱码精品一区二区 | 日本久久91| 亚洲精品高清在线观看 | 亚洲精品国产精品国自产观看浪潮 | 五月天网站在线 | 久久久久久久精 | 在线免费中文字幕 | 中文字幕亚洲情99在线 | 天天草天天爽 | 国产免费激情久久 | 国产系列 在线观看 | 国产小视频在线免费观看 | 日韩二区三区在线观看 | 国产黄a三级三级三级三级三级 | 国产一区私人高清影院 | 91在线精品一区二区 | 日韩资源在线播放 | 久草在线视频看看 | 色综合天天天天做夜夜夜夜做 | 丝袜美腿一区 | 久久久久久久久久久久电影 | 99久久日韩精品免费热麻豆美女 | 天天爽夜夜爽人人爽一区二区 | 日本中文字幕在线一区 | 日韩视频免费在线 | 在线观看a视频 | 久久网站免费 | 手机在线欧美 | 日韩在线免费播放 | 免费a视频 | 国产视 | 久久午夜精品影院一区 | 婷婷在线看 | 国产精品久久久久av免费 | 日本99精品 | 伊人永久 | 毛片无卡免费无播放器 | 久久久综合九色合综国产精品 | 日韩av片无码一区二区不卡电影 | 国产亚洲精品成人av久久ww | 婷婷丁香激情 | 久久久久免费看 | www天天干com | a精品视频 | 中文字幕日韩有码 | 99中文字幕| 在线免费观看羞羞视频 | 久久精品99国产精品亚洲最刺激 | 国产伦精品一区二区三区… | 蜜臀av网站| 福利一区在线视频 | www.福利| 综合久久久久久 | 91麻豆高清视频 | 久久在线观看 | www在线观看视频 | 亚洲国内精品在线 | 婷婷激情综合五月天 | 日韩不卡高清 | 久久国产精品久久w女人spa | 国产一二三在线视频 | 欧美色插 | 免费网站看v片在线a | 久草在线国产 | www.精选视频.com | 欧美精品一区二区在线观看 | 在线观看片 | 五月婷久 | 六月婷色 | 久久久亚洲国产精品麻豆综合天堂 | 99久久久久成人国产免费 | 99视频在线播放 | 国产尤物在线视频 | 日韩影视在线 | 欧美日韩国产mv | 国产精品毛片一区二区在线 | 国产 日韩 欧美 中文 在线播放 | 国产精品3区 | 一区二区三区日韩视频在线观看 | 亚洲欧美成人在线 | 精品久久九九 | 在线观看午夜 | 西西人体www444 | 国产免费成人 | 亚洲成av人片 | 亚洲第一成网站 | 人人插人人看 | 天天射射天天 | 丁香网五月天 | 国产美女视频黄a视频免费 久久综合九色欧美综合狠狠 | 欧美激情综合五月色丁香 | 视色网站 | 在线看v片成人 | 99色免费视频 | 五月婷婷精品 | 亚洲精品9| 亚洲一区尤物 | 93久久精品日日躁夜夜躁欧美 | 在线观看中文字幕第一页 | 亚洲精品久久久久中文字幕m男 | 欧美一级电影在线观看 | 狠狠搞,com | 精品国产人成亚洲区 | 国产一级大片免费看 | 99riav1国产精品视频 | 亚洲午夜精品一区二区三区电影院 | 久久视频在线观看 | 午夜黄色一级片 | 激情深爱.com | 日韩精品无码一区二区三区 | 免费瑟瑟网站 | 国产成人久久精品一区二区三区 | 黄色一级片视频 | 激情开心站 | 久久久久国产精品免费 | 日韩免费观看一区二区 | 国产淫片免费看 | 国产成人性色生活片 | 欧美在线一 | 国产一级视频在线免费观看 | 久久69精品 | 久久久久久久久久久久国产精品 | 免费高清在线观看电视网站 | 日本乱视频 | 精品国产诱惑 | 亚洲成a人片在线www | 91成人网页版 | 中文乱幕日产无线码1区 | 精品99视频| 手机av在线免费观看 | 久射网 | 免费在线观看a v | 91香蕉视频黄色 | 在线一二三四区 | 成人在线免费观看网站 | 日韩a级黄色| 国产一级黄色电影 | 色狠狠综合 | 免费午夜网站 | 91精品办公室少妇高潮对白 | 午夜性盈盈| 色综合久久五月 | 99热精品免费观看 | 黄色免费网站下载 | 波多野结衣亚洲一区二区 | 美女网色 | 欧美一级免费 | 久久久色 | 日日夜夜天天久久 | 亚洲 综合 精品 | 久久久久久草 | 国内精品久久久久久 | 欧美精品小视频 | 中文字幕在线免费看 | 韩日视频在线 | 国产99久久久精品 | 亚洲精品国产视频 | 国产精品成| av电影免费在线播放 | 91九色在线 | 天天搞天天 | 亚洲精品视频在线免费 | 激情网站五月天 | 婷婷午夜激情 | 日韩欧美一区二区三区黑寡妇 | 午夜狠狠干 | 91久久国产综合精品女同国语 | 免费在线一区二区三区 | 六月丁香综合 | 在线观看av国产 | 日韩在线视频二区 | 国产黄色精品在线观看 | 在线高清av | 亚洲精品大全 | 人人揉人人揉人人揉人人揉97 | av免费在线观 | 精品久久久久久久久久 | 九九九九九九精品任你躁 | 久久久人人人 | av在线一二三区 | 欧美色操 | 色吊丝在线永久观看最新版本 | 在线中文字幕电影 | 开心丁香婷婷深爱五月 | 美女视频永久黄网站免费观看国产 | 国产一性一爱一乱一交 | 视频福利在线观看 | 超碰人人超 | 久久久久综合网 | 国产不卡在线观看 | 久久久蜜桃一区二区 | 成人啪啪18免费游戏链接 | 国内精品在线看 | 久久视频在线观看 | 国产精品乱码久久久 | 午夜精品一区二区三区在线视频 | 色狠狠综合天天综合综合 | 日韩com| 成人性生交大片免费观看网站 | 成人午夜剧场在线观看 | 首页av在线 | 久久久久国产精品一区二区 | 三级av网| 国产黄色av | 国产精品丝袜 | 欧美视频国产视频 | 日韩欧美综合 | 91高清在线 | 在线观看91视频 | 久久久久久电影 | 欧美日韩国内在线 | 天天精品视频 | 三级av网站| 亚洲色五月 | 天天操天天添天天吹 | 综合网在线视频 | av免费观看网址 | 久久久久久久久艹 |