Browse Source

商品编码字典查询

heguanxun 9 months ago
parent
commit
f5337d697d
14 changed files with 1092 additions and 0 deletions
  1. 34 0
      snowy-admin-web/src/api/biz/qyRecordProductDictApi.js
  2. 120 0
      snowy-admin-web/src/views/biz/qyrecordproductdict/detail.vue
  3. 201 0
      snowy-admin-web/src/views/biz/qyrecordproductdict/index.vue
  4. 174 0
      snowy-plugin/snowy-plugin-biz/src/main/java/vip/xiaonuo/biz/modular/qyrecordproductdict/controller/QyRecordProductDictController.java
  5. 82 0
      snowy-plugin/snowy-plugin-biz/src/main/java/vip/xiaonuo/biz/modular/qyrecordproductdict/entity/QyRecordProductDict.java
  6. 34 0
      snowy-plugin/snowy-plugin-biz/src/main/java/vip/xiaonuo/biz/modular/qyrecordproductdict/enums/QyRecordProductDictEnum.java
  7. 25 0
      snowy-plugin/snowy-plugin-biz/src/main/java/vip/xiaonuo/biz/modular/qyrecordproductdict/mapper/QyRecordProductDictMapper.java
  8. 5 0
      snowy-plugin/snowy-plugin-biz/src/main/java/vip/xiaonuo/biz/modular/qyrecordproductdict/mapper/mapping/QyRecordProductDictMapper.xml
  9. 69 0
      snowy-plugin/snowy-plugin-biz/src/main/java/vip/xiaonuo/biz/modular/qyrecordproductdict/param/QyRecordProductDictAddParam.java
  10. 74 0
      snowy-plugin/snowy-plugin-biz/src/main/java/vip/xiaonuo/biz/modular/qyrecordproductdict/param/QyRecordProductDictEditParam.java
  11. 35 0
      snowy-plugin/snowy-plugin-biz/src/main/java/vip/xiaonuo/biz/modular/qyrecordproductdict/param/QyRecordProductDictIdParam.java
  12. 59 0
      snowy-plugin/snowy-plugin-biz/src/main/java/vip/xiaonuo/biz/modular/qyrecordproductdict/param/QyRecordProductDictPageParam.java
  13. 80 0
      snowy-plugin/snowy-plugin-biz/src/main/java/vip/xiaonuo/biz/modular/qyrecordproductdict/service/QyRecordProductDictService.java
  14. 100 0
      snowy-plugin/snowy-plugin-biz/src/main/java/vip/xiaonuo/biz/modular/qyrecordproductdict/service/impl/QyRecordProductDictServiceImpl.java

+ 34 - 0
snowy-admin-web/src/api/biz/qyRecordProductDictApi.js

@@ -0,0 +1,34 @@
+import { baseRequest } from '@/utils/request'
+
+const request = (url, ...arg) => baseRequest(`/biz/qyrecordproductdict/` + url, ...arg)
+
+/**
+ * 商品编码表Api接口管理器
+ *
+ * @author hgx
+ * @date  2024/07/12 18:29
+ **/
+export default {
+	// 获取商品编码表分页
+	qyRecordProductDictPage(data) {
+		return request('page', data, 'get')
+	},
+	// 提交商品编码表表单 edit为true时为编辑,默认为新增
+	qyRecordProductDictSubmitForm(data, edit = false) {
+		return request(edit ? 'edit' : 'add', data)
+	},
+	// 删除商品编码表
+	qyRecordProductDictDelete(data) {
+		return request('delete', data)
+	},
+	// 导出商品编码表
+    qyRecordProductDictExport(data) {
+        return request('export', data, 'post', {
+            responseType: 'blob'
+        })
+    },
+	// 获取商品编码表详情
+	qyRecordProductDictDetail(data) {
+		return request('detail', data, 'get')
+	}
+}

+ 120 - 0
snowy-admin-web/src/views/biz/qyrecordproductdict/detail.vue

@@ -0,0 +1,120 @@
+<template>
+    <a-card :bordered="false">
+		<a-page-header
+            :title="formData.id ? '编辑商品编码表' : '新增商品编码表'"
+			@back="onClose"
+		>
+			<template #extra>
+				<a-button style="margin-right: 8px" @click="onClose">关闭</a-button>
+				<a-popconfirm title="请确认是否保存?" @confirm="onSubmit" v-if="!isView">
+                    <a-button type="primary" :loading="submitLoading">保存</a-button>
+                </a-popconfirm>
+			</template>
+		</a-page-header>
+		<a-form ref="formRef" :model="formData" :rules="formRules" layout="vertical">
+            <a-row :gutter="16">
+                <a-col :span="12">
+                    <a-form-item label="商品编号:" name="productCode">
+                        <a-input v-model:value="formData.productCode" :disabled="isView" placeholder="请输入商品编号" allow-clear />
+                    </a-form-item>
+                </a-col>
+                <a-col :span="12">
+                    <a-form-item label="商品名称:" name="productName">
+                        <a-input v-model:value="formData.productName" :disabled="isView" placeholder="请输入商品名称" allow-clear />
+                    </a-form-item>
+                </a-col>
+                <a-col :span="12">
+                    <a-form-item label="年份:" name="year">
+                        <a-input v-model:value="formData.year" :disabled="isView" placeholder="请输入年份" allow-clear />
+                    </a-form-item>
+                </a-col>
+                <a-col :span="12">
+                    <a-form-item label="第一计量单位编码:" name="firstUnitCode">
+                        <a-input v-model:value="formData.firstUnitCode" :disabled="isView" placeholder="请输入第一计量单位编码" allow-clear />
+                    </a-form-item>
+                </a-col>
+                <a-col :span="12">
+                    <a-form-item label="第一计量单位名称:" name="firstUnitName">
+                        <a-input v-model:value="formData.firstUnitName" :disabled="isView" placeholder="请输入第一计量单位名称" allow-clear />
+                    </a-form-item>
+                </a-col>
+                <a-col :span="12">
+                    <a-form-item label="第二计量单位编码:" name="secondUnitCode">
+                        <a-input v-model:value="formData.secondUnitCode" :disabled="isView" placeholder="请输入第二计量单位编码" allow-clear />
+                    </a-form-item>
+                </a-col>
+                <a-col :span="12">
+                    <a-form-item label="第二计量单位名称:" name="secondUnitName">
+                        <a-input v-model:value="formData.secondUnitName" :disabled="isView" placeholder="请输入第二计量单位名称" allow-clear />
+                    </a-form-item>
+                </a-col>
+            </a-row>
+        </a-form>
+	</a-card>
+</template>
+
+<script setup name="qyRecordProductDictDetail">
+	import { cloneDeep } from 'lodash-es'
+	import { required } from '@/utils/formRules'
+	import qyRecordProductDictApi from '@/api/biz/qyRecordProductDictApi'
+	// 抽屉状态
+    const { proxy } = getCurrentInstance()
+	const emit = defineEmits({ successful: null, onClose: null })
+	const formRef = ref()
+	// 表单数据
+	const formData = ref({})
+	const submitLoading = ref(false)
+	const isView = ref(false)
+
+	// 打开抽屉
+	const onOpen = (record, view = false) => {
+	    isView.value = view
+		if (record) {
+			let recordData = cloneDeep(record)
+			formData.value = Object.assign({}, recordData)
+		}
+	}
+	// 关闭抽屉
+	const onClose = () => {
+		formRef.value.resetFields()
+		formData.value = {}
+		isView.value = true
+		emit('onClose')
+	}
+	// 默认要校验的
+	const formRules = {
+		productCode: [required('请输入商品编号')],
+		productName: [required('请输入商品名称')],
+		year: [required('请输入年份')],
+		firstUnitCode: [required('请输入第一计量单位编码')],
+		firstUnitName: [required('请输入第一计量单位名称')],
+		secondUnitCode: [required('请输入第二计量单位编码')],
+		secondUnitName: [required('请输入第二计量单位名称')],
+	}
+	// 验证并提交数据
+	const onSubmit = () => {
+		formRef.value
+			.validate()
+			.then(() => {
+				submitLoading.value = true
+				const formDataParam = cloneDeep(formData.value)
+				qyRecordProductDictApi
+					.qyRecordProductDictSubmitForm(formDataParam, formDataParam.id)
+					.then(() => {
+						onClose()
+						emit('successful')
+					})
+					.finally(() => {
+						submitLoading.value = false
+					})
+			})
+			.catch(() => {})
+	}
+	// 抛出函数
+	defineExpose({
+		onOpen
+	})
+</script>
+
+<style lang="less" scoped>
+</style>

