allbet gmaing代理:abp(net core)+easyui+efcore实现仓储治理系统——出库治理之一(四十九)

admin 4个月前 (06-01) 科技 39 0

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

abp(net core)+easyui+efcore实现仓储治理系统——ABP总体先容(一) abp(net core)+easyui+efcore实现仓储治理系统——解决方案先容(二) abp(net core)+easyui+efcore实现仓储治理系统——领域层建立实体(三) &NBsp;abp(net core)+easyui+efcore实现仓储治理系统——界说仓储并实现 (四) abp(net core)+easyui+efcore实现仓储治理系统——建立应用服务(五) abp(net core)+easyui+efcore实现仓储治理系统——展现层实现增删改查之控制器(六) abp(net core)+easyui+efcore实现仓储治理系统——展现层实现增删改查之列表视图(七) abp(net core)+easyui+efcore实现仓储治理系统——展现层实现增删改查之增删改视图(八) abp(net core)+easyui+efcore实现仓储治理系统——展现层实现增删改查之菜单与测试(九) abp(net core)+easyui+efcore实现仓储治理系统——使用 WEBAPI实现CURD (十一)

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

abp(net core)+easyui+efcore实现仓储治理系统——EasyUI之货物治理一 (十九) abp(net core)+easyui+efcore实现仓储治理系统——ABP WebAPI与EasyUI连系增删改查之一(二十七) abp(net core)+easyui+efcore实现仓储治理系统——ABP WebAPI与EasyUI连系增删改查之三(二十九) abp(net core)+easyui+efcore实现仓储治理系统——ABP WebAPI与EasyUI连系增删改查之八(三十四) abp(net core)+easyui+efcore实现仓储治理系统——ABP WebAPI与EasyUI连系增删改查之十(三十六) abp(net core)+easyui+efcore实现仓储治理系统——入库治理之一(三十七) abp(net core)+easyui+efcore实现仓储治理系统——入库治理之二(三十八) abp(net core)+easyui+efcore实现仓储治理系统——入库治理之三存储历程(三十九) abp(net core)+easyui+efcore实现仓储治理系统——入库治理之四(四十) abp(net core)+easyui+efcore实现仓储治理系统——入库治理之五(四十一) abp(net core)+easyui+efcore实现仓储治理系统——入库治理之六(四十二) abp(net core)+easyui+efcore实现仓储治理系统——入库治理之七(四十三) abp(net core)+easyui+efcore实现仓储治理系统——入库治理之八(四十四)    abp(net core)+easyui+efcore实现仓储治理系统——入库治理之九(四十五) abp(net core)+easyui+efcore实现仓储治理系统——入库治理之十(四十六)
abp(net core)+easyui+efcore实现仓储治理系统——入库治理之十一(四十七) abp(net core)+easyui+efcore实现仓储治理系统——入库治理之十二(四十八)

.前言

        出库单的功效。能学习了出库单治理之后,WMS的 最基本的功效算是完成了。固然一个成熟的WMS还包罗了清点,报表,计谋规则,移库功效及与其他系统(ERP、TMS等)的接口,实现无缝集成,打破信息孤岛,让数据实时、准确和同步。

二、出库单的流程

    1.一样平常情况下会有一个前置的OMS系统——即订单治理系统。主要功效之一是由客户填写订单。

      2.客户把订单下第三方物流公司时,第三方物流公司会天生出货单推送到堆栈时,系统会自动天生拣货单,理货员凭据拣货单拣货,并制作出库单,然后打印标签,粘贴条码标签,分配托盘,核验条码标签,货物装箱,订舱出库,并在系统中对出库单举行审核通过。整个流程如下图。

 

     固然我们接下来要实现的出库单功效,没有这么庞大。

 

三、建立出库单实体

    1. 做为一个出库单,在数据库中一样平常存在两张表,表头OutStockOrder,表体OutStocKDetail

    2.Visual Studio 2017的“解决方案资源治理器”中,右键单击“ABP.TPLMS.Core”项目的“Entitys”文件夹,在弹出菜单中选择“添加” >

 > “类”。 将类命名为 OutStockOrder,然后选择“添加”。

    3.建立OutStockOrder类继续自Entity<int>,通过实现审计模块中的IHasCreationTime来实现保留建立时间。代码如下:

