dzx 1 рік тому
батько
коміт
26abdcf821
19 змінених файлів з 1437 додано та 0 видалено
  1. 108 0
      src/main/java/com/xjrsoft/module/textbook/controller/TextbookController.java
  2. 43 0
      src/main/java/com/xjrsoft/module/textbook/dto/AddTextbookClassRelationDto.java
  3. 130 0
      src/main/java/com/xjrsoft/module/textbook/dto/AddTextbookDto.java
  4. 43 0
      src/main/java/com/xjrsoft/module/textbook/dto/AddTextbookSubscriptionRecordDto.java
  5. 37 0
      src/main/java/com/xjrsoft/module/textbook/dto/TextbookPageDto.java
  6. 34 0
      src/main/java/com/xjrsoft/module/textbook/dto/UpdateTextbookDto.java
  7. 182 0
      src/main/java/com/xjrsoft/module/textbook/entity/Textbook.java
  8. 93 0
      src/main/java/com/xjrsoft/module/textbook/entity/TextbookClassRelation.java
  9. 93 0
      src/main/java/com/xjrsoft/module/textbook/entity/TextbookSubscriptionRecord.java
  10. 17 0
      src/main/java/com/xjrsoft/module/textbook/mapper/TextbookClassRelationMapper.java
  11. 27 0
      src/main/java/com/xjrsoft/module/textbook/mapper/TextbookMapper.java
  12. 17 0
      src/main/java/com/xjrsoft/module/textbook/mapper/TextbookSubscriptionRecordMapper.java
  13. 50 0
      src/main/java/com/xjrsoft/module/textbook/service/ITextbookService.java
  14. 133 0
      src/main/java/com/xjrsoft/module/textbook/service/impl/TextbookServiceImpl.java
  15. 44 0
      src/main/java/com/xjrsoft/module/textbook/vo/TextbookClassRelationVo.java
  16. 163 0
      src/main/java/com/xjrsoft/module/textbook/vo/TextbookPageVo.java
  17. 44 0
      src/main/java/com/xjrsoft/module/textbook/vo/TextbookSubscriptionRecordVo.java
  18. 131 0
      src/main/java/com/xjrsoft/module/textbook/vo/TextbookVo.java
  19. 48 0
      src/test/java/com/xjrsoft/xjrsoftboot/FreeMarkerGeneratorTest.java

+ 108 - 0
src/main/java/com/xjrsoft/module/textbook/controller/TextbookController.java

@@ -0,0 +1,108 @@
+package com.xjrsoft.module.textbook.controller;
+
+import cn.dev33.satoken.annotation.SaCheckPermission;
+import cn.hutool.core.bean.BeanUtil;
+import com.alibaba.excel.EasyExcel;
+import com.alibaba.excel.support.ExcelTypeEnum;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.xjrsoft.common.model.result.RT;
+import com.xjrsoft.common.page.ConventPage;
+import com.xjrsoft.common.page.PageOutput;
+import com.xjrsoft.module.textbook.dto.AddTextbookDto;
+import com.xjrsoft.module.textbook.dto.TextbookPageDto;
+import com.xjrsoft.module.textbook.dto.UpdateTextbookDto;
+import com.xjrsoft.module.textbook.entity.Textbook;
+import com.xjrsoft.module.textbook.service.ITextbookService;
+import com.xjrsoft.module.textbook.vo.TextbookPageVo;
+import com.xjrsoft.module.textbook.vo.TextbookVo;
+import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiOperation;
+import lombok.AllArgsConstructor;
+import org.springframework.http.ResponseEntity;
+import org.springframework.web.bind.annotation.DeleteMapping;
+import org.springframework.web.bind.annotation.GetMapping;
+import org.springframework.web.bind.annotation.PostMapping;
+import org.springframework.web.bind.annotation.PutMapping;
+import org.springframework.web.bind.annotation.RequestBody;
+import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RequestParam;
+import org.springframework.web.bind.annotation.RestController;
+
+import javax.validation.Valid;
+import java.io.ByteArrayOutputStream;
+import java.util.ArrayList;
+import java.util.List;
+
+/**
+* @title: 教材管理
+* @Author dzx
+* @Date: 2023-12-25
+* @Version 1.0
+*/
+@RestController
+@RequestMapping("/textbook" + "/textbook")
+@Api(value = "/textbook"  + "/textbook",tags = "教材管理代码")
+@AllArgsConstructor
+public class TextbookController {
+
+
+    private final ITextbookService textbookService;
+
+    @GetMapping(value = "/page")
+    @ApiOperation(value="教材管理列表(分页)")
+    @SaCheckPermission("textbook:detail")
+    public RT<PageOutput<TextbookPageVo>> page(@Valid TextbookPageDto dto){
+        Page<TextbookPageVo> page = textbookService.getPage(new Page<>(dto.getLimit(), dto.getSize()), dto);
+        PageOutput<TextbookPageVo> pageOutput = ConventPage.getPageOutput(page, TextbookPageVo.class);
+        return RT.ok(pageOutput);
+    }
+
+    @GetMapping(value = "/info")
+    @ApiOperation(value="根据id查询教材管理信息")
+    @SaCheckPermission("textbook:detail")
+    public RT<TextbookVo> info(@RequestParam Long id){
+        Textbook textbook = textbookService.getByIdDeep(id);
+        if (textbook == null) {
+           return RT.error("找不到此数据!");
+        }
+        return RT.ok(BeanUtil.toBean(textbook, TextbookVo.class));
+    }
+
+
+    @PostMapping
+    @ApiOperation(value = "新增教材管理")
+    @SaCheckPermission("textbook:add")
+    public RT<Boolean> add(@Valid @RequestBody AddTextbookDto dto){
+        Textbook textbook = BeanUtil.toBean(dto, Textbook.class);
+        boolean isSuccess = textbookService.add(textbook);
+    return RT.ok(isSuccess);
+    }
+
+    @PutMapping
+    @ApiOperation(value = "修改教材管理")
+    @SaCheckPermission("textbook:edit")
+    public RT<Boolean> update(@Valid @RequestBody UpdateTextbookDto dto){
+
+        Textbook textbook = BeanUtil.toBean(dto, Textbook.class);
+        return RT.ok(textbookService.update(textbook));
+
+    }
+
+    @DeleteMapping
+    @ApiOperation(value = "删除教材管理")
+    @SaCheckPermission("textbook:delete")
+    public RT<Boolean> delete(@Valid @RequestBody List<Long> ids){
+        return RT.ok(textbookService.delete(ids));
+
+    }
+
+    @GetMapping("/export")
+    @ApiOperation(value = "导出")
+    public ResponseEntity<byte[]> exportData(@Valid TextbookPageDto dto, @RequestParam(defaultValue = "false") Boolean isTemplate) {
+        List<TextbookPageVo> customerList = isTemplate != null && isTemplate ? new ArrayList<>() : ((PageOutput<TextbookPageVo>) page(dto).getData()).getList();
+        ByteArrayOutputStream bot = new ByteArrayOutputStream();
+        EasyExcel.write(bot, TextbookPageVo.class).automaticMergeHead(false).excelType(ExcelTypeEnum.XLSX).sheet().doWrite(customerList);
+
+        return RT.fileStream(bot.toByteArray(), "Textbook" + ExcelTypeEnum.XLSX.getValue());
+    }
+}