+ 201 - 0
snowy-admin-web/src/views/biz/qyrecordproductdict/index.vue

@@ -0,0 +1,201 @@
+<template>
+	<a-card :bordered="false" v-if="indexShow">
+		<a-form ref="searchFormRef" name="advanced_search" :model="searchFormState" class="ant-advanced-search-form">
+            <a-row :gutter="24">
+                <a-col :span="6">
+                    <a-form-item label="商品编号" name="productCode">
+                        <a-input v-model:value="searchFormState.productCode" placeholder="请输入商品编号" allow-clear/>
+                    </a-form-item>
+                </a-col>
+                <a-col :span="6">
+                    <a-form-item label="商品名称" name="productName">
+                        <a-input v-model:value="searchFormState.productName" placeholder="请输入商品名称" allow-clear/>
+                    </a-form-item>
+                </a-col>
+                <a-col :span="6">
+                    <a-button type="primary" @click="onSearch()">查询</a-button>
+                    <a-button style="margin: 0 8px" @click="reset">重置</a-button>
+                </a-col>
+            </a-row>
+        </a-form>
+		<s-table
+			ref="tableRef"
+			:columns="columns"
+			:data="loadData"
+			:alert="options.alert.show"
+			bordered
+			:row-key="(record) => record.id"
+			:tool-config="toolConfig"
+			:row-selection="options.rowSelection"
+			v-model:filterParam="filterParam"
+			:scroll="{ x: 2000 }"
+		>
+			<template #operator class="table-operator">
+				<a-space>
+					<a-button type="primary" @click="onDetail()" v-if="hasPerm('qyRecordProductDictAdd')">
+						<template #icon><plus-outlined /></template>
+						新增
+					</a-button>
+					<xn-batch-delete
+						v-if="hasPerm('qyRecordProductDictDelete')"
+						:selectedRowKeys="selectedRowKeys"
+						@batchDelete="deleteBatchQyRecordProductDict"
+					/>
+					<a-button @click="onExport" v-if="hasPerm('qyRecordProductDictBatchExport')">
+                        <template #icon><export-outlined /></template>
+                        批量导出
+                    </a-button>
+				</a-space>
+			</template>
+			<template #bodyCell="{ column, record }">
+				<template v-if="column.dataIndex === 'action'">
+					<a-space>
+					    <a @click="onDetail(record, true)" v-if="hasPerm('qyRecordProductDictView')">查看</a>
+						<a @click="onDetail(record)" v-if="hasPerm('qyRecordProductDictEdit')">编辑</a>
+						<a-popconfirm title="确定要删除吗?" @confirm="deleteQyRecordProductDict(record)">
+							<a-button type="link" danger size="small" v-if="hasPerm('qyRecordProductDictDelete')">删除</a-button>
+						</a-popconfirm>
+					</a-space>
+				</template>
+			</template>
+		</s-table>
+	</a-card>
+	<Detail v-else ref="detailRef" @onClose="indexShow = true" @successful="onSearch()" />
+</template>
+
+<script setup name="qyrecordproductdict">
+	import { cloneDeep } from 'lodash-es'
+	import Detail from './detail.vue'
+	import qyRecordProductDictApi from '@/api/biz/qyRecordProductDictApi'
+	import downloadUtil from "@/utils/downloadUtil";
+    const { proxy } = getCurrentInstance()
+	const searchFormState = ref({})
+	const searchFormStateReal = ref(searchFormState.value) // 点击搜索后备份的查询参数
+	const searchFormRef = ref()
+	const tableRef = ref()
+	const filterParam = ref({})
+	const detailRef = ref()
+	const indexShow = ref(true)
+	const toolConfig = { refresh: true, height: true, columnSetting: true, striped: false }
+	const columns = [
+		{
+			title: '商品编号',
+			dataIndex: 'productCode',
+		},
+		{
+			title: '商品名称',
+			dataIndex: 'productName',
+		},
+		{
+			title: '年份',
+			dataIndex: 'year',
+		},
+		{
+			title: '第一计量单位编码',
+			dataIndex: 'firstUnitCode',
+		},
+		{
+			title: '第一计量单位名称',
+			dataIndex: 'firstUnitName',
+		},
+		{
+			title: '第二计量单位编码',
+			dataIndex: 'secondUnitCode',
+		},
+		{
+			title: '第二计量单位名称',
+			dataIndex: 'secondUnitName',
+		},
+	]
+	// 操作栏通过权限判断是否显示
+	if (hasPerm(['qyRecordProductDictEdit', 'qyRecordProductDictDelete'])) {
+		columns.push({
+			title: '操作',
+			dataIndex: 'action',
+			align: 'center',
+			width: 200,
+			fixed: 'right',
+		})
+	}
+	const selectedRowKeys = ref([])
+	// 列表选择配置
+	const options = {
+		// columns数字类型字段加入 needTotal: true 可以勾选自动算账
+		alert: {
+			show: true,
+			clear: () => {
+				selectedRowKeys.value = ref([])
+			}
+		},
+		rowSelection: {
+			onChange: (selectedRowKey, selectedRows) => {
+				selectedRowKeys.value = selectedRowKey
+			}
+		}
+	}
+	const loadData = (parameter) => {
+        tableRef.value.clearSelected()
+        return qyRecordProductDictApi.qyRecordProductDictPage(Object.assign(parameter, searchFormStateReal.value)).then((data) => {
+            return data
+        })
+    }
+    // 搜索同时备份参数
+    const onSearch = (parameter) => {
+        searchFormStateReal.value = cloneDeep(Object.assign(searchFormState.value, filterParam.value))
+        nextTick(() => {
+            tableRef.value.refresh(parameter)
+        })
+    }
+    // 重置
+    const reset = () => {
+        searchFormRef.value.resetFields()
+        onSearch(true)
+    }
+	// 删除
+	const deleteQyRecordProductDict = (record) => {
+		let params = [
+			{
+				id: record.id
+			}
+		]
+		qyRecordProductDictApi.qyRecordProductDictDelete(params).then(() => {
+			tableRef.value.refresh(true)
+		})
+	}
+	// 批量删除
+	const deleteBatchQyRecordProductDict = (params) => {
+		qyRecordProductDictApi.qyRecordProductDictDelete(params).then(() => {
+			tableRef.value.clearRefreshSelected()
+		})
+	}
+	// 批量导出
+    const onExport = () => {
+        const params = {
+            ...filterParam.value
+        }
+        if (selectedRowKeys.value.length > 0) {
+            params.ids = selectedRowKeys.value
+        } else {
+            Object.entries(searchFormStateReal.value).forEach(([key, value]) => {
+                console.log(key)
+                if (proxy.$util.isValue(value)) {
+                    params[key] = value
+                }
+            })
+        }
+        qyRecordProductDictApi.qyRecordProductDictExport(params).then((res) => {
+            downloadUtil.resultDownload(res)
+            tableRef.value.clearSelected()
+        })
+    }
+	// 切换至表单
+    const onDetail = (record = null, view) => {
+    	indexShow.value = false
+    	nextTick(() => {
+            detailRef.value.onOpen(record, view)
+    	})
+    }
+</script>
+
+<style lang="less" scoped>
+</style>