using Abp.Domain.Entities; using Abp.Domain.Entities.Auditing; using System; using System.Collections.Generic; using System.ComponentModel.DataAnnotations; using System.TeXt; namespace ABP.TPLMS.Entitys { public class OutStockOrder: Entity<int>, IHasCreationTime { public const int MaxLength = 255; public OutStockOrder() { No = string.Empty; CustomerCode = string.Empty; CustomerName = string.Empty; WarehouseNo = string.Empty; DeliveryNo = string.Empty; TallyClerk = string.Empty; TallyTime = string.Empty; CreationTime = DateTime.Now; Oper = string.Empty; Checker = string.Empty; CheckTime = string.Empty; Gwt = 0; Nwt = 0; PackageQty = 0; OwnerCode = string.Empty; OwnerName = string.Empty; Remark = string.Empty; Status = 0; PreOutStockTime = string.Empty; } [StringLength(50)] [Required] public string No { get; set; } /// <summary>
        /// 客户名称 /// </summary>
 [StringLength(MaxLength)] [Required] public string CustomerName { get; set; } /// <summary>
        /// 车牌号 /// </summary>
        public string VehicleNo { get; set; } /// <summary>
        /// 客户代码 /// </summary>
        [StringLength(50)] [Required] public string CustomerCode { get; set; } /// <summary>
        /// 收货人代码 /// </summary>
        public string ConsIGneeCode { get; set; } /// <summary>
        /// 收货人 /// </summary>
        public string Consignee{get ;set;} /// <summary>
        /// 收货人社会信用代码 /// </summary>
        public string ConsigneeSCCD { get; set; } /// <summary>
        /// 托运人,发货人 /// </summary>
        public string Shipper { get; set; } /// <summary>
        /// 托运人,发货人代码 /// </summary>
        public string ShipperCode { get; set; } /// <summary>
        /// 托运人,发货人社会信用代码 /// </summary>
        public string ShipperSCCD { get; set; } /// <summary>
        /// 通知人 /// </summary>
        public string Notify { get; set; } /// <summary>
        /// 通知人代码 /// </summary>
        public string NotifyCode { get; set; } /// <summary>
        /// 通知人社会信用代码 /// </summary>
        public string NotifySCCD { 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(20)] public string TallyTime { get; set; } /// <summary>
        /// 理货员 /// </summary>
        [StringLength(50)] public string TallyClerk { get; set; } [StringLength(50)] public string Oper { get; set; } public int Status { get; set; } [StringLength(50)] public string OwnerCode { get; set; } /// <summary>
        /// 预计出库时间 /// </summary>
        [StringLength(20)] public string PreOutStockTime { get; set; } /// <summary>
        /// 审核人 /// </summary>
        [StringLength(50)] public string Checker { get; set; } [StringLength(20)] public string CheckTime { get; set; } [StringLength(1000)] public string Remark { get; set; } public DateTime CreationTime { get; set; } [StringLength(20)] public string LastUpdateTime { get; set; } [StringLength(50)] public string LastOper { get; set; } } } 
    4. 重得第2,3步,我们在“ABP.TPLMS.Core”项目的“Entitys”文件夹,建立OutStockOrderDetail类。代码如下:
using Abp.Domain.Entities; using Abp.Domain.Entities.Auditing; using System; using System.Collections.Generic; using System.ComponentModel.DataAnnotations; using System.ComponentModel.DataAnnotations.Schema; using System.Text; namespace ABP.TPLMS.Entitys { public class OutStockOrderDetail : Entity<int>, IHasCreationTime { public const int MaxLength = 255; public OutStockOrderDetail() { this.Qty = 0; this.CargoCode = string.Empty; this.CargoName = string.Empty; this.Brand = string.Empty; this.Country = string.Empty; this.CreationTime = DateTime.Now; this.Curr = string.Empty; this.GrossWt = 0; this.Height = 0; this.HSCode = string.Empty; this.Length = 0; this.SecdLawfQty = 0; this.LawfQty = 0; this.NetWt = 0; this.Package = string.Empty; this.Price = 0; this.SPCf = string.Empty; this.Unit = string.Empty; this.InStockNo = string.Empty; this.LawfUnit = string.Empty; this.Vol = 0; this.Width = 0; this.LawfUnit = string.Empty; this.SecdLawfUnit = string.Empty; this.Batch = string.Empty; this.InStockOrderDetailId = 0; } public int SupplierId { get; set; } [MaxLength(50)] public string CargoCode { get; set; } [MaxLength(10)] public string HSCode { get; set; } [MaxLength(MaxLength)] public string CargoName { get; set; } [MaxLength(MaxLength)] public string Spcf { get; set; } [MaxLength(20)] public string Unit { get; set; } /// <summary>
        /// 目的国 /// </summary>
        [MaxLength(20)] public string DestCountry { get; set; } /// <summary>
        /// 原产国 /// </summary>
 [MaxLength(20)] public string Country { get; set; } [MaxLength(50)] public string Brand { get; set; } [MaxLength(20)] public string Curr { get; set; } [MaxLength(20)] 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(20)] public string InStockNo { get; set; } public int InStockOrderDetailId { get; set; } public decimal Qty { get; set; } public decimal LawfQty { get; set; } public decimal SecdLawfQty { get; set; } [MaxLength(20)] public string LawfUnit { get; set; } [MaxLength(20)] public string SecdLawfUnit { get; set; } [MaxLength(20)] public string Batch { get; set; } public string  Loc { get; set; } } }

5.界说入库单的实体之后,我们去“ABP.TPLMS.EntityFrameworkCore”项目中的“TPLMSDbContext”类中界说实体对应的DbSet,以应用Code First 数据迁徙。添加以下代码

using Microsoft.EntityFrameworkCore; using Abp.Zero.EntityFrameworkCore; using ABP.TPLMS.Authorization.Roles; using ABP.TPLMS.Authorization.Users; using ABP.TPLMS.MultiTenancy; using ABP.TPLMS.Entitys; namespace ABP.TPLMS.EntityFrameworkCore { public class TPLMSDbContext : AbpZeroDbContext<Tenant, Role, User, TPLMSDbContext> { /* Define a DbSet for each entity of the application */
      

        public TPLMSDbContext(DbContextOptions<TPLMSDbContext> options) : base(options) { } public DbSet<Module> Modules { get; set; } public DbSet<Supplier> Suppliers { get; set; } public DbSet<Cargo> Cargos { get; set; } public DbSet<Org> Orgs { get; set; } public virtual DbSet<InStockOrder> InStockOrder { get; set; } public virtual DbSet<InStockOrderDetail> InStockOrderDetail { get; set; } public virtual DbSet<InStockOrderDetailLoc> InStockOrderDetailLoc { get; set; } public virtual DbSet<OutStockOrder> OutStockOrder { get; set; } public virtual DbSet<OutStockOrderDetail> OutStockOrderDetail { get; set; } } }

     6.从菜单中选择“工具->NuGet包治理器器—>程序包治理器控制台”菜单。

    7. 在PMC中,默认项目选择EntityframeworkCore对应的项目后。输入以下下令:Add-Migration AddEntityOutStock,建立迁徙。如下图。

 

    8. 在上面的下令执行完毕之后,建立乐成后,会在Migrations文件夹下建立时间_AddEntityOutStock花样的类文件,这些代码是基于DbContext指定的模子。如下图。

 

    9.在程序包治理器控制台,输入Update-Database,回车执行迁徙。执行乐成后,如下图。

 

    10. 在SQL Server Management Studio中查看数据库,OutStockOrder、OutStockOrderDetail两张表建立乐成。

 

 

 

,

Allbet

www.ipvps.cn欢迎进入欧搏平台(Allbet Game),欧搏平台开放欧搏Allbet开户、欧搏Allbet代理开户、欧搏Allbet电脑客户端、欧搏AllbetAPP下载等业务。

Sunbet声明:该文看法仅代表作者自己,与本平台无关。转载请注明:allbet gmaing代理:abp(net core)+easyui+efcore实现仓储治理系统——出库治理之一(四十九)

网友评论

  • (*)

最新评论

标签列表

    文章归档

      站点信息

      • 文章总数:653
      • 页面总数:0
      • 分类总数:8
      • 标签总数:1146
      • 评论总数:283
      • 浏览总数:17261