+ 43 - 0
src/main/java/com/xjrsoft/module/textbook/dto/AddTextbookClassRelationDto.java

@@ -0,0 +1,43 @@
+package com.xjrsoft.module.textbook.dto;
+
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+import java.io.Serializable;
+import com.fasterxml.jackson.annotation.JsonFormat;
+
+import java.time.LocalTime;
+import java.time.LocalDateTime;
+import java.math.BigDecimal;
+import java.util.List;
+import java.util.Date;
+
+
+
+/**
+* @title: 教材教辅班级引用
+* @Author szs
+* @Date: 2023-12-25
+* @Version 1.0
+*/
+@Data
+public class AddTextbookClassRelationDto implements Serializable {
+
+    private static final long serialVersionUID = 1L;
+
+    /**
+    * 序号
+    */
+    @ApiModelProperty("序号")
+    private Integer sortCode;
+    /**
+    * 教材管理编号
+    */
+    @ApiModelProperty("教材管理编号")
+    private Long textbookId;
+    /**
+    * 班级编号
+    */
+    @ApiModelProperty("班级编号")
+    private Long classId;
+
+}

+ 130 - 0
src/main/java/com/xjrsoft/module/textbook/dto/AddTextbookDto.java

@@ -0,0 +1,130 @@
+package com.xjrsoft.module.textbook.dto;
+
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+import java.io.Serializable;
+import com.fasterxml.jackson.annotation.JsonFormat;
+
+import java.time.LocalTime;
+import java.time.LocalDateTime;
+import java.math.BigDecimal;
+import java.util.List;
+import java.util.Date;
+import com.xjrsoft.module.textbook.entity.TextbookClassRelation;
+import com.xjrsoft.module.textbook.entity.TextbookSubscriptionRecord;
+
+
+
+/**
+* @title: 教材管理
+* @Author szs
+* @Date: 2023-12-25
+* @Version 1.0
+*/
+@Data
+public class AddTextbookDto implements Serializable {
+
+    private static final long serialVersionUID = 1L;
+
+    /**
+    * 序号
+    */
+    @ApiModelProperty("序号")
+    private Integer sortCode;
+    /**
+    * 国际标准刊号
+    */
+    @ApiModelProperty("国际标准刊号")
+    private String issn;
+    /**
+    * 国际标准书号
+    */
+    @ApiModelProperty("国际标准书号")
+    private String isbn;
+    /**
+    * 书名
+    */
+    @ApiModelProperty("书名")
+    private String bookName;
+    /**
+    * 出版社
+    */
+    @ApiModelProperty("出版社")
+    private String publishingHouse;
+    /**
+    * 主编
+    */
+    @ApiModelProperty("主编")
+    private String editorInChief;
+    /**
+    * 学科组管理编号(subject_group)
+    */
+    @ApiModelProperty("学科组管理编号(subject_group)")
+    private Long subjectGroupId;
+    /**
+    * 学期ID(base_semester)
+    */
+    @ApiModelProperty("学期ID(base_semester)")
+    private Long baseSemesterId;
+    /**
+    * 课程编号(base_course_subject)
+    */
+    @ApiModelProperty("课程编号(base_course_subject)")
+    private Long courseSubjectId;
+    /**
+    * 版本
+    */
+    @ApiModelProperty("版本")
+    private String version;
+    /**
+    * 是否为规划教材(xjr_dictionary_item[judgment_method_1])
+    */
+    @ApiModelProperty("是否为规划教材(xjr_dictionary_item[judgment_method_1])")
+    private String isTextbookPlan;
+    /**
+    * 教材类型(xjr_dictionary_item[textbook_type])
+    */
+    @ApiModelProperty("教材类型(xjr_dictionary_item[textbook_type])")
+    private String textbookType;
+    /**
+    * 规格型号
+    */
+    @ApiModelProperty("规格型号")
+    private String specificationsModels;
+    /**
+    * 估价(元)
+    */
+    @ApiModelProperty("估价(元)")
+    private BigDecimal appraisalPrice;
+    /**
+    * 定价(元)
+    */
+    @ApiModelProperty("定价(元)")
+    private BigDecimal price;
+    /**
+    * 折扣
+    */
+    @ApiModelProperty("折扣")
+    private Double discount;
+    /**
+    * 小计(元)
+    */
+    @ApiModelProperty("小计(元)")
+    private BigDecimal subtotal;
+    /**
+    * 库存
+    */
+    @ApiModelProperty("库存")
+    private Integer stock;
+
+    /**
+    * textbookClassRelation
+    */
+    @ApiModelProperty("textbookClassRelation子表")
+    private List<AddTextbookClassRelationDto> textbookClassRelationList;
+    /**
+    * textbookSubscriptionRecord
+    */
+    @ApiModelProperty("textbookSubscriptionRecord子表")
+    private List<AddTextbookSubscriptionRecordDto> textbookSubscriptionRecordList;
+}

+ 43 - 0
src/main/java/com/xjrsoft/module/textbook/dto/AddTextbookSubscriptionRecordDto.java