+ 174 - 0
snowy-plugin/snowy-plugin-biz/src/main/java/vip/xiaonuo/biz/modular/qyrecordproductdict/controller/QyRecordProductDictController.java

@@ -0,0 +1,174 @@
+/*
+ * Copyright [2022] [https://www.xiaonuo.vip]
+ *
+ * Snowy采用APACHE LICENSE 2.0开源协议,您在使用过程中,需要注意以下几点:
+ *
+ * 1.请不要删除和修改根目录下的LICENSE文件。
+ * 2.请不要删除和修改Snowy源码头部的版权声明。
+ * 3.本项目代码可免费商业使用,商业使用请保留源码和相关描述文件的项目出处,作者声明等。
+ * 4.分发源码时候,请注明软件出处 https://www.xiaonuo.vip
+ * 5.不可二次分发开源参与同类竞品,如有想法可联系团队xiaonuobase@qq.com商议合作。
+ * 6.若您的项目无法满足以上几点,需要更多功能代码,获取Snowy商业授权许可,请在官网购买授权,地址为 https://www.xiaonuo.vip
+ */
+package vip.xiaonuo.biz.modular.qyrecordproductdict.controller;
+
+import cn.dev33.satoken.annotation.SaCheckPermission;
+import cn.hutool.core.util.URLUtil;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import io.swagger.v3.oas.annotations.tags.Tag;
+import io.swagger.v3.oas.annotations.Operation;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.GetMapping;
+import org.springframework.web.bind.annotation.PostMapping;
+import org.springframework.web.bind.annotation.RequestBody;
+import org.springframework.web.bind.annotation.RestController;
+import vip.xiaonuo.common.annotation.CommonLog;
+import vip.xiaonuo.common.pojo.CommonResult;
+import vip.xiaonuo.biz.modular.qyrecordproductdict.entity.QyRecordProductDict;
+import vip.xiaonuo.biz.modular.qyrecordproductdict.param.QyRecordProductDictAddParam;
+import vip.xiaonuo.biz.modular.qyrecordproductdict.param.QyRecordProductDictEditParam;
+import vip.xiaonuo.biz.modular.qyrecordproductdict.param.QyRecordProductDictIdParam;
+import vip.xiaonuo.biz.modular.qyrecordproductdict.param.QyRecordProductDictPageParam;
+import vip.xiaonuo.biz.modular.qyrecordproductdict.service.QyRecordProductDictService;
+import jakarta.servlet.http.HttpServletResponse;
+import jakarta.annotation.Resource;
+import jakarta.validation.Valid;
+import jakarta.validation.constraints.NotEmpty;
+import java.util.List;
+import java.io.IOException;
+import com.alibaba.excel.EasyExcel;
+import com.alibaba.fastjson.JSON;
+import java.net.URLEncoder;
+import java.util.HashMap;
+
+/**
+ * 商品编码表控制器
+ *
+ * @author hgx
+ * @date  2024/07/12 18:29
+ */
+@Tag(name = "商品编码表控制器")
+@RestController
+@Validated
+public class QyRecordProductDictController {
+
+    @Resource
+    private QyRecordProductDictService qyRecordProductDictService;
+
+    /**
+     * 获取商品编码表分页
+     *
+     * @author hgx
+     * @date  2024/07/12 18:29
+     */
+    @Operation(summary = "获取商品编码表分页")
+    @SaCheckPermission("/biz/qyrecordproductdict/page")
+    @GetMapping("/biz/qyrecordproductdict/page")
+    public CommonResult<Page<QyRecordProductDict>> page(QyRecordProductDictPageParam qyRecordProductDictPageParam) {
+        return CommonResult.data(qyRecordProductDictService.page(qyRecordProductDictPageParam));
+    }
+
+    /**
+     * 添加商品编码表
+     *
+     * @author hgx
+     * @date  2024/07/12 18:29
+     */
+    @Operation(summary = "添加商品编码表")
+    @CommonLog("添加商品编码表")
+    @SaCheckPermission("/biz/qyrecordproductdict/add")
+    @PostMapping("/biz/qyrecordproductdict/add")
+    public CommonResult<String> add(@RequestBody @Valid QyRecordProductDictAddParam qyRecordProductDictAddParam) {
+        qyRecordProductDictService.add(qyRecordProductDictAddParam);
+        return CommonResult.ok();
+    }
+
+    /**
+     * 编辑商品编码表
+     *
+     * @author hgx
+     * @date  2024/07/12 18:29
+     */
+    @Operation(summary = "编辑商品编码表")
+    @CommonLog("编辑商品编码表")
+    @SaCheckPermission("/biz/qyrecordproductdict/edit")
+    @PostMapping("/biz/qyrecordproductdict/edit")
+    public CommonResult<String> edit(@RequestBody @Valid QyRecordProductDictEditParam qyRecordProductDictEditParam) {
+        qyRecordProductDictService.edit(qyRecordProductDictEditParam);
+        return CommonResult.ok();
+    }
+
+    /**
+     * 导出商品编码表
+     *
+     * @author hgx
+     * @date  2024/07/12 18:29
+     */
+    @Operation(summary = "导出商品编码表")
+    @CommonLog("导出商品编码表")
+    @SaCheckPermission("/biz/qyrecordproductdict/export")
+    @PostMapping("/biz/qyrecordproductdict/export")
+    public void export(@RequestBody @Valid QyRecordProductDictPageParam qyRecordProductDictPageParam, HttpServletResponse response) {
+        Page<QyRecordProductDict> page =  qyRecordProductDictService.page(qyRecordProductDictPageParam);
+        List<QyRecordProductDict> records = page.getRecords();
+        exportExcel(response,QyRecordProductDict.class,records,"商品编码表");
+    }
+
+
+    /**
+     * 导出表格数据
+     * @param cl       表格字段实体类
+     * @param data     查询数据
+     * @param sheetName  表格名称
+     */
+    public void exportExcel(HttpServletResponse response, Class cl, List data, String sheetName){
+       HashMap<String, String> map = new HashMap<>();
+       try {
+           response.setHeader("Content-disposition", "attachment;filename=" + URLUtil.encode(sheetName) + ".xlsx");
+           response.setHeader("Access-Control-Allow-Origin", "*");
+           response.setHeader("Access-Control-Expose-Headers", "Content-Disposition");
+           response.setContentType("application/octet-stream;charset=UTF-8");
+           EasyExcel.write(response.getOutputStream(), cl).autoCloseStream(Boolean.FALSE).sheet(sheetName).doWrite(data);
+       } catch (IOException e) {
+           response.reset();
+           response.setContentType("application/json");
+           response.setCharacterEncoding("utf-8");
+           map.put("status", "failure");
+           map.put("message", "下载文件失败" + e.getMessage());
+           try {
+               response.getWriter().println(JSON.toJSONString(map));
+           } catch (IOException ex) {
+               ex.printStackTrace();
+           }
+       }
+    }
+
+    /**
+     * 删除商品编码表
+     *
+     * @author hgx
+     * @date  2024/07/12 18:29
+     */
+    @Operation(summary = "删除商品编码表")
+    @CommonLog("删除商品编码表")
+    @SaCheckPermission("/biz/qyrecordproductdict/delete")
+    @PostMapping("/biz/qyrecordproductdict/delete")
+    public CommonResult<String> delete(@RequestBody @Valid @NotEmpty(message = "集合不能为空")
+                                                   List<QyRecordProductDictIdParam> qyRecordProductDictIdParamList) {
+        qyRecordProductDictService.delete(qyRecordProductDictIdParamList);
+        return CommonResult.ok();
+    }
+
+    /**
+     * 获取商品编码表详情
+     *
+     * @author hgx
+     * @date  2024/07/12 18:29
+     */
+    @Operation(summary = "获取商品编码表详情")
+    @SaCheckPermission("/biz/qyrecordproductdict/detail")
+    @GetMapping("/biz/qyrecordproductdict/detail")
+    public CommonResult<QyRecordProductDict> detail(@Valid QyRecordProductDictIdParam qyRecordProductDictIdParam) {
+        return CommonResult.data(qyRecordProductDictService.detail(qyRecordProductDictIdParam));
+    }
+}

