abp(net core)+easyui+efcore实现仓储管理系统目录

abp(net core)+easyui+efcore实现仓储管理系统——EasyUI前端页面框架 (十八)

abp(net core)+easyui+efcore实现仓储管理系统——ABP WebAPI与EasyUI结合增删改查之八(三十四)

 

在上一篇文章abp(net core)+easyui+efcore实现仓储管理系统——入库管理之一(三十七)中我们创建了入库单的实体类,并使用CodeFirst功能创建了数据库表,接下我们来创建一些有关与入库单有关的DTO类与查询分页类。

四、定义应用服务接口需要用到的DTO类

为了在进行查询入库单表头,我们需要创建, PagedInStockResultRequestDto类,用来将查询条件数据传递到基础设施层.

1. 在Visual Studio 2017的“解决方案资源管理器”中,右键单击“ABP.TPLMS.Application”项目,在弹出菜单中选择“添加” > “新建文件夹”,并重命名为“InStocks”

2. 使用鼠标右键单击我们刚才创建的“InStocks”文件夹,在弹出菜单中选择“添加” > “新建文件夹”,并重命名为“Dto”。

3.右键单击“Dto”文件夹,然后选择“添加” > “类”。 将类命名为 Paged InStockResultRequestDto,然后选择“添加”。代码如下。

using Abp.Application.Services.Dto;
using System;
using System.Collections.Generic;
using System.Text; namespace ABP.TPLMS.InStocks.Dto
{ public class PagedInStockResultRequestDto : PagedResultRequestDto
{ public string Keyword { get; set; }
public string InStockNo { get; set; }
public DateTime BeginTime { get; set; }
DateTime m_EndTime;
/// <summary>
/// 查询截止日期,如果当前时间小于100年前,就给一个默认日期(明天)
/// </summary> public DateTime EndTime { get
{ if (m_EndTime < DateTime.Now.AddYears(-))
return DateTime.Now.AddDays();
else
return m_EndTime;
} set
{
m_EndTime = value;
}
} public string OwnerName { get; set; }
public string No { get; set; }
}
}

4.右键单击“Dto”文件夹,然后选择“添加” > “类”。 将类命名为 PagedInStockDetailResultRequestDto,然后选择“添加”。此类根据入库单单号查询入库单的明细数据。代码如下。

using Abp.Application.Services.Dto;
using System;
using System.Collections.Generic;
using System.Text; namespace ABP.TPLMS.InStocks.Dto
{ public class PagedInStockDetailResultRequestDto : PagedResultRequestDto
{ public string Keyword { get; set; }
public string InStockNo { get; set; } }
}

5.右键单击“Dto”文件夹,然后选择“添加” > “类”。 将类命名为 PagedInStockDetailLocResultRequestDto,然后选择“添加”。此类根据入库单明细的ID查询入库单某条明细数据的库位信息。代码如下。

using Abp.Application.Services.Dto;
using System;
using System.Collections.Generic;
using System.Text; namespace ABP.TPLMS.InStocks.Dto
{ public class PagedInStockDetailLocResultRequestDto : PagedResultRequestDto
{ public string Keyword { get; set; }
public int InStockOrderDetailId { get; set; } }
}

6.右键单击“Dto”文件夹,然后选择“添加” > “类”。 将类命名为 InStockOrderDto,然后选择“添加”。代码如下。

using Abp.Application.Services.Dto;
using Abp.AutoMapper;
using ABP.TPLMS.Entitys;
using System;
using System.Collections.Generic;
using System.Text; namespace ABP.TPLMS.InStocks.Dto
{ [AutoMapFrom(typeof(InStockOrder))]
public class InStockOrderDto : EntityDto<int>
{ public string No { get; set; }
/// <summary>
/// 客户名称
/// </summary>
public string CustomerName { get; set; } public string WarehouseType { get; set; } /// <summary>
/// 客户代码
/// </summary>
public string CustomerCode { get; set; } /// <summary>
/// 送货单号
/// </summary>
public string DeliveryNo { get; set; }
/// <summary>
/// 仓库号
/// </summary>
public string WarehouseNo { get; set; } /// <summary>
/// 货主
/// </summary>
public string OwnerName { get; set; } /// <summary>
/// 毛重
/// </summary>
public decimal Gwt { get; set; }
public decimal Nwt { get; set; }
public int PackageQty { get; set; } /// <summary>
/// 接收时间
/// </summary>
public string ReceiveTime { get; set; } /// <summary>
/// 接收人
/// </summary> public string Receiver { get; set; }
public string Oper { get; set; }
public int Status { get; set; }
public string OwnerCode { get; set; } /// <summary>
/// 预计送货时间
/// </summary> public string PreDeliveryTime { get; set; } /// <summary>
/// 审核人
/// </summary> public string Checker { get; set; }
public string CheckTime { get; set; } public string Remark { get; set; }
public DateTime CreationTime { get; set; } public string LastUpdateTime { get; set; }
public string LastOper { get; set; } public List<InStockOrderDetailDto> InStockOrderDetail { get; set; } } }