@@ -0,0 +1,43 @@
+package com.xjrsoft.module.textbook.dto;
+
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+import java.io.Serializable;
+import com.fasterxml.jackson.annotation.JsonFormat;
+
+import java.time.LocalTime;
+import java.time.LocalDateTime;
+import java.math.BigDecimal;
+import java.util.List;
+import java.util.Date;
+
+
+
+/**
+* @title: 教材教辅征订记录
+* @Author szs
+* @Date: 2023-12-25
+* @Version 1.0
+*/
+@Data
+public class AddTextbookSubscriptionRecordDto implements Serializable {
+
+    private static final long serialVersionUID = 1L;
+
+    /**
+    * 序号
+    */
+    @ApiModelProperty("序号")
+    private Integer sortCode;
+    /**
+    * 教材管理编号
+    */
+    @ApiModelProperty("教材管理编号")
+    private Long textbookId;
+    /**
+    * 教材教辅征订编号
+    */
+    @ApiModelProperty("教材教辅征订编号")
+    private Long wfTextbookSubscriptionId;
+
+}

+ 37 - 0
src/main/java/com/xjrsoft/module/textbook/dto/TextbookPageDto.java

@@ -0,0 +1,37 @@
+package com.xjrsoft.module.textbook.dto;
+
+import com.xjrsoft.common.page.PageInput;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+import lombok.EqualsAndHashCode;
+import org.springframework.format.annotation.DateTimeFormat;
+
+import java.time.LocalTime;
+import java.time.LocalDateTime;
+import java.math.BigDecimal;
+import java.util.Date;
+
+
+/**
+* @title: 教材管理分页查询入参
+* @Author szs
+* @Date: 2023-12-25
+* @Version 1.0
+*/
+@Data
+@EqualsAndHashCode(callSuper = false)
+public class TextbookPageDto extends PageInput {
+
+    @ApiModelProperty("教材类型")
+    public String textbook_type;
+
+    @ApiModelProperty("学期id")
+    public Long base_semester_id;
+
+    @ApiModelProperty("学科id")
+    public Long subject_group_id;
+
+    @ApiModelProperty("课程id")
+    public Long course_subject_id;
+
+}

+ 34 - 0
src/main/java/com/xjrsoft/module/textbook/dto/UpdateTextbookDto.java

@@ -0,0 +1,34 @@
+package com.xjrsoft.module.textbook.dto;
+
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+import java.io.Serializable;
+
+import java.time.LocalTime;
+import java.time.LocalDateTime;
+import java.math.BigDecimal;
+import com.fasterxml.jackson.annotation.JsonFormat;
+import java.util.List;
+import java.util.Date;
+import com.xjrsoft.module.textbook.entity.TextbookClassRelation;
+import com.xjrsoft.module.textbook.entity.TextbookSubscriptionRecord;
+
+
+
+/**
+* @title: 教材管理
+* @Author szs
+* @Date: 2023-12-25
+* @Version 1.0
+*/
+@Data
+public class UpdateTextbookDto extends AddTextbookDto {
+
+    private static final long serialVersionUID = 1L;
+
+    /**
+    * 主键编号
+    */
+    @ApiModelProperty("主键编号")
+    private Long id;
+}

+ 182 - 0
src/main/java/com/xjrsoft/module/textbook/entity/Textbook.java

@@ -0,0 +1,182 @@
+package com.xjrsoft.module.textbook.entity;
+
+import com.baomidou.mybatisplus.annotation.FieldFill;
+import com.baomidou.mybatisplus.annotation.TableField;
+import com.baomidou.mybatisplus.annotation.TableLogic;
+import com.baomidou.mybatisplus.annotation.TableName;
+import com.baomidou.mybatisplus.annotation.TableId;
+import com.github.yulichang.annotation.EntityMapping;
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+import java.io.Serializable;
+import java.time.LocalTime;
+import java.time.LocalDateTime;
+import java.math.BigDecimal;
+import java.util.List;
+import java.util.Date;
+
+
+/**
+* @title: 教材管理
+* @Author szs
+* @Date: 2023-12-25
+* @Version 1.0
+*/
+@Data
+@TableName("textbook")
+@ApiModel(value = "textbook", description = "教材管理")
+public class Textbook implements Serializable {
+
+    private static final long serialVersionUID = 1L;
+
+    /**
+    * 主键编号
+    */
+    @ApiModelProperty("主键编号")
+    @TableId
+    private Long id;
+    /**
+    * 创建人
+    */
+    @ApiModelProperty("创建人")
+    @TableField(fill = FieldFill.INSERT)
+    private Long createUserId;
+    /**
+    * 创建时间
+    */
+    @ApiModelProperty("创建时间")
+    @TableField(fill = FieldFill.INSERT)
+    private Date createDate;
+    /**
+    * 修改人
+    */
+    @ApiModelProperty("修改人")
+    @TableField(fill = FieldFill.UPDATE)
+    private Long modifyUserId;
+    /**
+    * 修改时间
+    */
+    @ApiModelProperty("修改时间")
+    @TableField(fill = FieldFill.UPDATE)
+    private Date modifyDate;
+    /**
+    * 删除标记
+    */
+    @ApiModelProperty("删除标记")
+    @TableField(fill = FieldFill.INSERT)
+    @TableLogic
+    private Integer deleteMark;
+    /**
+    * 有效标志
+    */
+    @ApiModelProperty("有效标志")
+    @TableField(fill = FieldFill.INSERT)
+    private Integer enabledMark;
+    /**
+    * 序号
+    */
+    @ApiModelProperty("序号")
+    private Integer sortCode;
+    /**
+    * 国际标准刊号
+    */
+    @ApiModelProperty("国际标准刊号")
+    private String issn;
+    /**
+    * 国际标准书号
+    */
+    @ApiModelProperty("国际标准书号")
+    private String isbn;
+    /**
+    * 书名
+    */
+    @ApiModelProperty("书名")
+    private String bookName;
+    /**
+    * 出版社
+    */
+    @ApiModelProperty("出版社")
+    private String publishingHouse;
+    /**
+    * 主编
+    */
+    @ApiModelProperty("主编")
+    private String editorInChief;
+    /**
+    * 学科组管理编号(subject_group)
+    */
+    @ApiModelProperty("学科组管理编号(subject_group)")
+    private Long subjectGroupId;
+    /**
+    * 学期ID(base_semester)
+    */
+    @ApiModelProperty("学期ID(base_semester)")
+    private Long baseSemesterId;
+    /**
+    * 课程编号(base_course_subject)
+    */
+    @ApiModelProperty("课程编号(base_course_subject)")
+    private Long courseSubjectId;
+    /**
+    * 版本
+    */
+    @ApiModelProperty("版本")
+    private String version;
+    /**
+    * 是否为规划教材(xjr_dictionary_item[judgment_method_1])
+    */
+    @ApiModelProperty("是否为规划教材(xjr_dictionary_item[judgment_method_1])")
+    private String isTextbookPlan;
+    /**
+    * 教材类型(xjr_dictionary_item[textbook_type])
+    */
+    @ApiModelProperty("教材类型(xjr_dictionary_item[textbook_type])")
+    private String textbookType;
+    /**
+    * 规格型号
+    */
+    @ApiModelProperty("规格型号")
+    private String specificationsModels;
+    /**
+    * 估价(元)
+    */
+    @ApiModelProperty("估价(元)")
+    private BigDecimal appraisalPrice;
+    /**
+    * 定价(元)
+    */
+    @ApiModelProperty("定价(元)")
+    private BigDecimal price;
+    /**
+    * 折扣
+    */
+    @ApiModelProperty("折扣")
+    private Double discount;
+    /**
+    * 小计(元)
+    */
+    @ApiModelProperty("小计(元)")
+    private BigDecimal subtotal;
+    /**
+    * 库存
+    */
+    @ApiModelProperty("库存")
+    private Integer stock;
+
+    /**
+    * textbookClassRelation
+    */
+    @ApiModelProperty("textbookClassRelation子表")
+    @TableField(exist = false)
+    @EntityMapping(thisField = "id", joinField = "textbookId")
+    private List<TextbookClassRelation> textbookClassRelationList;
+    /**
+    * textbookSubscriptionRecord
+    */
+    @ApiModelProperty("textbookSubscriptionRecord子表")
+    @TableField(exist = false)
+    @EntityMapping(thisField = "id", joinField = "wfTextbookSubscriptionId")
+    private List<TextbookSubscriptionRecord> textbookSubscriptionRecordList;
+
+}