+ 82 - 0
snowy-plugin/snowy-plugin-biz/src/main/java/vip/xiaonuo/biz/modular/qyrecordproductdict/entity/QyRecordProductDict.java

@@ -0,0 +1,82 @@
+/*
+ * Copyright [2022] [https://www.xiaonuo.vip]
+ *
+ * Snowy采用APACHE LICENSE 2.0开源协议,您在使用过程中,需要注意以下几点:
+ *
+ * 1.请不要删除和修改根目录下的LICENSE文件。
+ * 2.请不要删除和修改Snowy源码头部的版权声明。
+ * 3.本项目代码可免费商业使用,商业使用请保留源码和相关描述文件的项目出处,作者声明等。
+ * 4.分发源码时候,请注明软件出处 https://www.xiaonuo.vip
+ * 5.不可二次分发开源参与同类竞品,如有想法可联系团队xiaonuobase@qq.com商议合作。
+ * 6.若您的项目无法满足以上几点,需要更多功能代码,获取Snowy商业授权许可,请在官网购买授权,地址为 https://www.xiaonuo.vip
+ */
+package vip.xiaonuo.biz.modular.qyrecordproductdict.entity;
+import com.alibaba.excel.annotation.ExcelProperty;
+import com.alibaba.excel.annotation.write.style.ColumnWidth;
+import com.baomidou.mybatisplus.annotation.*;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Getter;
+import lombok.Setter;
+import java.math.BigDecimal;
+import java.util.Date;
+
+/**
+ * 商品编码表实体
+ *
+ * @author hgx
+ * @date  2024/07/12 18:29
+ **/
+@Getter
+@Setter
+@TableName("qy_record_product_dict")
+public class QyRecordProductDict {
+
+    /** ID */
+    @TableId
+    @Schema(description = "ID")
+    @ColumnWidth(12)
+    @ExcelProperty(index = 0,value = "ID")
+    private String id;
+
+    /** 商品编号 */
+    @Schema(description = "商品编号")
+    @ColumnWidth(12)
+    @ExcelProperty(index = 1,value = "商品编号")
+    private String productCode;
+
+    /** 商品名称 */
+    @Schema(description = "商品名称")
+    @ColumnWidth(12)
+    @ExcelProperty(index = 2,value = "商品名称")
+    private String productName;
+
+    /** 年份 */
+    @Schema(description = "年份")
+    @ColumnWidth(12)
+    @ExcelProperty(index = 3,value = "年份")
+    private String year;
+
+    /** 第一计量单位编码 */
+    @Schema(description = "第一计量单位编码")
+    @ColumnWidth(12)
+    @ExcelProperty(index = 4,value = "第一计量单位编码")
+    private String firstUnitCode;
+
+    /** 第一计量单位名称 */
+    @Schema(description = "第一计量单位名称")
+    @ColumnWidth(12)
+    @ExcelProperty(index = 5,value = "第一计量单位名称")
+    private String firstUnitName;
+
+    /** 第二计量单位编码 */
+    @Schema(description = "第二计量单位编码")
+    @ColumnWidth(12)
+    @ExcelProperty(index = 6,value = "第二计量单位编码")
+    private String secondUnitCode;
+
+    /** 第二计量单位名称 */
+    @Schema(description = "第二计量单位名称")
+    @ColumnWidth(12)
+    @ExcelProperty(index = 7,value = "第二计量单位名称")
+    private String secondUnitName;
+}

