357 lines
9.8 KiB
C#
357 lines
9.8 KiB
C#
|
|
/// <summary>
|
|
///INTERFACE CLASS FOR TABLE t_wmsGoods
|
|
///By wm with codesmith.
|
|
///on 05/04/2017
|
|
/// </summary>
|
|
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using System.Text;
|
|
using System.Data;
|
|
using DeiNiu.Utils;
|
|
|
|
namespace DeiNiu.wms.Data.Model
|
|
{
|
|
[Serializable]
|
|
public class WmsGoods : WmsGoods_base
|
|
{
|
|
|
|
|
|
public WmsGoods()
|
|
{
|
|
|
|
}
|
|
|
|
public WmsGoods(int id): base(id)
|
|
{
|
|
|
|
}
|
|
public WmsGoods(DataRow dr): base(dr)
|
|
{
|
|
|
|
}
|
|
|
|
public WmsGoods(string goodsId)
|
|
{
|
|
cmdParameters[0] = goodsId;
|
|
getModel(110);
|
|
initialExtFields();
|
|
}
|
|
public WmsGoods(string goodsId,string batch):this(goodsId)
|
|
{
|
|
getStockInfo(goodsId,batch);
|
|
}
|
|
protected override void getImp()
|
|
{
|
|
model_imp = new WmsGoods_Imp();
|
|
|
|
}
|
|
/// <summary>
|
|
/// 更新cache
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
public new int Update()
|
|
{
|
|
base.Update();
|
|
ObjectsFactory.putGoods(this);
|
|
return 1;
|
|
}
|
|
|
|
#region fieldNames
|
|
public enum exfields
|
|
{ goodsName, spec,unit,manufacturer,address,barcode, regeditCode, goodsTypeName,bigCount,type,pinYin ,station,repTypeName}
|
|
#endregion
|
|
|
|
|
|
private string _goodsName, _spec, _unit, _manufacturer, _address, _barcode, _regeditCode, _goodsTypeName, _type,_pinyin;
|
|
// decimal _bigCount;
|
|
public string goodsName
|
|
{
|
|
get { return _goodsName; }
|
|
|
|
}
|
|
public string spec
|
|
{
|
|
get { return _spec; }
|
|
|
|
}
|
|
public string unit
|
|
{
|
|
get { return _unit; }
|
|
|
|
}
|
|
public string manufacturer
|
|
{
|
|
get { return _manufacturer; }
|
|
|
|
}
|
|
public string address
|
|
{
|
|
get { return _address; }
|
|
|
|
}
|
|
public string barcode
|
|
{
|
|
get { return _barcode; }
|
|
|
|
}
|
|
public string regeditCode
|
|
{
|
|
get { return _regeditCode; }
|
|
|
|
}
|
|
public string goodsTypeName
|
|
{
|
|
get { return _goodsTypeName; }
|
|
|
|
}
|
|
|
|
public string type
|
|
{
|
|
get { return _type; }
|
|
|
|
}
|
|
|
|
public string pinyin
|
|
{
|
|
get { return _pinyin; }
|
|
|
|
}
|
|
|
|
|
|
public void initialExtFields()
|
|
{
|
|
cmdParameters[0] = _goodsId;
|
|
|
|
DataTable dt = CustQuery(120).Tables[0];
|
|
foreach (DataRow dr in dt.Rows){
|
|
if (!(dr[exfields.address.ToString()] is DBNull))
|
|
{
|
|
_address = dr[exfields.address.ToString()].ToString() ;
|
|
}
|
|
if (!(dr[exfields.barcode.ToString()] is DBNull))
|
|
{
|
|
_barcode = dr[exfields.barcode.ToString()].ToString();
|
|
}
|
|
|
|
if (!(dr[exfields.bigCount.ToString()] is DBNull))
|
|
{
|
|
_bigCount = Convert.ToDecimal(dr[exfields.bigCount.ToString()].ToString());
|
|
}
|
|
if (!(dr[exfields.goodsName.ToString()] is DBNull))
|
|
{
|
|
_goodsName = dr[exfields.goodsName.ToString()].ToString();
|
|
} if (!(dr[exfields.goodsTypeName.ToString()] is DBNull))
|
|
{
|
|
_goodsTypeName = dr[exfields.goodsTypeName.ToString()].ToString();
|
|
}
|
|
if (!(dr[exfields.manufacturer.ToString()] is DBNull))
|
|
{
|
|
_manufacturer = dr[exfields.manufacturer.ToString()].ToString();
|
|
}
|
|
if (!(dr[exfields.regeditCode.ToString()] is DBNull))
|
|
{
|
|
_regeditCode = dr[exfields.regeditCode.ToString()].ToString();
|
|
}
|
|
if (!(dr[exfields.spec.ToString()] is DBNull))
|
|
{
|
|
_spec = dr[exfields.spec.ToString()].ToString();
|
|
}
|
|
if (!(dr[exfields.type.ToString()] is DBNull))
|
|
{
|
|
_type = dr[exfields.type.ToString()].ToString();
|
|
}
|
|
if (!(dr[exfields.unit.ToString()] is DBNull))
|
|
{
|
|
_unit = dr[exfields.unit.ToString()].ToString();
|
|
}
|
|
if (!(dr[exfields.pinYin.ToString()] is DBNull))
|
|
{
|
|
_unit = dr[exfields.pinYin.ToString()].ToString();
|
|
}
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
//begin cust db operation, query, excute sql etc.
|
|
public DataSet QueryByName(string name)
|
|
{
|
|
cmdParameters[0] = name;
|
|
return CustQuery(100);
|
|
}
|
|
|
|
/// <summary>
|
|
/// 同步erp 商品信息
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
public int syncGoods()
|
|
{
|
|
|
|
return CustOper(300);
|
|
}
|
|
/// <summary>
|
|
/// 根据货位类型返回货物的库容量
|
|
/// </summary>
|
|
/// <param name="locVolType"></param>
|
|
/// <returns></returns>
|
|
public decimal getMaxCount(int locVolType)
|
|
{
|
|
decimal goodsMaxcnt = 0m;
|
|
switch (locVolType)
|
|
{
|
|
case (int)enumWhLocVol.零库:
|
|
goodsMaxcnt = this.bulkMax;
|
|
break;
|
|
case (int)enumWhLocVol.小整:
|
|
goodsMaxcnt = this.batchMax1;
|
|
break;
|
|
case (int)enumWhLocVol.大整:
|
|
goodsMaxcnt = this.batchMax2;
|
|
break;
|
|
case (int)enumWhLocVol.超大整:
|
|
goodsMaxcnt = this.batchMax3;
|
|
break;
|
|
|
|
}
|
|
return goodsMaxcnt;
|
|
}
|
|
|
|
private decimal _stockSumCount, _stockBulkCount, _stockBatch1Count, _stockBatch2Count;
|
|
private decimal _stockSumCountIn, _stockBulkCountIn, _stockBatch1CountIn, _stockBatch2CountIn;
|
|
private decimal _stockSumCountOuting, _stockBulkCountOuting, _stockBatch1CountOuting, _stockBatch2CountOuting;
|
|
public decimal stockSumCountIn
|
|
{
|
|
get { return _stockSumCountIn; }
|
|
|
|
}
|
|
public decimal stockBulkCountIn
|
|
{
|
|
get { return _stockBulkCountIn; }
|
|
|
|
}
|
|
public decimal stockBatch1CountIn
|
|
{
|
|
get { return _stockBatch1CountIn; }
|
|
|
|
}
|
|
public decimal stockBatch2CountIn
|
|
{
|
|
get { return _stockBatch2CountIn; }
|
|
|
|
}
|
|
|
|
public decimal stockSumCountOuting
|
|
{
|
|
get { return _stockSumCountOuting; }
|
|
|
|
}
|
|
public decimal stockBulkCountOuting
|
|
{
|
|
get { return _stockBulkCountOuting; }
|
|
|
|
}
|
|
public decimal stockBatch1CountOuting
|
|
{
|
|
get { return _stockBatch1CountOuting; }
|
|
|
|
}
|
|
public decimal stockBatch2CountOuting
|
|
{
|
|
get { return _stockBatch2CountOuting; }
|
|
|
|
}
|
|
|
|
|
|
public decimal stockSumCount
|
|
{
|
|
get { return _stockSumCount; }
|
|
|
|
}
|
|
public decimal stockBulkCount
|
|
{
|
|
get { return _stockBulkCount; }
|
|
|
|
}
|
|
public decimal stockBatch1Count
|
|
{
|
|
get { return _stockBatch1Count; }
|
|
|
|
}
|
|
public decimal stockBatch2Count
|
|
{
|
|
get { return _stockBatch2Count; }
|
|
|
|
}
|
|
private List<WmsStock> _stocks;
|
|
|
|
public List<WmsStock> stocks
|
|
{
|
|
get {
|
|
if (_stocks == null)
|
|
{
|
|
_stocks = new List<WmsStock>();
|
|
|
|
}
|
|
|
|
return _stocks;
|
|
}
|
|
|
|
}
|
|
|
|
/// <summary>
|
|
/// 取得商品的即时库存
|
|
/// </summary>
|
|
/// <param name="goodsId"></param>
|
|
/// <param name="batch"></param>
|
|
public void getStockInfo(string goodsId,string batch, enumWhType whType = enumWhType.合格库)
|
|
{
|
|
cmdParameters[0] = goodsId;
|
|
cmdParameters[1] = batch;
|
|
cmdParameters[2] = (int)whType;
|
|
DataTable dt = CustQuery(400).Tables[0];
|
|
_stocks = new List<WmsStock>();
|
|
_stockSumCount = 0m; _stockBulkCount = 0m; _stockBatch1Count = 0m; _stockBatch2Count = 0m;
|
|
_stockSumCountIn = 0m; _stockBulkCountIn = 0m; _stockBatch1CountIn = 0m; _stockBatch2CountIn = 0m;
|
|
_stockSumCountOuting = 0m; _stockBulkCountOuting = 0m; _stockBatch1CountOuting = 0m; _stockBatch2CountOuting = 0m;
|
|
foreach (DataRow dr in dt.Rows){
|
|
|
|
WmsStock st = new WmsStock(dr);
|
|
|
|
_stocks.Add(st);
|
|
decimal cnt = st.count - st.countOut;
|
|
_stockSumCount += cnt;
|
|
_stockSumCountIn +=st.countIn;
|
|
_stockSumCountOuting += st.countOuting;
|
|
|
|
switch (st.location.whVolType)
|
|
{
|
|
case (int) enumWhLocVol.零库:
|
|
_stockBulkCount += cnt;
|
|
_stockBulkCountIn += st.countIn;
|
|
_stockBulkCountOuting += st.countOuting;
|
|
break;
|
|
case (int)enumWhLocVol.小整:
|
|
_stockBatch1Count += cnt;
|
|
_stockBatch1CountIn += st.countIn;
|
|
_stockBatch1CountOuting += st.countOuting;
|
|
break;
|
|
case (int)enumWhLocVol.大整:
|
|
_stockBatch2Count += cnt;
|
|
_stockBatch2CountIn += st.countIn;
|
|
_stockBatch2CountOuting += st.countOuting;
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
}
|
|
}
|
|
}
|
|
|