+ 93 - 0
src/main/java/com/xjrsoft/module/textbook/entity/TextbookClassRelation.java

@@ -0,0 +1,93 @@
+package com.xjrsoft.module.textbook.entity;
+
+import com.baomidou.mybatisplus.annotation.FieldFill;
+import com.baomidou.mybatisplus.annotation.TableField;
+import com.baomidou.mybatisplus.annotation.TableLogic;
+import com.baomidou.mybatisplus.annotation.TableName;
+import com.baomidou.mybatisplus.annotation.TableId;
+import com.github.yulichang.annotation.EntityMapping;
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+import java.io.Serializable;
+import java.time.LocalTime;
+import java.time.LocalDateTime;
+import java.math.BigDecimal;
+import java.util.List;
+import java.util.Date;
+
+
+/**
+* @title: 教材教辅班级引用
+* @Author szs
+* @Date: 2023-12-25
+* @Version 1.0
+*/
+@Data
+@TableName("textbook_class_relation")
+@ApiModel(value = "textbook_class_relation", description = "教材教辅班级引用")
+public class TextbookClassRelation implements Serializable {
+
+    private static final long serialVersionUID = 1L;
+
+    /**
+    * 主键编号
+    */
+    @ApiModelProperty("主键编号")
+    @TableId
+    private Long id;
+    /**
+    * 创建人
+    */
+    @ApiModelProperty("创建人")
+    @TableField(fill = FieldFill.INSERT)
+    private Long createUserId;
+    /**
+    * 创建时间
+    */
+    @ApiModelProperty("创建时间")
+    @TableField(fill = FieldFill.INSERT)
+    private Date createDate;
+    /**
+    * 修改人
+    */
+    @ApiModelProperty("修改人")
+    @TableField(fill = FieldFill.UPDATE)
+    private Long modifyUserId;
+    /**
+    * 修改时间
+    */
+    @ApiModelProperty("修改时间")
+    @TableField(fill = FieldFill.UPDATE)
+    private Date modifyDate;
+    /**
+    * 删除标记
+    */
+    @ApiModelProperty("删除标记")
+    @TableField(fill = FieldFill.INSERT)
+    @TableLogic
+    private Integer deleteMark;
+    /**
+    * 有效标志
+    */
+    @ApiModelProperty("有效标志")
+    @TableField(fill = FieldFill.INSERT)
+    private Integer enabledMark;
+    /**
+    * 序号
+    */
+    @ApiModelProperty("序号")
+    private Integer sortCode;
+    /**
+    * 教材管理编号
+    */
+    @ApiModelProperty("教材管理编号")
+    private Long textbookId;
+    /**
+    * 班级编号
+    */
+    @ApiModelProperty("班级编号")
+    private Long classId;
+
+
+}

+ 93 - 0
src/main/java/com/xjrsoft/module/textbook/entity/TextbookSubscriptionRecord.java

@@ -0,0 +1,93 @@
+package com.xjrsoft.module.textbook.entity;
+
+import com.baomidou.mybatisplus.annotation.FieldFill;
+import com.baomidou.mybatisplus.annotation.TableField;
+import com.baomidou.mybatisplus.annotation.TableLogic;
+import com.baomidou.mybatisplus.annotation.TableName;
+import com.baomidou.mybatisplus.annotation.TableId;
+import com.github.yulichang.annotation.EntityMapping;
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+import java.io.Serializable;
+import java.time.LocalTime;
+import java.time.LocalDateTime;
+import java.math.BigDecimal;
+import java.util.List;
+import java.util.Date;
+
+
+/**
+* @title: 教材教辅征订记录
+* @Author szs
+* @Date: 2023-12-25
+* @Version 1.0
+*/
+@Data
+@TableName("textbook_subscription_record")
+@ApiModel(value = "textbook_subscription_record", description = "教材教辅征订记录")
+public class TextbookSubscriptionRecord implements Serializable {
+
+    private static final long serialVersionUID = 1L;
+
+    /**
+    * 主键编号
+    */
+    @ApiModelProperty("主键编号")
+    @TableId
+    private Long id;
+    /**
+    * 创建人
+    */
+    @ApiModelProperty("创建人")
+    @TableField(fill = FieldFill.INSERT)
+    private Long createUserId;
+    /**
+    * 创建时间
+    */
+    @ApiModelProperty("创建时间")
+    @TableField(fill = FieldFill.INSERT)
+    private Date createDate;
+    /**
+    * 修改人
+    */
+    @ApiModelProperty("修改人")
+    @TableField(fill = FieldFill.UPDATE)
+    private Long modifyUserId;
+    /**
+    * 修改时间
+    */
+    @ApiModelProperty("修改时间")
+    @TableField(fill = FieldFill.UPDATE)
+    private Date modifyDate;
+    /**
+    * 删除标记
+    */
+    @ApiModelProperty("删除标记")
+    @TableField(fill = FieldFill.INSERT)
+    @TableLogic
+    private Integer deleteMark;
+    /**
+    * 有效标志
+    */
+    @ApiModelProperty("有效标志")
+    @TableField(fill = FieldFill.INSERT)
+    private Integer enabledMark;
+    /**
+    * 序号
+    */
+    @ApiModelProperty("序号")
+    private Integer sortCode;
+    /**
+    * 教材管理编号
+    */
+    @ApiModelProperty("教材管理编号")
+    private Long textbookId;
+    /**
+    * 教材教辅征订编号
+    */
+    @ApiModelProperty("教材教辅征订编号")
+    private Long wfTextbookSubscriptionId;
+
+
+}