+ 34 - 0
snowy-plugin/snowy-plugin-biz/src/main/java/vip/xiaonuo/biz/modular/qyrecordproductdict/enums/QyRecordProductDictEnum.java

@@ -0,0 +1,34 @@
+/*
+ * Copyright [2022] [https://www.xiaonuo.vip]
+ *
+ * Snowy采用APACHE LICENSE 2.0开源协议,您在使用过程中,需要注意以下几点:
+ *
+ * 1.请不要删除和修改根目录下的LICENSE文件。
+ * 2.请不要删除和修改Snowy源码头部的版权声明。
+ * 3.本项目代码可免费商业使用,商业使用请保留源码和相关描述文件的项目出处,作者声明等。
+ * 4.分发源码时候,请注明软件出处 https://www.xiaonuo.vip
+ * 5.不可二次分发开源参与同类竞品,如有想法可联系团队xiaonuobase@qq.com商议合作。
+ * 6.若您的项目无法满足以上几点,需要更多功能代码,获取Snowy商业授权许可,请在官网购买授权,地址为 https://www.xiaonuo.vip
+ */
+package vip.xiaonuo.biz.modular.qyrecordproductdict.enums;
+
+import lombok.Getter;
+
+/**
+ * 商品编码表枚举
+ *
+ * @author hgx
+ * @date  2024/07/12 18:29
+ **/
+@Getter
+public enum QyRecordProductDictEnum {
+
+    /** 测试 */
+    TEST("TEST");
+
+    private final String value;
+
+    QyRecordProductDictEnum(String value) {
+        this.value = value;
+    }
+}

+ 25 - 0
snowy-plugin/snowy-plugin-biz/src/main/java/vip/xiaonuo/biz/modular/qyrecordproductdict/mapper/QyRecordProductDictMapper.java

@@ -0,0 +1,25 @@
+/*
+ * Copyright [2022] [https://www.xiaonuo.vip]
+ *
+ * Snowy采用APACHE LICENSE 2.0开源协议,您在使用过程中,需要注意以下几点:
+ *
+ * 1.请不要删除和修改根目录下的LICENSE文件。
+ * 2.请不要删除和修改Snowy源码头部的版权声明。
+ * 3.本项目代码可免费商业使用,商业使用请保留源码和相关描述文件的项目出处,作者声明等。
+ * 4.分发源码时候,请注明软件出处 https://www.xiaonuo.vip
+ * 5.不可二次分发开源参与同类竞品,如有想法可联系团队xiaonuobase@qq.com商议合作。
+ * 6.若您的项目无法满足以上几点,需要更多功能代码,获取Snowy商业授权许可,请在官网购买授权,地址为 https://www.xiaonuo.vip
+ */
+package vip.xiaonuo.biz.modular.qyrecordproductdict.mapper;
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import vip.xiaonuo.biz.modular.qyrecordproductdict.entity.QyRecordProductDict;
+
+/**
+ * 商品编码表Mapper接口
+ *
+ * @author hgx
+ * @date  2024/07/12 18:29
+ **/
+public interface QyRecordProductDictMapper extends BaseMapper<QyRecordProductDict> {
+}

+ 5 - 0
snowy-plugin/snowy-plugin-biz/src/main/java/vip/xiaonuo/biz/modular/qyrecordproductdict/mapper/mapping/QyRecordProductDictMapper.xml

@@ -0,0 +1,5 @@
+<?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="vip.xiaonuo.biz.modular.qyrecordproductdict.mapper.QyRecordProductDictMapper">
+
+</mapper>

+ 69 - 0
snowy-plugin/snowy-plugin-biz/src/main/java/vip/xiaonuo/biz/modular/qyrecordproductdict/param/QyRecordProductDictAddParam.java