7.右键单击“Dto”文件夹,然后选择“添加” > “类”。 将类命名为 CreateUpdateInStockOrderDto,然后选择“添加”。代码如下。

using Abp.Application.Services.Dto;
using Abp.AutoMapper;
using ABP.TPLMS.Entitys;
using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
using System.Text; namespace ABP.TPLMS.InStocks.Dto
{ [AutoMapTo(typeof(InStockOrder))]
public class CreateUpdateInStockOrderDto : EntityDto<int>
{ public const int MaxLength = ; [StringLength()]
[Required]
public string No { get; set; } /// <summary>
/// 客户名称
/// </summary> [StringLength(MaxLength)]
[Required]
public string CustomerName { get; set; } public string WarehouseType { get; set; } /// <summary>
/// 客户代码
/// </summary> [StringLength()]
[Required]
public string CustomerCode { get; set; } /// <summary>
/// 送货单号
/// </summary>
public string DeliveryNo { get; set; } /// <summary>
/// 仓库号
/// </summary>
public string WarehouseNo { get; set; } /// <summary>
/// 货主
/// </summary>
[StringLength(MaxLength)]
[Required]
public string OwnerName { get; set; }
public decimal Gwt { get; set; }
public decimal Nwt { get; set; }
public int PackageQty { get; set; } /// <summary>
/// 接收时间
/// </summary>
[StringLength()]
public string ReceiveTime { get; set; } /// <summary>
/// 接收人
/// </summary>
[StringLength()]
public string Receiver { get; set; } [StringLength()] public string Oper { get; set; }
public int Status { get; set; }
[StringLength()]
public string OwnerCode { get; set; } /// <summary>
/// 预计送货时间
/// </summary>
[StringLength()]
public string PreDeliveryTime { get; set; } /// <summary>
/// 审核人
/// </summary>
[StringLength()]
public string Checker { get; set; }
[StringLength()]
public string CheckTime { get; set; }
[StringLength()]
public string Remark { get; set; }
public DateTime CreationTime { get; set; } [StringLength()]
public string LastUpdateTime { get; set; } [StringLength()]
public string LastOper { get; set; }
public List<CreateUpdateInStockOrderDetailDto> InStockOrderDetail { get; set; }
}
}
 
   8. 重复上面的第6-7步,我们来创建InStockDetailDto与CreateUpdateInStockDetailDto、InStockDetailLocDto与CreateUpdateInStockDetailLocDto。

8.1 InStockDetailDto

using Abp.Application.Services.Dto;
using Abp.AutoMapper;
using Abp.Domain.Entities;
using Abp.Domain.Entities.Auditing;
using ABP.TPLMS.Entitys;
using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;
using System.Text; namespace ABP.TPLMS.InStocks.Dto
{ [AutoMapFrom(typeof(InStockOrderDetail))]
public class InStockOrderDetailDto : EntityDto<int>
{ public int SupplierId { get; set; } public string CargoCode { get; set; }
public string HSCode { get; set; }
public string CargoName { get; set; }
public string Spcf { get; set; } public string Unit { get; set; }
public string Country { get; set; }
public string Brand { get; set; }
public string Curr { get; set; }
public string Package { get; set; } public decimal Length { get; set; } public decimal Width { get; set; } public decimal Height { get; set; }
public decimal Vol { get; set; } public decimal Price { get; set; }
public decimal TotalAmt { get; set; } public decimal GrossWt { get; set; }
public decimal NetWt { get; set; }
public DateTime CreationTime { get; set; } public string InStockNo { get; set; }
public int SeqNo { get; set; } public decimal Qty { get; set; }
public decimal LawfQty { get; set; }
public decimal SecdLawfQty { get; set; } public string LawfUnit { get; set; }
public string SecdLawfUnit { get; set; } public string Batch { get; set; }
public int DeliveryOrderDetailId { get; set; }
[NotMapped]
public List<InStockOrderDetailLoc> InStockOrderDetailLoc { get; set; }
}
}