+ 17 - 0
src/main/java/com/xjrsoft/module/textbook/mapper/TextbookClassRelationMapper.java

@@ -0,0 +1,17 @@
+package com.xjrsoft.module.textbook.mapper;
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.github.yulichang.base.MPJBaseMapper;
+import com.xjrsoft.module.textbook.entity.TextbookClassRelation;
+import org.apache.ibatis.annotations.Mapper;
+
+/**
+* @title: 教材教辅班级引用
+* @Author szs
+* @Date: 2023-12-25
+* @Version 1.0
+*/
+@Mapper
+public interface TextbookClassRelationMapper extends MPJBaseMapper<TextbookClassRelation> {
+
+}

+ 27 - 0
src/main/java/com/xjrsoft/module/textbook/mapper/TextbookMapper.java

@@ -0,0 +1,27 @@
+package com.xjrsoft.module.textbook.mapper;
+
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.github.yulichang.base.MPJBaseMapper;
+import com.xjrsoft.module.textbook.dto.TextbookPageDto;
+import com.xjrsoft.module.textbook.entity.Textbook;
+import com.xjrsoft.module.textbook.vo.TextbookPageVo;
+import org.apache.ibatis.annotations.Mapper;
+
+/**
+* @title: 教材管理
+* @Author dzx
+* @Date: 2023-12-25
+* @Version 1.0
+*/
+@Mapper
+public interface TextbookMapper extends MPJBaseMapper<Textbook> {
+
+    /**
+     * 分页查询
+     * @param page
+     * @param dto
+     * @return
+     */
+    Page<TextbookPageVo> getPage(Page<TextbookPageDto> page, TextbookPageDto dto);
+
+}

+ 17 - 0
src/main/java/com/xjrsoft/module/textbook/mapper/TextbookSubscriptionRecordMapper.java

@@ -0,0 +1,17 @@
+package com.xjrsoft.module.textbook.mapper;
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.github.yulichang.base.MPJBaseMapper;
+import com.xjrsoft.module.textbook.entity.TextbookSubscriptionRecord;
+import org.apache.ibatis.annotations.Mapper;
+
+/**
+* @title: 教材教辅征订记录
+* @Author szs
+* @Date: 2023-12-25
+* @Version 1.0
+*/
+@Mapper
+public interface TextbookSubscriptionRecordMapper extends MPJBaseMapper<TextbookSubscriptionRecord> {
+
+}

+ 50 - 0
src/main/java/com/xjrsoft/module/textbook/service/ITextbookService.java

@@ -0,0 +1,50 @@
+package com.xjrsoft.module.textbook.service;
+
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.github.yulichang.base.MPJBaseService;
+import com.xjrsoft.module.textbook.dto.TextbookPageDto;
+import com.xjrsoft.module.textbook.entity.Textbook;
+import com.xjrsoft.module.textbook.vo.TextbookPageVo;
+
+import java.util.List;
+
+/**
+* @title: 教材管理
+* @Author dzx
+* @Date: 2023-12-25
+* @Version 1.0
+*/
+
+public interface ITextbookService extends MPJBaseService<Textbook> {
+    /**
+    * 新增
+    *
+    * @param textbook
+    * @return
+    */
+    Boolean add(Textbook textbook);
+
+    /**
+    * 更新
+    *
+    * @param textbook
+    * @return
+    */
+    Boolean update(Textbook textbook);
+
+    /**
+    * 删除
+    *
+    * @param ids
+    * @return
+    */
+    Boolean delete(List<Long> ids);
+
+    /**
+     * 分页查询
+     * @param page
+     * @param dto
+     * @return
+     */
+    Page<TextbookPageVo> getPage(Page<TextbookPageDto> page, TextbookPageDto dto);
+}

+ 133 - 0
src/main/java/com/xjrsoft/module/textbook/service/impl/TextbookServiceImpl.java