@@ -0,0 +1,69 @@
+/*
+ * Copyright [2022] [https://www.xiaonuo.vip]
+ *
+ * Snowy采用APACHE LICENSE 2.0开源协议,您在使用过程中,需要注意以下几点:
+ *
+ * 1.请不要删除和修改根目录下的LICENSE文件。
+ * 2.请不要删除和修改Snowy源码头部的版权声明。
+ * 3.本项目代码可免费商业使用,商业使用请保留源码和相关描述文件的项目出处,作者声明等。
+ * 4.分发源码时候,请注明软件出处 https://www.xiaonuo.vip
+ * 5.不可二次分发开源参与同类竞品,如有想法可联系团队xiaonuobase@qq.com商议合作。
+ * 6.若您的项目无法满足以上几点,需要更多功能代码,获取Snowy商业授权许可,请在官网购买授权,地址为 https://www.xiaonuo.vip
+ */
+package vip.xiaonuo.biz.modular.qyrecordproductdict.param;
+
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Getter;
+import lombok.Setter;
+
+import jakarta.validation.constraints.NotBlank;
+import jakarta.validation.constraints.NotNull;
+import java.math.BigDecimal;
+import java.util.Date;
+
+/**
+ * 商品编码表添加参数
+ *
+ * @author hgx
+ * @date  2024/07/12 18:29
+ **/
+@Getter
+@Setter
+public class QyRecordProductDictAddParam {
+
+    /** 商品编号 */
+    @Schema(description = "商品编号", requiredMode = Schema.RequiredMode.REQUIRED)
+    @NotBlank(message = "productCode不能为空")
+    private String productCode;
+
+    /** 商品名称 */
+    @Schema(description = "商品名称", requiredMode = Schema.RequiredMode.REQUIRED)
+    @NotBlank(message = "productName不能为空")
+    private String productName;
+
+    /** 年份 */
+    @Schema(description = "年份", requiredMode = Schema.RequiredMode.REQUIRED)
+    @NotBlank(message = "year不能为空")
+    private String year;
+
+    /** 第一计量单位编码 */
+    @Schema(description = "第一计量单位编码", requiredMode = Schema.RequiredMode.REQUIRED)
+    @NotBlank(message = "firstUnitCode不能为空")
+    private String firstUnitCode;
+
+    /** 第一计量单位名称 */
+    @Schema(description = "第一计量单位名称", requiredMode = Schema.RequiredMode.REQUIRED)
+    @NotBlank(message = "firstUnitName不能为空")
+    private String firstUnitName;
+
+    /** 第二计量单位编码 */
+    @Schema(description = "第二计量单位编码", requiredMode = Schema.RequiredMode.REQUIRED)
+    @NotBlank(message = "secondUnitCode不能为空")
+    private String secondUnitCode;
+
+    /** 第二计量单位名称 */
+    @Schema(description = "第二计量单位名称", requiredMode = Schema.RequiredMode.REQUIRED)
+    @NotBlank(message = "secondUnitName不能为空")
+    private String secondUnitName;
+
+}

+ 74 - 0
snowy-plugin/snowy-plugin-biz/src/main/java/vip/xiaonuo/biz/modular/qyrecordproductdict/param/QyRecordProductDictEditParam.java

@@ -0,0 +1,74 @@
+/*
+ * Copyright [2022] [https://www.xiaonuo.vip]
+ *
+ * Snowy采用APACHE LICENSE 2.0开源协议,您在使用过程中,需要注意以下几点:
+ *
+ * 1.请不要删除和修改根目录下的LICENSE文件。
+ * 2.请不要删除和修改Snowy源码头部的版权声明。
+ * 3.本项目代码可免费商业使用,商业使用请保留源码和相关描述文件的项目出处,作者声明等。
+ * 4.分发源码时候,请注明软件出处 https://www.xiaonuo.vip
+ * 5.不可二次分发开源参与同类竞品,如有想法可联系团队xiaonuobase@qq.com商议合作。
+ * 6.若您的项目无法满足以上几点,需要更多功能代码,获取Snowy商业授权许可,请在官网购买授权,地址为 https://www.xiaonuo.vip
+ */
+package vip.xiaonuo.biz.modular.qyrecordproductdict.param;
+
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Getter;
+import lombok.Setter;
+
+import jakarta.validation.constraints.NotBlank;
+import jakarta.validation.constraints.NotNull;
+import java.math.BigDecimal;
+import java.util.Date;
+
+/**
+ * 商品编码表编辑参数
+ *
+ * @author hgx
+ * @date  2024/07/12 18:29
+ **/
+@Getter
+@Setter
+public class QyRecordProductDictEditParam {
+
+    /** ID */
+    @Schema(description = "ID", requiredMode = Schema.RequiredMode.REQUIRED)
+    @NotBlank(message = "id不能为空")
+    private String id;
+
+    /** 商品编号 */
+    @Schema(description = "商品编号", requiredMode = Schema.RequiredMode.REQUIRED)
+    @NotBlank(message = "productCode不能为空")
+    private String productCode;
+
+    /** 商品名称 */
+    @Schema(description = "商品名称", requiredMode = Schema.RequiredMode.REQUIRED)
+    @NotBlank(message = "productName不能为空")
+    private String productName;
+
+    /** 年份 */
+    @Schema(description = "年份", requiredMode = Schema.RequiredMode.REQUIRED)
+    @NotBlank(message = "year不能为空")
+    private String year;
+
+    /** 第一计量单位编码 */
+    @Schema(description = "第一计量单位编码", requiredMode = Schema.RequiredMode.REQUIRED)
+    @NotBlank(message = "firstUnitCode不能为空")
+    private String firstUnitCode;
+
+    /** 第一计量单位名称 */
+    @Schema(description = "第一计量单位名称", requiredMode = Schema.RequiredMode.REQUIRED)
+    @NotBlank(message = "firstUnitName不能为空")
+    private String firstUnitName;
+
+    /** 第二计量单位编码 */
+    @Schema(description = "第二计量单位编码", requiredMode = Schema.RequiredMode.REQUIRED)
+    @NotBlank(message = "secondUnitCode不能为空")
+    private String secondUnitCode;
+
+    /** 第二计量单位名称 */
+    @Schema(description = "第二计量单位名称", requiredMode = Schema.RequiredMode.REQUIRED)
+    @NotBlank(message = "secondUnitName不能为空")
+    private String secondUnitName;
+
+}

+ 35 - 0
snowy-plugin/snowy-plugin-biz/src/main/java/vip/xiaonuo/biz/modular/qyrecordproductdict/param/QyRecordProductDictIdParam.java