8.2 CreateUpdateInStockDetailDto

using Abp.Application.Services.Dto;
using Abp.AutoMapper;
using Abp.Domain.Entities;
using Abp.Domain.Entities.Auditing;
using ABP.TPLMS.Entitys;
using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;
using System.Text; namespace ABP.TPLMS.InStocks.Dto
{ [AutoMapTo(typeof(InStockOrderDetail))]
public class CreateUpdateInStockOrderDetailDto : EntityDto<int>
{ public const int MaxLength = ;
public int SupplierId { get; set; }
[MaxLength()]
public string CargoCode { get; set; } [MaxLength()]
public string HSCode { get; set; } [MaxLength(MaxLength)]
public string CargoName { get; set; } [MaxLength(MaxLength)]
public string Spcf { get; set; } [MaxLength()]
public string Unit { get; set; } [MaxLength()]
public string Country { get; set; } [MaxLength()]
public string Brand { get; set; } [MaxLength()]
public string Curr { get; set; } [MaxLength()]
public string Package { get; set; } public decimal Length { get; set; }
public decimal Width { get; set; } public decimal Height { get; set; }
public decimal Vol { get; set; } public decimal Price { get; set; }
public decimal TotalAmt { get; set; }
public decimal GrossWt { get; set; } public decimal NetWt { get; set; } public DateTime CreationTime { get; set; } [MaxLength()]
public string InStockNo { get; set; }
public int SeqNo { get; set; }
public decimal Qty { get; set; }
public decimal LawfQty { get; set; } public decimal SecdLawfQty { get; set; } [MaxLength()]
public string LawfUnit { get; set; }
[MaxLength()]
public string SecdLawfUnit { get; set; }
[MaxLength()] public string Batch { get; set; }
public int DeliveryOrderDetailId { get; set; } [NotMapped]
public List<InStockOrderDetailLoc> InStockOrderDetailLoc { get; set; } }
}

8.3  InStockDetailLocDto

using Abp.Application.Services.Dto;
using Abp.AutoMapper;
using Abp.Domain.Entities;
using Abp.Domain.Entities.Auditing;
using ABP.TPLMS.Entitys;
using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
using System.Text; namespace ABP.TPLMS.InStocks.Dto
{ public class InStockOrderDetailLocDto : EntityDto<int>
{
[AutoMapFrom(typeof(InStockOrderDetailLoc))]
public InStockOrderDetailLocDto()
{
this.Qty = ;
this.SeqNo = ;
this.Loc = string.Empty;
this.CreationTime = DateTime.Now;
this.InStockOrderDetailId = ; } public int InStockOrderDetailId { get; set; }
public int SeqNo { get; set; }
public string Loc { get; set; }
public decimal Qty { get; set; }
public DateTime CreationTime { get; set; }
}
}

8.4  CreateUpdateInStockDetailLocDto。

using Abp.Application.Services.Dto;
using Abp.AutoMapper;
using Abp.Domain.Entities;
using Abp.Domain.Entities.Auditing;
using ABP.TPLMS.Entitys;
using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
using System.Text; namespace ABP.TPLMS.InStocks.Dto
{ public class CreateUpdateInStockOrderDetailLocDto : EntityDto<int>
{ [AutoMapTo(typeof(InStockOrderDetailLoc))]
public CreateUpdateInStockOrderDetailLocDto()
{ this.Qty = ;
this.SeqNo = ;
this.Loc = string.Empty;
this.CreationTime = DateTime.Now;
this.InStockOrderDetailId = ;
}
public int InStockOrderDetailId { get; set; }
public int SeqNo { get; set; }
[StringLength()]
public string Loc { get; set; }
public decimal Qty { get; set; }
public DateTime CreationTime { get; set; }
}
}
 