@@ -0,0 +1,133 @@
+package com.xjrsoft.module.textbook.service.impl;
+
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.github.yulichang.base.MPJBaseServiceImpl;
+import com.xjrsoft.module.textbook.dto.TextbookPageDto;
+import com.xjrsoft.module.textbook.entity.Textbook;
+import com.xjrsoft.module.textbook.entity.TextbookClassRelation;
+import com.xjrsoft.module.textbook.entity.TextbookSubscriptionRecord;
+import com.xjrsoft.module.textbook.mapper.TextbookClassRelationMapper;
+import com.xjrsoft.module.textbook.mapper.TextbookMapper;
+import com.xjrsoft.module.textbook.mapper.TextbookSubscriptionRecordMapper;
+import com.xjrsoft.module.textbook.service.ITextbookService;
+import com.xjrsoft.module.textbook.vo.TextbookPageVo;
+import lombok.AllArgsConstructor;
+import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
+
+import java.util.List;
+import java.util.Objects;
+import java.util.stream.Collectors;
+
+/**
+* @title: 教材管理
+* @Author szs
+* @Date: 2023-12-25
+* @Version 1.0
+*/
+@Service
+@AllArgsConstructor
+public class TextbookServiceImpl extends MPJBaseServiceImpl<TextbookMapper, Textbook> implements ITextbookService {
+    private final TextbookMapper textbookTextbookMapper;
+
+    private final TextbookClassRelationMapper textbookTextbookClassRelationMapper;
+    private final TextbookSubscriptionRecordMapper textbookTextbookSubscriptionRecordMapper;
+
+
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public Boolean add(Textbook textbook) {
+        textbookTextbookMapper.insert(textbook);
+        for (TextbookClassRelation textbookClassRelation : textbook.getTextbookClassRelationList()) {
+            textbookClassRelation.setTextbookId(textbook.getId());
+            textbookTextbookClassRelationMapper.insert(textbookClassRelation);
+        }
+        for (TextbookSubscriptionRecord textbookSubscriptionRecord : textbook.getTextbookSubscriptionRecordList()) {
+            textbookSubscriptionRecord.setWfTextbookSubscriptionId(textbook.getId());
+            textbookTextbookSubscriptionRecordMapper.insert(textbookSubscriptionRecord);
+        }
+
+        return true;
+    }
+
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public Boolean update(Textbook textbook) {
+        textbookTextbookMapper.updateById(textbook);
+        //********************************* TextbookClassRelation  增删改  开始 *******************************************/
+        {
+            // 查出所有子级的id
+            List<TextbookClassRelation> textbookClassRelationList = textbookTextbookClassRelationMapper.selectList(Wrappers.lambdaQuery(TextbookClassRelation.class).eq(TextbookClassRelation::getTextbookId, textbook.getId()).select(TextbookClassRelation::getId));
+            List<Long> textbookClassRelationIds = textbookClassRelationList.stream().map(TextbookClassRelation::getId).collect(Collectors.toList());
+            //原有子表单 没有被删除的主键
+            List<Long> textbookClassRelationOldIds = textbook.getTextbookClassRelationList().stream().map(TextbookClassRelation::getId).filter(Objects::nonNull).collect(Collectors.toList());
+            //找到需要删除的id
+            List<Long> textbookClassRelationRemoveIds = textbookClassRelationIds.stream().filter(item -> !textbookClassRelationOldIds.contains(item)).collect(Collectors.toList());
+
+            for (TextbookClassRelation textbookClassRelation : textbook.getTextbookClassRelationList()) {
+                //如果不等于空则修改
+                if (textbookClassRelation.getId() != null) {
+                    textbookTextbookClassRelationMapper.updateById(textbookClassRelation);
+                }
+                //如果等于空 则新增
+                else {
+                    //已经不存在的id 删除
+                    textbookClassRelation.setTextbookId(textbook.getId());
+                    textbookTextbookClassRelationMapper.insert(textbookClassRelation);
+                }
+            }
+            //已经不存在的id 删除
+            if(textbookClassRelationRemoveIds.size() > 0){
+                textbookTextbookClassRelationMapper.deleteBatchIds(textbookClassRelationRemoveIds);
+            }
+        }
+        //********************************* TextbookClassRelation  增删改  结束 *******************************************/
+
+        //********************************* TextbookSubscriptionRecord  增删改  开始 *******************************************/
+        {
+            // 查出所有子级的id
+            List<TextbookSubscriptionRecord> textbookSubscriptionRecordList = textbookTextbookSubscriptionRecordMapper.selectList(Wrappers.lambdaQuery(TextbookSubscriptionRecord.class).eq(TextbookSubscriptionRecord::getWfTextbookSubscriptionId, textbook.getId()).select(TextbookSubscriptionRecord::getId));
+            List<Long> textbookSubscriptionRecordIds = textbookSubscriptionRecordList.stream().map(TextbookSubscriptionRecord::getId).collect(Collectors.toList());
+            //原有子表单 没有被删除的主键
+            List<Long> textbookSubscriptionRecordOldIds = textbook.getTextbookSubscriptionRecordList().stream().map(TextbookSubscriptionRecord::getId).filter(Objects::nonNull).collect(Collectors.toList());
+            //找到需要删除的id
+            List<Long> textbookSubscriptionRecordRemoveIds = textbookSubscriptionRecordIds.stream().filter(item -> !textbookSubscriptionRecordOldIds.contains(item)).collect(Collectors.toList());
+
+            for (TextbookSubscriptionRecord textbookSubscriptionRecord : textbook.getTextbookSubscriptionRecordList()) {
+                //如果不等于空则修改
+                if (textbookSubscriptionRecord.getId() != null) {
+                    textbookTextbookSubscriptionRecordMapper.updateById(textbookSubscriptionRecord);
+                }
+                //如果等于空 则新增
+                else {
+                    //已经不存在的id 删除
+                    textbookSubscriptionRecord.setWfTextbookSubscriptionId(textbook.getId());
+                    textbookTextbookSubscriptionRecordMapper.insert(textbookSubscriptionRecord);
+                }
+            }
+            //已经不存在的id 删除
+            if(textbookSubscriptionRecordRemoveIds.size() > 0){
+                textbookTextbookSubscriptionRecordMapper.deleteBatchIds(textbookSubscriptionRecordRemoveIds);
+            }
+        }
+        //********************************* TextbookSubscriptionRecord  增删改  结束 *******************************************/
+
+        return true;
+    }
+
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public Boolean delete(List<Long> ids) {
+        textbookTextbookMapper.deleteBatchIds(ids);
+        textbookTextbookClassRelationMapper.delete(Wrappers.lambdaQuery(TextbookClassRelation.class).in(TextbookClassRelation::getTextbookId, ids));
+        textbookTextbookSubscriptionRecordMapper.delete(Wrappers.lambdaQuery(TextbookSubscriptionRecord.class).in(TextbookSubscriptionRecord::getWfTextbookSubscriptionId, ids));
+
+        return true;
+    }
+
+    @Override
+    public Page<TextbookPageVo> getPage(Page<TextbookPageDto> page, TextbookPageDto dto) {
+        return textbookTextbookMapper.getPage(page, dto);
+    }
+}

+ 44 - 0
src/main/java/com/xjrsoft/module/textbook/vo/TextbookClassRelationVo.java

@@ -0,0 +1,44 @@
+package com.xjrsoft.module.textbook.vo;
+
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+import java.time.LocalTime;
+import java.time.LocalDateTime;
+import java.math.BigDecimal;
+import java.util.List;
+import java.util.Date;
+
+/**
+* @title: 教材教辅班级引用表单出参
+* @Author szs
+* @Date: 2023-12-25
+* @Version 1.0
+*/
+@Data
+public class TextbookClassRelationVo {
+
+    /**
+    * 主键编号
+    */
+    @ApiModelProperty("主键编号")
+    private Long id;
+    /**
+    * 序号
+    */
+    @ApiModelProperty("序号")
+    private Integer sortCode;
+    /**
+    * 教材管理编号
+    */
+    @ApiModelProperty("教材管理编号")
+    private Long textbookId;
+    /**
+    * 班级编号
+    */
+    @ApiModelProperty("班级编号")
+    private Long classId;
+
+
+
+}