@@ -0,0 +1,35 @@
+/*
+ * Copyright [2022] [https://www.xiaonuo.vip]
+ *
+ * Snowy采用APACHE LICENSE 2.0开源协议,您在使用过程中,需要注意以下几点:
+ *
+ * 1.请不要删除和修改根目录下的LICENSE文件。
+ * 2.请不要删除和修改Snowy源码头部的版权声明。
+ * 3.本项目代码可免费商业使用,商业使用请保留源码和相关描述文件的项目出处,作者声明等。
+ * 4.分发源码时候,请注明软件出处 https://www.xiaonuo.vip
+ * 5.不可二次分发开源参与同类竞品,如有想法可联系团队xiaonuobase@qq.com商议合作。
+ * 6.若您的项目无法满足以上几点,需要更多功能代码,获取Snowy商业授权许可,请在官网购买授权,地址为 https://www.xiaonuo.vip
+ */
+package vip.xiaonuo.biz.modular.qyrecordproductdict.param;
+
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Getter;
+import lombok.Setter;
+
+import jakarta.validation.constraints.NotBlank;
+
+/**
+ * 商品编码表Id参数
+ *
+ * @author hgx
+ * @date  2024/07/12 18:29
+ **/
+@Getter
+@Setter
+public class QyRecordProductDictIdParam {
+
+    /** ID */
+    @Schema(description = "ID", requiredMode = Schema.RequiredMode.REQUIRED)
+    @NotBlank(message = "id不能为空")
+    private String id;
+}

+ 59 - 0
snowy-plugin/snowy-plugin-biz/src/main/java/vip/xiaonuo/biz/modular/qyrecordproductdict/param/QyRecordProductDictPageParam.java

@@ -0,0 +1,59 @@
+/*
+ * Copyright [2022] [https://www.xiaonuo.vip]
+ *
+ * Snowy采用APACHE LICENSE 2.0开源协议,您在使用过程中,需要注意以下几点:
+ *
+ * 1.请不要删除和修改根目录下的LICENSE文件。
+ * 2.请不要删除和修改Snowy源码头部的版权声明。
+ * 3.本项目代码可免费商业使用,商业使用请保留源码和相关描述文件的项目出处,作者声明等。
+ * 4.分发源码时候,请注明软件出处 https://www.xiaonuo.vip
+ * 5.不可二次分发开源参与同类竞品,如有想法可联系团队xiaonuobase@qq.com商议合作。
+ * 6.若您的项目无法满足以上几点,需要更多功能代码,获取Snowy商业授权许可,请在官网购买授权,地址为 https://www.xiaonuo.vip
+ */
+package vip.xiaonuo.biz.modular.qyrecordproductdict.param;
+
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Getter;
+import lombok.Setter;
+import java.math.BigDecimal;
+import java.util.Date;
+
+/**
+ * 商品编码表查询参数
+ *
+ * @author hgx
+ * @date  2024/07/12 18:29
+ **/
+@Getter
+@Setter
+public class QyRecordProductDictPageParam {
+
+    /** 当前页 */
+    @Schema(description = "当前页码")
+    private Integer current;
+
+    /** 每页条数 */
+    @Schema(description = "每页条数")
+    private Integer size;
+
+    /** 排序字段 */
+    @Schema(description = "排序字段,字段驼峰名称,如:userName")
+    private String sortField;
+
+    /** 排序方式 */
+    @Schema(description = "排序方式,升序:ASCEND;降序:DESCEND")
+    private String sortOrder;
+
+    /** 关键词 */
+    @Schema(description = "关键词")
+    private String searchKey;
+
+    /** 商品编号 */
+    @Schema(description = "商品编号")
+    private String productCode;
+
+    /** 商品名称 */
+    @Schema(description = "商品名称")
+    private String productName;
+
+}

+ 80 - 0
snowy-plugin/snowy-plugin-biz/src/main/java/vip/xiaonuo/biz/modular/qyrecordproductdict/service/QyRecordProductDictService.java

@@ -0,0 +1,80 @@
+/*
+ * Copyright [2022] [https://www.xiaonuo.vip]
+ *
+ * Snowy采用APACHE LICENSE 2.0开源协议,您在使用过程中,需要注意以下几点:
+ *
+ * 1.请不要删除和修改根目录下的LICENSE文件。
+ * 2.请不要删除和修改Snowy源码头部的版权声明。
+ * 3.本项目代码可免费商业使用,商业使用请保留源码和相关描述文件的项目出处,作者声明等。
+ * 4.分发源码时候,请注明软件出处 https://www.xiaonuo.vip
+ * 5.不可二次分发开源参与同类竞品,如有想法可联系团队xiaonuobase@qq.com商议合作。
+ * 6.若您的项目无法满足以上几点,需要更多功能代码,获取Snowy商业授权许可,请在官网购买授权,地址为 https://www.xiaonuo.vip
+ */
+package vip.xiaonuo.biz.modular.qyrecordproductdict.service;
+
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.baomidou.mybatisplus.extension.service.IService;
+import vip.xiaonuo.biz.modular.qyrecordproductdict.entity.QyRecordProductDict;
+import vip.xiaonuo.biz.modular.qyrecordproductdict.param.QyRecordProductDictAddParam;
+import vip.xiaonuo.biz.modular.qyrecordproductdict.param.QyRecordProductDictEditParam;
+import vip.xiaonuo.biz.modular.qyrecordproductdict.param.QyRecordProductDictIdParam;
+import vip.xiaonuo.biz.modular.qyrecordproductdict.param.QyRecordProductDictPageParam;
+
+import java.util.List;
+
+/**
+ * 商品编码表Service接口
+ *
+ * @author hgx
+ * @date  2024/07/12 18:29
+ **/
+public interface QyRecordProductDictService extends IService<QyRecordProductDict> {
+
+    /**
+     * 获取商品编码表分页
+     *
+     * @author hgx
+     * @date  2024/07/12 18:29
+     */
+    Page<QyRecordProductDict> page(QyRecordProductDictPageParam qyRecordProductDictPageParam);
+
+    /**
+     * 添加商品编码表
+     *
+     * @author hgx
+     * @date  2024/07/12 18:29
+     */
+    void add(QyRecordProductDictAddParam qyRecordProductDictAddParam);
+
+    /**
+     * 编辑商品编码表
+     *
+     * @author hgx
+     * @date  2024/07/12 18:29
+     */
+    void edit(QyRecordProductDictEditParam qyRecordProductDictEditParam);
+
+    /**
+     * 删除商品编码表
+     *
+     * @author hgx
+     * @date  2024/07/12 18:29
+     */
+    void delete(List<QyRecordProductDictIdParam> qyRecordProductDictIdParamList);
+
+    /**
+     * 获取商品编码表详情
+     *
+     * @author hgx
+     * @date  2024/07/12 18:29
+     */
+    QyRecordProductDict detail(QyRecordProductDictIdParam qyRecordProductDictIdParam);
+
+    /**
+     * 获取商品编码表详情
+     *
+     * @author hgx
+     * @date  2024/07/12 18:29
+     **/
+    QyRecordProductDict queryEntity(String id);
+}