bp(net core)+easyui+efcore实现仓储管理系统——入库管理之二(三十八)的更多相关文章

  1. bp(net core)+easyui+efcore实现仓储管理系统——入库管理之三存储过程(三十九)

    abp(net core)+easyui+efcore实现仓储管理系统目录 abp(net core)+easyui+efcore实现仓储管理系统——ABP总体介绍(一) abp(net core)+ ...

  2. abp(net core)+easyui+efcore实现仓储管理系统——入库管理之九(四十五)

    abp(net core)+easyui+efcore实现仓储管理系统目录 abp(net core)+easyui+efcore实现仓储管理系统——ABP总体介绍(一) abp(net core)+ ...

  3. abp(net core)+easyui+efcore实现仓储管理系统——入库管理之四(四十)

    abp(net core)+easyui+efcore实现仓储管理系统目录 abp(net core)+easyui+efcore实现仓储管理系统——ABP总体介绍(一) abp(net core)+ ...

  4. abp(net core)+easyui+efcore实现仓储管理系统——入库管理之五(四十一)

    abp(net core)+easyui+efcore实现仓储管理系统目录 abp(net core)+easyui+efcore实现仓储管理系统——ABP总体介绍(一) abp(net core)+ ...

  5. abp(net core)+easyui+efcore实现仓储管理系统——入库管理之六(四十二)

    abp(net core)+easyui+efcore实现仓储管理系统目录 abp(net core)+easyui+efcore实现仓储管理系统——ABP总体介绍(一) abp(net core)+ ...

  6. abp(net core)+easyui+efcore实现仓储管理系统——入库管理之七(四十三)

    abp(net core)+easyui+efcore实现仓储管理系统目录 abp(net core)+easyui+efcore实现仓储管理系统——ABP总体介绍(一) abp(net core)+ ...

  7. abp(net core)+easyui+efcore实现仓储管理系统——入库管理之八(四十四)

    abp(net core)+easyui+efcore实现仓储管理系统目录 abp(net core)+easyui+efcore实现仓储管理系统——ABP总体介绍(一) abp(net core)+ ...

  8. abp(net core)+easyui+efcore实现仓储管理系统——入库管理之十(四十六)

    abp(net core)+easyui+efcore实现仓储管理系统目录 abp(net core)+easyui+efcore实现仓储管理系统——ABP总体介绍(一) abp(net core)+ ...

  9. abp(net core)+easyui+efcore实现仓储管理系统——入库管理之十一(四十七)

    abp(net core)+easyui+efcore实现仓储管理系统目录 abp(net core)+easyui+efcore实现仓储管理系统——ABP总体介绍(一) abp(net core)+ ...

随机推荐

  1. 吴裕雄--天生自然 pythonTensorFlow图形数据处理:读取MNIST手写图片数据写入的TFRecord文件

    import numpy as np import tensorflow as tf from tensorflow.examples.tutorials.mnist import input_dat ...

  2. 唐顿庄园S01E01观看感悟

    刚刚看了唐顿庄园的第一季第一集.看第一遍的时候,主要是看剧情,看看有没有什么吸引人的.我是一带而过的.等到看第二遍的时候,仔细观察画面,欣赏画面的美感,琢磨人物的台词对话.不断的倒退回放,越看越有滋味 ...

  3. JavaScript 的 URL 对象是什么?

    如果我们自己编写从URL中分析和提取元素的代码,那么有可能会比较痛苦和麻烦.程序员作为这个社会中最“懒”的群体之一,无休止的重复造轮子必然是令人难以容忍的,所以大多数浏览器的标准库中都已经内置了URL ...

  4. socker通信-struct模块-粘包问题

    Socket概念 Socket是应用层与TCP/IP协议族通信的中间软件抽象层,它是一组接口.在设计模式中,Socket其实就是一个门面模式,它把复杂的TCP/IP协议族隐藏在Socket接口后面,对 ...

  5. linux_cat命令

    cat 命令可以用来显示文本文件的内容(类似于 DOS 下的 type 命令),也可以把几个文件内容附加到另一个文件中,即连接合并文件. 关于此命令,有人认为写 cat 命令的人是因为喜欢猫,因此给此 ...

  6. B - Sequence II (HDU 5147)

    Long long ago, there is a sequence A with length n. All numbers in this sequence is no smaller than ...

  7. java作业-----方法重载

    满足方法重载的条件:1.方法名相同    2.参数类型不同,参数个数不同,参数类型的顺序不同. 同时,方法的返回值不作为方法重载的判断条件.

  8. jsp 页面内容导出到Excel中

    日常使用网络资源时经常需要把网页中的内容下载到本地,并且导出到Excel中,现在介绍一种非常简单的方式实现网络资源的下载.只需要讲jsp的最上面加上一句话 <% response.reset() ...

  9. ibatis in语句参数传入方法

    第一种:传入参数仅有数组        <select id="GetEmailList_Test"  resultClass="EmailInfo_"& ...

  10. CPU内核、用户模式

    本文由是阅读该文章做下的笔记. CPU分内核与用户模式. 三言蔽之 内核模式下,应用可以直接存取内存,能够执行任何CPU指令.一般来说驱动运行在该模式下.内核模式的应用一旦崩溃,整个操作系统都会崩溃. ...