+ 163 - 0
src/main/java/com/xjrsoft/module/textbook/vo/TextbookPageVo.java

@@ -0,0 +1,163 @@
+package com.xjrsoft.module.textbook.vo;
+
+import com.alibaba.excel.annotation.ExcelProperty;
+import com.alibaba.excel.annotation.write.style.ContentStyle;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+import java.math.BigDecimal;
+
+/**
+* @title: 教材管理分页列表出参
+* @Author szs
+* @Date: 2023-12-25
+* @Version 1.0
+*/
+@Data
+public class TextbookPageVo {
+
+    /**
+    * 主键编号
+    */
+    @ContentStyle(dataFormat = 49)
+    @ExcelProperty("主键编号")
+    @ApiModelProperty("主键编号")
+    private String id;
+    /**
+    * 序号
+    */
+    @ContentStyle(dataFormat = 49)
+    @ExcelProperty("序号")
+    @ApiModelProperty("序号")
+    private Integer sortCode;
+    /**
+    * 国际标准刊号
+    */
+    @ContentStyle(dataFormat = 49)
+    @ExcelProperty("国际标准刊号")
+    @ApiModelProperty("国际标准刊号")
+    private String issn;
+    /**
+    * 书名
+    */
+    @ContentStyle(dataFormat = 49)
+    @ExcelProperty("书名")
+    @ApiModelProperty("书名")
+    private String bookName;
+    /**
+    * 出版社
+    */
+    @ContentStyle(dataFormat = 49)
+    @ExcelProperty("出版社")
+    @ApiModelProperty("出版社")
+    private String publishingHouse;
+    /**
+    * 主编
+    */
+    @ContentStyle(dataFormat = 49)
+    @ExcelProperty("主编")
+    @ApiModelProperty("主编")
+    private String editorInChief;
+    /**
+     * 学科组名称
+     */
+    @ContentStyle(dataFormat = 49)
+    @ExcelProperty("学科组名称")
+    @ApiModelProperty("学科组名称")
+    private String groupName;
+
+    /**
+    * 学期名称
+    */
+    @ContentStyle(dataFormat = 49)
+    @ExcelProperty("学期名称")
+    @ApiModelProperty("学期名称")
+    private String semesterName;
+    /**
+    * 课程
+    */
+    @ContentStyle(dataFormat = 49)
+    @ExcelProperty("课程")
+    @ApiModelProperty("课程")
+    private String courseName;
+    /**
+    * 版本
+    */
+    @ContentStyle(dataFormat = 49)
+    @ExcelProperty("版本")
+    @ApiModelProperty("版本")
+    private String version;
+    /**
+    * 是否为规划教材
+    */
+    @ContentStyle(dataFormat = 49)
+    @ExcelProperty("是否为规划教材")
+    @ApiModelProperty("是否为规划教材")
+    private String isTextbookPlanCn;
+
+    /**
+     * 教材类型(xjr_dictionary_item[textbook_type])
+     */
+    @ContentStyle(dataFormat = 49)
+    @ExcelProperty("教材类型")
+    @ApiModelProperty("教材类型-中文")
+    private String textbookTypeCn;
+    /**
+    * 规格型号
+    */
+    @ContentStyle(dataFormat = 49)
+    @ExcelProperty("规格型号")
+    @ApiModelProperty("规格型号")
+    private String specificationsModels;
+    /**
+    * 估价(元)
+    */
+    @ContentStyle(dataFormat = 49)
+    @ExcelProperty("估价(元)")
+    @ApiModelProperty("估价(元)")
+    private BigDecimal appraisalPrice;
+    /**
+    * 定价(元)
+    */
+    @ContentStyle(dataFormat = 49)
+    @ExcelProperty("定价(元)")
+    @ApiModelProperty("定价(元)")
+    private BigDecimal price;
+    /**
+    * 折扣
+    */
+    @ContentStyle(dataFormat = 49)
+    @ExcelProperty("折扣")
+    @ApiModelProperty("折扣")
+    private Double discount;
+    /**
+    * 小计(元)
+    */
+    @ContentStyle(dataFormat = 49)
+    @ExcelProperty("小计(元)")
+    @ApiModelProperty("小计(元)")
+    private BigDecimal subtotal;
+    /**
+    * 库存
+    */
+    @ContentStyle(dataFormat = 49)
+    @ExcelProperty("库存")
+    @ApiModelProperty("库存")
+    private Integer stock;
+
+    /**
+     * 使用年级
+     */
+    @ContentStyle(dataFormat = 49)
+    @ExcelProperty("使用年级")
+    @ApiModelProperty("使用年级")
+    private String useGrade;
+
+    /**
+     * 使用班级
+     */
+    @ContentStyle(dataFormat = 49)
+    @ExcelProperty("使用班级")
+    @ApiModelProperty("使用班级")
+    private String useClass;
+}

+ 44 - 0
src/main/java/com/xjrsoft/module/textbook/vo/TextbookSubscriptionRecordVo.java

@@ -0,0 +1,44 @@
+package com.xjrsoft.module.textbook.vo;
+
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+import java.time.LocalTime;
+import java.time.LocalDateTime;
+import java.math.BigDecimal;
+import java.util.List;
+import java.util.Date;
+
+/**
+* @title: 教材教辅征订记录表单出参
+* @Author szs
+* @Date: 2023-12-25
+* @Version 1.0
+*/
+@Data
+public class TextbookSubscriptionRecordVo {
+
+    /**
+    * 主键编号
+    */
+    @ApiModelProperty("主键编号")
+    private Long id;
+    /**
+    * 序号
+    */
+    @ApiModelProperty("序号")
+    private Integer sortCode;
+    /**
+    * 教材管理编号
+    */
+    @ApiModelProperty("教材管理编号")
+    private Long textbookId;
+    /**
+    * 教材教辅征订编号
+    */
+    @ApiModelProperty("教材教辅征订编号")
+    private Long wfTextbookSubscriptionId;
+
+
+
+}

+ 131 - 0
src/main/java/com/xjrsoft/module/textbook/vo/TextbookVo.java