+ 100 - 0
snowy-plugin/snowy-plugin-biz/src/main/java/vip/xiaonuo/biz/modular/qyrecordproductdict/service/impl/QyRecordProductDictServiceImpl.java

@@ -0,0 +1,100 @@
+/*
+ * Copyright [2022] [https://www.xiaonuo.vip]
+ *
+ * Snowy采用APACHE LICENSE 2.0开源协议,您在使用过程中,需要注意以下几点:
+ *
+ * 1.请不要删除和修改根目录下的LICENSE文件。
+ * 2.请不要删除和修改Snowy源码头部的版权声明。
+ * 3.本项目代码可免费商业使用,商业使用请保留源码和相关描述文件的项目出处,作者声明等。
+ * 4.分发源码时候,请注明软件出处 https://www.xiaonuo.vip
+ * 5.不可二次分发开源参与同类竞品,如有想法可联系团队xiaonuobase@qq.com商议合作。
+ * 6.若您的项目无法满足以上几点,需要更多功能代码,获取Snowy商业授权许可,请在官网购买授权,地址为 https://www.xiaonuo.vip
+ */
+package vip.xiaonuo.biz.modular.qyrecordproductdict.service.impl;
+
+import cn.hutool.core.bean.BeanUtil;
+import cn.hutool.core.collection.CollStreamUtil;
+import cn.hutool.core.util.ObjectUtil;
+import cn.hutool.core.util.StrUtil;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
+import vip.xiaonuo.common.enums.CommonSortOrderEnum;
+import vip.xiaonuo.common.exception.CommonException;
+import vip.xiaonuo.common.page.CommonPageRequest;
+import vip.xiaonuo.biz.modular.qyrecordproductdict.entity.QyRecordProductDict;
+import vip.xiaonuo.biz.modular.qyrecordproductdict.mapper.QyRecordProductDictMapper;
+import vip.xiaonuo.biz.modular.qyrecordproductdict.param.QyRecordProductDictAddParam;
+import vip.xiaonuo.biz.modular.qyrecordproductdict.param.QyRecordProductDictEditParam;
+import vip.xiaonuo.biz.modular.qyrecordproductdict.param.QyRecordProductDictIdParam;
+import vip.xiaonuo.biz.modular.qyrecordproductdict.param.QyRecordProductDictPageParam;
+import vip.xiaonuo.biz.modular.qyrecordproductdict.service.QyRecordProductDictService;
+
+import java.util.List;
+
+/**
+ * 商品编码表Service接口实现类
+ *
+ * @author hgx
+ * @date  2024/07/12 18:29
+ **/
+@Service
+public class QyRecordProductDictServiceImpl extends ServiceImpl<QyRecordProductDictMapper, QyRecordProductDict> implements QyRecordProductDictService {
+
+    @Override
+    public Page<QyRecordProductDict> page(QyRecordProductDictPageParam qyRecordProductDictPageParam) {
+        QueryWrapper<QyRecordProductDict> queryWrapper = new QueryWrapper<QyRecordProductDict>().checkSqlInjection();
+        if(ObjectUtil.isNotEmpty(qyRecordProductDictPageParam.getProductCode())) {
+            queryWrapper.lambda().like(QyRecordProductDict::getProductCode, qyRecordProductDictPageParam.getProductCode());
+        }
+        if(ObjectUtil.isNotEmpty(qyRecordProductDictPageParam.getProductName())) {
+            queryWrapper.lambda().like(QyRecordProductDict::getProductName, qyRecordProductDictPageParam.getProductName());
+        }
+        if(ObjectUtil.isAllNotEmpty(qyRecordProductDictPageParam.getSortField(), qyRecordProductDictPageParam.getSortOrder())) {
+            CommonSortOrderEnum.validate(qyRecordProductDictPageParam.getSortOrder());
+            queryWrapper.orderBy(true, qyRecordProductDictPageParam.getSortOrder().equalsIgnoreCase(CommonSortOrderEnum.ASC.getValue()),
+                    StrUtil.toUnderlineCase(qyRecordProductDictPageParam.getSortField()));
+        } else {
+            queryWrapper.lambda().orderByAsc(QyRecordProductDict::getId);
+        }
+        return this.page(CommonPageRequest.defaultPage(), queryWrapper);
+    }
+
+    @Transactional(rollbackFor = Exception.class)
+    @Override
+    public void add(QyRecordProductDictAddParam qyRecordProductDictAddParam) {
+        QyRecordProductDict qyRecordProductDict = BeanUtil.toBean(qyRecordProductDictAddParam, QyRecordProductDict.class);
+        this.save(qyRecordProductDict);
+    }
+
+    @Transactional(rollbackFor = Exception.class)
+    @Override
+    public void edit(QyRecordProductDictEditParam qyRecordProductDictEditParam) {
+        QyRecordProductDict qyRecordProductDict = this.queryEntity(qyRecordProductDictEditParam.getId());
+        BeanUtil.copyProperties(qyRecordProductDictEditParam, qyRecordProductDict);
+        this.updateById(qyRecordProductDict);
+    }
+
+    @Transactional(rollbackFor = Exception.class)
+    @Override
+    public void delete(List<QyRecordProductDictIdParam> qyRecordProductDictIdParamList) {
+        // 执行删除
+        this.removeByIds(CollStreamUtil.toList(qyRecordProductDictIdParamList, QyRecordProductDictIdParam::getId));
+    }
+
+    @Override
+    public QyRecordProductDict detail(QyRecordProductDictIdParam qyRecordProductDictIdParam) {
+        return this.queryEntity(qyRecordProductDictIdParam.getId());
+    }
+
+    @Override
+    public QyRecordProductDict queryEntity(String id) {
+        QyRecordProductDict qyRecordProductDict = this.getById(id);
+        if(ObjectUtil.isEmpty(qyRecordProductDict)) {
+            throw new CommonException("商品编码表不存在,id值为:{}", id);
+        }
+        return qyRecordProductDict;
+    }
+}