@@ -0,0 +1,131 @@
+package com.xjrsoft.module.textbook.vo;
+
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+import java.time.LocalTime;
+import java.time.LocalDateTime;
+import java.math.BigDecimal;
+import java.util.List;
+import java.util.Date;
+import com.xjrsoft.module.textbook.entity.TextbookClassRelation;
+import com.xjrsoft.module.textbook.entity.TextbookSubscriptionRecord;
+
+/**
+* @title: 教材管理表单出参
+* @Author szs
+* @Date: 2023-12-25
+* @Version 1.0
+*/
+@Data
+public class TextbookVo {
+
+    /**
+    * 主键编号
+    */
+    @ApiModelProperty("主键编号")
+    private Long id;
+    /**
+    * 序号
+    */
+    @ApiModelProperty("序号")
+    private Integer sortCode;
+    /**
+    * 国际标准刊号
+    */
+    @ApiModelProperty("国际标准刊号")
+    private String issn;
+    /**
+    * 国际标准书号
+    */
+    @ApiModelProperty("国际标准书号")
+    private String isbn;
+    /**
+    * 书名
+    */
+    @ApiModelProperty("书名")
+    private String bookName;
+    /**
+    * 出版社
+    */
+    @ApiModelProperty("出版社")
+    private String publishingHouse;
+    /**
+    * 主编
+    */
+    @ApiModelProperty("主编")
+    private String editorInChief;
+    /**
+    * 学科组管理编号(subject_group)
+    */
+    @ApiModelProperty("学科组管理编号(subject_group)")
+    private Long subjectGroupId;
+    /**
+    * 学期ID(base_semester)
+    */
+    @ApiModelProperty("学期ID(base_semester)")
+    private Long baseSemesterId;
+    /**
+    * 课程编号(base_course_subject)
+    */
+    @ApiModelProperty("课程编号(base_course_subject)")
+    private Long courseSubjectId;
+    /**
+    * 版本
+    */
+    @ApiModelProperty("版本")
+    private String version;
+    /**
+    * 是否为规划教材(xjr_dictionary_item[judgment_method_1])
+    */
+    @ApiModelProperty("是否为规划教材(xjr_dictionary_item[judgment_method_1])")
+    private String isTextbookPlan;
+    /**
+    * 教材类型(xjr_dictionary_item[textbook_type])
+    */
+    @ApiModelProperty("教材类型(xjr_dictionary_item[textbook_type])")
+    private String textbookType;
+    /**
+    * 规格型号
+    */
+    @ApiModelProperty("规格型号")
+    private String specificationsModels;
+    /**
+    * 估价(元)
+    */
+    @ApiModelProperty("估价(元)")
+    private BigDecimal appraisalPrice;
+    /**
+    * 定价(元)
+    */
+    @ApiModelProperty("定价(元)")
+    private BigDecimal price;
+    /**
+    * 折扣
+    */
+    @ApiModelProperty("折扣")
+    private Double discount;
+    /**
+    * 小计(元)
+    */
+    @ApiModelProperty("小计(元)")
+    private BigDecimal subtotal;
+    /**
+    * 库存
+    */
+    @ApiModelProperty("库存")
+    private Integer stock;
+
+
+    /**
+    * textbookClassRelation
+    */
+    @ApiModelProperty("textbookClassRelation子表")
+    private List<TextbookClassRelationVo> textbookClassRelationList;
+    /**
+    * textbookSubscriptionRecord
+    */
+    @ApiModelProperty("textbookSubscriptionRecord子表")
+    private List<TextbookSubscriptionRecordVo> textbookSubscriptionRecordList;
+
+}

+ 48 - 0
src/test/java/com/xjrsoft/xjrsoftboot/FreeMarkerGeneratorTest.java

@@ -1221,4 +1221,52 @@ public class FreeMarkerGeneratorTest {
         apiGeneratorService.generateCodes(params);
     }
 
+    /**
+     * 学科组课程管理
+     *
+     */
+    @Test
+    public void gcTextBookManage() throws IOException {
+        List<TableConfig> tableConfigs = new ArrayList<>();
+        TableConfig mainTable = new TableConfig();
+        mainTable.setTableName("textbook");//init_sql中的表名
+        mainTable.setIsMain(true);//是否是主表,一般默认为true
+        mainTable.setPkField(GlobalConstant.DEFAULT_PK);//设置主键
+        mainTable.setPkType(GlobalConstant.DEFAULT_PK_TYPE);//设置主键类型
+        tableConfigs.add(mainTable);
+
+        mainTable = new TableConfig();
+        mainTable.setTableName("textbook_class_relation");//init_sql中的表名
+        mainTable.setIsMain(false);//是否是主表,一般默认为true
+        mainTable.setPkField(GlobalConstant.DEFAULT_PK);//设置主键
+        mainTable.setPkType(GlobalConstant.DEFAULT_PK_TYPE);//设置主键类型
+        mainTable.setRelationField("textbook_id");//设置外键
+        mainTable.setRelationTableField(GlobalConstant.DEFAULT_PK);//设置外键
+        tableConfigs.add(mainTable);
+
+        mainTable = new TableConfig();
+        mainTable.setTableName("textbook_subscription_record");//init_sql中的表名
+        mainTable.setIsMain(false);//是否是主表,一般默认为true
+        mainTable.setPkField(GlobalConstant.DEFAULT_PK);//设置主键
+        mainTable.setPkType(GlobalConstant.DEFAULT_PK_TYPE);//设置主键类型
+        mainTable.setRelationField("wf_textbook_subscription_id");//设置外键
+        mainTable.setRelationTableField(GlobalConstant.DEFAULT_PK);//设置外键
+        tableConfigs.add(mainTable);
+
+
+        ApiGenerateCodesDto params = new ApiGenerateCodesDto();
+        params.setAuthor("szs");//作者名称
+        params.setPackageName("textbook");//包名
+        params.setTableConfigs(tableConfigs);
+        params.setPage(true);//是否生成分页接口
+        params.setImport(false);//是否生成导入接口
+        params.setExport(true);//是否生成导出接口
+        params.setOutMainDir(true);//是否生成在主目录,前期测试可设置成false
+        params.setDs(ds);
+
+        IApiGeneratorService apiGeneratorService = new ApiGeneratorServiceImpl();
+
+        apiGeneratorService.generateCodes(params);
+    }
+
 }