You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
DS7/DSWeb/Areas/MvcShipping/DAL/MsSeaeOrder/MsSeaeOrderDAL.cs

3925 lines
227 KiB
C#

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

using System;
using System.Collections;
using System.Collections.Generic;
using System.Data;
using System.Net.Mail;
using System.Web.Mvc;
using System.Text;
using DSWeb.Areas.CommMng.Models;
using DSWeb.EntityDA;
using DSWeb.MvcShipping.Models.MsSeaeOrder;
using HcUtility.Comm;
using HcUtility.Core;
using Microsoft.Practices.EnterpriseLibrary.Data;
using System.Data.SqlClient;
using DSWeb.MvcShipping.DAL.MsSysBillNoSet;
using DSWeb.TruckMng.Helper.Repository;
using DSWeb.MvcShipping.Models.MsOpSeae;
using DSWeb.MvcShipping.DAL.MsSysParamSet;
using CommonTool.MailKit;
using System.IO;
using DSWeb.MvcShipping.Models.MsOpMailLog;
using DSWeb.Areas.SysMng.DAL.SysUser;
using DSWeb.Areas.Import.DAL.ReceiptDoc;
using MimeKit.Text;
using DSWeb.Common.DB;
using System.Linq;
using DSWeb.MvcShipping.DAL.MsOpSeaeDAL;
using DSWeb.Areas.MvcShipping.Helper;
using DSWeb.Areas.CommMng.DAL;
using DSWeb.MvcShipping.DAL.MsBaseInfoDAL;
using org.apache.pdfbox.util.@operator;
using DSWeb.SysMng.DAL.SysRoleTaskQuery;
using DSWeb.MvcShipping.DAL.MsInfoClient;
namespace DSWeb.MvcShipping.DAL.MsSeaeOrderDAL
{
public class MsSeaeOrderDAL : IGetTotalCount
{
#region 查询
static public List<MsSeaeOrder> GetDataList(int start, int limit, string strCondition, string userid, string usercode, string companyid,string sort = null)
{
SysRoleTaskQueryDAL.SaveQuery(userid, "modSeaeOrderList", "formMsSeaeOrderIndex", strCondition);
var rangstr = GetRangDAStr("index", userid, usercode, companyid);
if (!string.IsNullOrEmpty(rangstr))
{
if (!string.IsNullOrEmpty(strCondition))
{
strCondition = strCondition + " and " + rangstr;
}
else
{
strCondition = rangstr;
}
}
var OPLISTNOCANCEL = MsSysParamSetDAL.GetData("PARAMNAME='CRMSEAEORDERLISTNOCANCEL'").PARAMVALUE;
if (OPLISTNOCANCEL == "1")
{
var opcondition = " not exists(select 1 from op_seae where bsno=B.bsno and ISCANCEL='1') ";
if (!string.IsNullOrEmpty(strCondition))
{
strCondition = strCondition + " and "+ opcondition;
}
else
{
strCondition = opcondition;
}
}
//
var strSql = new StringBuilder();
strSql.Append(@"SELECT * from (SELECT row_number() over (");
var sortstring = DatasetSort.Getsortstring(sort);
if (!string.IsNullOrEmpty(sortstring))
{
strSql.Append(" order by " + sortstring);
}
else
{
var SeaeDefaultSort = MsSysParamSetDAL.GetData("PARAMNAME='SeaeOrderDefaultSort'");
if (SeaeDefaultSort.PARAMVALUE != "")
strSql.Append(" order by " + SeaeDefaultSort.PARAMVALUE);
else
strSql.Append(" order by BSDATE desc");
}
strSql.Append(@") as num , * from(select ");
GetDataListBuilder(ref strSql);
if (!string.IsNullOrEmpty(strCondition))
{
strSql.Append(" where " + strCondition);
}
//
strSql.Append(@")as t2 )as t ");
strSql.Append(string.Format("where t.num>{0} and t.num<={1} order by t.num ", start, start + limit)); //
var isNoForward = MsBaseInfoDAL.MsBaseInfoDAL.GetUserModuleEnable("modMsNoForward", userid);
return SetData(strSql,"",isNoForward);
}
public static void GetDataListBuilder(ref StringBuilder strSql) {
strSql.Append(" ORDNO,BSNO,ORSTATUS,ORREASON,BSDATE,CUSTOMERNAME,ORDTYPE,SHIPPERID,CONSIGNEEID,NOTIFYPARTYID,YARD");
strSql.Append(",SHIPPER,CONSIGNEE,NOTIFYPARTY,VESSEL,VOYNO,ETD,PlACERECEIPT,PlACERECEIPTID,PORTLOADID,PORTLOAD,PORTDISCHARGEID,PORTDISCHARGE");
strSql.Append(",PLACEDELIVERYID,PLACEDELIVERY,DESTINATIONID,DESTINATION,NOBILL,ISSUETYPE,ISSUEDATE,ISSUEPLACE,ISSUEPLACEID,BLFRT");
strSql.Append(",PREPARDAT,PAYABLEAT,[SERVICE],MARKS,NOPKGS,[DESCRIPTION],GOODSNAME,GROSSWEIGHT,MEASUREMENT,PKGS,KINDPKGS");
strSql.Append(",KGS,CBM,TOTALNO,CNTRTOTAL,INPUTBY,INVNO,CARGOID,HSCODE,DCLASS,DUNNO,REEFERF,TEMPID,TEMPSET,TEMPMAX,TEMPMIN");
strSql.Append(",CUSTOMSNUM,REMARK,STATUS1,STATUS2,STATUS3,STATUS4,STATUS5,ISFUMIGATION,ISSTORAGE,ISLAND,ISCUSTOMS,ISINSPECTION");
strSql.Append(",ISBOOKING,ISAGENT,ISHBLNO,SERVICE9,SERVICE10,STLNAME,STLDATE,OCEANFEE,ISUSD,ISCOMMISSIONBACK,CARRIER,CARRIERATTN");
strSql.Append(",CARRIERTEL,CARRIEREMAIL,FORWARDER,FORWARDERATTN,FORWARDERTEL,FORWARDEREMAIL,SALE,PACKINGTYPE,BLTYPE,OP,FRCUSTSERVICE");
strSql.Append(",CUSTSERVICE,doc,AUDITOPERATOR,AUDITDATE,DPAGE,DLABEL,LINKMAN,BILLNUM,AGENTID,AGENT,TRANSPORT");
strSql.Append(",(CASE ORSTATUS WHEN '8' THEN '确认订舱' WHEN '0' THEN '审核通过' WHEN '1' THEN '提交审核' WHEN '2' THEN '驳回' WHEN '4' THEN '退舱' else '录入状态' end) as ORSTATUSREF ");
strSql.Append(",(SELECT CUSTNO FROM V_OP_BILL V WHERE V.BSNO=B.BSNO) as CUSTNO ");
strSql.Append(",(SELECT MBLNO FROM V_OP_BILL V WHERE V.BSNO=B.BSNO) as MBLNOREF,MBLNO,SALEDEPT,BSSOURCE,BSSOURCEDETAIL,(select top 1 sale from info_client where SHORTNAME=B.CUSTOMERNAME) DEFSALE ");
strSql.Append(",dbo.F_GetBillCrmFeeStatus(B.BSNO,1) DRFEESTATUS");
strSql.Append(",dbo.F_GetBillCrmFeeStatus(B.BSNO,2) CRFEESTATUS");
strSql.Append(",'' SenderMobile,'' SenderEmail,CONTRACTNO,'' AMSSHIPPER,'' AMSCONSIGNEE,'' AMSNOTIFYPARTY,CONFIRMOP,CONFIRMDATE,OPERATOR,OPERATORTEL,FBP,DESTFBP,MAXWEIGHT,PLANPROFIT,OPERATOREMAIL,B.LANE,SERVICECONTRACTNO ");
strSql.Append(",SALECORPID,(select [NAME] from [company] where GID=B.SALECORPID) as SALECORP ");
strSql.Append(",B.AUDITOPERATOR2,B.ETD2,B.ISSUETYPE2,B.STLNAME2,B.TIDANLEIXING,B.SUBMITDATE ,TRADETERM,DIANSHANGORDERNO,BCNO ");
strSql.Append(",(select DESCRIPTION from info_client where shortname=B.customername) CUSTOMERFULLNAME ");
strSql.Append(",(select top 1 CUSTOMERNAME from crm_seaeorder_fen where MASTERNO = b.BSNO order by ordno) FEN_CUSTOMERNAME");
strSql.Append(",B.ISEI,B.TEU,cd.COUNTRY,cd.CHAU,B.ORDER_CUSTCODE,B.ORDER_CUSTNAME");
strSql.Append(" from crm_seaeorder B WITH (NOLOCK)");
//strSql.Append(" left join (select t3.* from (select *,row_number() over (partition by EDICODE order by portid asc) as rownum from code_disport) t3 where t3.rownum = 1 ) cd on B.DESTINATIONID = cd.EDICODE ");
strSql.Append(" left join (select * from( select *,row_number() over (partition by EDICODE order by CHAU desc) as rownum from (select EDICODE,COUNTRY,CHAU from code_disport union all select PORTENAME EDICODE,COUNTRY,'' CHAU from code_air_port)t4) t3 where t3.rownum = 1) cd on B.DESTINATIONID = cd.EDICODE ");
}
public static int getTotalCount(string strCondition, string userid, string usercode, string companyid)
{
var rangstr = GetRangDAStr("index", userid, usercode, companyid);
if (!string.IsNullOrEmpty(rangstr))
{
if (!string.IsNullOrEmpty(strCondition))
{
strCondition = strCondition + " and " + rangstr;
}
else
{
strCondition = rangstr;
}
}
StringBuilder strSql = new StringBuilder();
strSql.Append("select count(*) ");
strSql.Append(" from crm_seaeorder B WITH (NOLOCK) ");
if (!string.IsNullOrEmpty(strCondition))
{
strSql.Append(" where " + strCondition);
}
int cnt = 0;
Database db = DatabaseFactory.CreateDatabase();
using (IDataReader reader = db.ExecuteReader(CommandType.Text, strSql.ToString()))
{
while (reader.Read())
{
cnt = Convert.ToInt32(reader[0]);
}
}
return cnt;
}
public int GetTotalCount(string strCondition, string userid, string usercode, string companyid)
{
try
{
return getTotalCount(strCondition, userid, usercode, companyid);
}
catch (Exception e)
{
return 0;
}
}
static public DBResult GetDataListStr(string strCondition, string userid, string usercode, string companyid, string sort = null)
{
var result = new DBResult();
var rangstr = GetRangDAStr("index", userid, usercode, companyid);
if (!string.IsNullOrEmpty(rangstr))
{
if (!string.IsNullOrEmpty(strCondition))
{
strCondition = strCondition + " and " + rangstr;
}
else
{
strCondition = rangstr;
}
}
//
var strSql = new StringBuilder();
strSql.Append("SELECT ");
GetDataListBuilder(ref strSql);
if (!string.IsNullOrEmpty(strCondition))
{
strSql.Append(" where " + strCondition);
}
//
var sortstring = DatasetSort.Getsortstring(sort);
if (!string.IsNullOrEmpty(sortstring))
{
strSql.Append(" order by " + sortstring);
}
else
{
strSql.Append(" order by BSDATE desc");
}
result.Data = strSql.ToString();
result.Message = strCondition;
return result;
}
static public MsSeaeOrder GetData(string condition,string userid="")
{
var strSql = new StringBuilder();
strSql.Append("SELECT top 1 ORDNO,BSNO,ORSTATUS,ORREASON,BSDATE,CUSTOMERNAME,ORDTYPE,SHIPPERID,CONSIGNEEID,NOTIFYPARTYID,YARD");
strSql.Append(",SHIPPER,CONSIGNEE,NOTIFYPARTY,VESSEL,VOYNO,ETD,PlACERECEIPT,PlACERECEIPTID,PORTLOADID,PORTLOAD,PORTDISCHARGEID,PORTDISCHARGE");
strSql.Append(",PLACEDELIVERYID,PLACEDELIVERY,DESTINATIONID,DESTINATION,NOBILL,ISSUETYPE,ISSUEDATE,ISSUEPLACE,ISSUEPLACEID,BLFRT");
strSql.Append(",PREPARDAT,PAYABLEAT,[SERVICE],MARKS,NOPKGS,[DESCRIPTION],GOODSNAME,GROSSWEIGHT,MEASUREMENT,PKGS,KINDPKGS");
strSql.Append(",KGS,CBM,TOTALNO,CNTRTOTAL,INPUTBY,INVNO,CARGOID,HSCODE,DCLASS,DUNNO,REEFERF,TEMPID,TEMPSET,TEMPMAX,TEMPMIN");
strSql.Append(",CUSTOMSNUM,REMARK,STATUS1,STATUS2,STATUS3,STATUS4,STATUS5,ISFUMIGATION,ISSTORAGE,ISLAND,ISCUSTOMS,ISINSPECTION");
strSql.Append(",ISBOOKING,ISAGENT,ISHBLNO,SERVICE9,SERVICE10,STLNAME,STLDATE,OCEANFEE,ISUSD,ISCOMMISSIONBACK,CARRIER,CARRIERATTN");
strSql.Append(",CARRIERTEL,CARRIEREMAIL,FORWARDER,FORWARDERATTN,FORWARDERTEL,FORWARDEREMAIL,SALE,PACKINGTYPE,BLTYPE,OP,FRCUSTSERVICE");
strSql.Append(",CUSTSERVICE,doc,AUDITOPERATOR,AUDITDATE,DPAGE,DLABEL,LINKMAN,BILLNUM,AGENTID,AGENT,TRANSPORT");
strSql.Append(",(CASE ORSTATUS WHEN '8' THEN '确认订舱' WHEN '0' THEN '审核通过' WHEN '1' THEN '提交审核' WHEN '2' THEN '驳回' WHEN '4' THEN '退舱' else '录入状态' end) as ORSTATUSREF ");
strSql.Append(",(SELECT CUSTNO FROM V_OP_BILL V WHERE V.BSNO=B.BSNO) as CUSTNO ");
strSql.Append(",(SELECT MBLNO FROM V_OP_BILL V WHERE V.BSNO=B.BSNO) as MBLNOREF,MBLNO,SALEDEPT,BSSOURCE,BSSOURCEDETAIL,(select top 1 sale from info_client where SHORTNAME=B.CUSTOMERNAME) DEFSALE ");
strSql.Append(",dbo.F_GetBillCrmFeeStatus(B.BSNO,1) DRFEESTATUS");
strSql.Append(",dbo.F_GetBillCrmFeeStatus(B.BSNO,2) CRFEESTATUS");
strSql.Append(",'' SenderMobile,'' SenderEmail,CONTRACTNO,'' AMSSHIPPER,'' AMSCONSIGNEE,'' AMSNOTIFYPARTY,CONFIRMOP,CONFIRMDATE,OPERATOR,OPERATORTEL,FBP,DESTFBP,MAXWEIGHT,PLANPROFIT,OPERATOREMAIL,B.LANE,SERVICECONTRACTNO ");
strSql.Append(",SALECORPID,(select [NAME] from [company] where GID=B.SALECORPID) as SALECORP ");
strSql.Append(",B.AUDITOPERATOR2,B.ETD2,B.ISSUETYPE2,B.STLNAME2,B.TIDANLEIXING,B.SUBMITDATE,TRADETERM,DIANSHANGORDERNO,BCNO ");
strSql.Append(",(select DESCRIPTION from info_client where shortname=B.customername) CUSTOMERFULLNAME ");
strSql.Append(",(select top 1 CUSTOMERNAME from crm_seaeorder_fen where MASTERNO = b.BSNO order by ordno) FEN_CUSTOMERNAME");
strSql.Append(",B.ISEI,B.TEU,cd.COUNTRY,cd.CHAU,B.ORDER_CUSTCODE,B.ORDER_CUSTNAME");
strSql.Append(" from crm_seaeorder B");
//strSql.Append(" left join (select t3.* from (select *,row_number() over (partition by EDICODE order by portid asc) as rownum from code_disport) t3 where t3.rownum = 1 ) cd on B.DESTINATIONID = cd.EDICODE ");
strSql.Append(" left join (select * from( select *,row_number() over (partition by EDICODE order by CHAU desc) as rownum from (select EDICODE,COUNTRY,CHAU from code_disport union all select PORTENAME EDICODE,COUNTRY,'' CHAU from code_air_port)t4) t3 where t3.rownum = 1) cd on B.DESTINATIONID = cd.EDICODE ");
if (!string.IsNullOrEmpty(condition))
{
strSql.Append(" where " + condition);
}
var isNoForward = false;
if (!string.IsNullOrWhiteSpace(userid))
isNoForward = MsBaseInfoDAL.MsBaseInfoDAL.GetUserModuleEnable("modMsNoForward", userid);
var list =SetData(strSql,"", isNoForward);
if (list.Count > 0)
return list[0];
return new MsSeaeOrder();
}
private static List<MsSeaeOrder> SetData(StringBuilder strSql,string dbstr="",bool isNoForward=false)
{
var headList = new List<MsSeaeOrder>();
Database db=null;
if (dbstr!="")
db = DatabaseFactory.CreateDatabase(dbstr);
else
db = DatabaseFactory.CreateDatabase();
SqlCommand cmd = new SqlCommand();
cmd.CommandText = strSql.ToString();
cmd.CommandTimeout = 120000; //要加这一句
using (IDataReader reader = db.ExecuteReader(cmd))
{
while (reader.Read())
{
MsSeaeOrder data = new MsSeaeOrder();
#region Set DB data to Object
try
{
data.LANE = reader["LANE"] == null ? "" : Convert.ToString(reader["LANE"]);
}
catch (Exception)
{
data.LANE = "";
}
data.ORDNO = Convert.ToString(reader["ORDNO"]);//委托
data.BSNO = Convert.ToString(reader["BSNO"]);//业务编号
//字段过滤器(判断是否存在该列)
reader.GetSchemaTable().DefaultView.RowFilter = "ColumnName= 'SERVICECONTRACTNO'";
if (reader.GetSchemaTable().DefaultView.Count > 0)
data.SERVICECONTRACTNO = Convert.ToString(reader["SERVICECONTRACTNO"]);
data.BLTYPE = Convert.ToString(reader["BLTYPE"]);//装运方式
data.ORSTATUS = Convert.ToString(reader["ORSTATUS"]);//主编号
data.ORSTATUSREF = Convert.ToString(reader["ORSTATUSREF"]);//委托编号
data.ORREASON = Convert.ToString(reader["ORREASON"]);//分提单号
data.BSDATE = Convert.ToDateTime(reader["BSDATE"]);//接单日期
data.MBLNO = Convert.ToString(reader["MBLNO"]);//主提单号
if (data.MBLNO=="") data.MBLNO = Convert.ToString(reader["MBLNOREF"]);//主提单号
data.CUSTNO = Convert.ToString(reader["CUSTNO"]);//主提单号
data.CUSTOMERNAME = Convert.ToString(reader["CUSTOMERNAME"]);//委托单位
data.ORDTYPE = Convert.ToString(reader["ORDTYPE"]);//业务状态
data.SHIPPERID = Convert.ToString(reader["SHIPPERID"]);//发货人
data.CONSIGNEEID = Convert.ToString(reader["CONSIGNEEID"]);//收货人
data.NOTIFYPARTYID = Convert.ToString(reader["NOTIFYPARTYID"]);//通知人
data.SHIPPER = Convert.ToString(reader["SHIPPER"]).Replace(@"\\\\", "\n").Replace(@"^", "\'").Replace(@"&-add-", "+"); //发货人内容
data.CONSIGNEE = Convert.ToString(reader["CONSIGNEE"]).Replace(@"\\\\", "\n").Replace(@"^", "\'").Replace(@"&-add-", "+");//收货人内容
data.NOTIFYPARTY = Convert.ToString(reader["NOTIFYPARTY"]).Replace(@"\\\\", "\n").Replace(@"^", "\'").Replace(@"&-add-", "+");//通知人内容
data.VESSEL = Convert.ToString(reader["VESSEL"]);//船名
data.VOYNO = Convert.ToString(reader["VOYNO"]);//航次
if (reader["ETD"] != DBNull.Value)
data.ETD = Convert.ToDateTime(reader["ETD"]).ToString("yyyy-MM-dd");//到港日期
data.PORTLOADID = Convert.ToString(reader["PORTLOADID"]);//装货港代码
data.PORTLOAD = Convert.ToString(reader["PORTLOAD"]);//装货港
data.TRANSPORT = Convert.ToString(reader["TRANSPORT"]);//装货港
data.PORTDISCHARGEID = Convert.ToString(reader["PORTDISCHARGEID"]);//卸货港代码
data.PORTDISCHARGE = Convert.ToString(reader["PORTDISCHARGE"]).Replace(@"^", "\'");//卸货港
data.PLACERECEIPT = Convert.ToString(reader["PlACERECEIPT"]).Replace(@"^", "\'");//收货地
data.PLACERECEIPTID = Convert.ToString(reader["PlACERECEIPTID"]).Replace(@"^", "\'");//收货地
data.PLACEDELIVERYID = Convert.ToString(reader["PLACEDELIVERYID"]);//交货地代码
data.PLACEDELIVERY = Convert.ToString(reader["PLACEDELIVERY"]).Replace(@"^", "\'");//交货地
data.DESTINATIONID = Convert.ToString(reader["DESTINATIONID"]);//目的地代码
data.DESTINATION = Convert.ToString(reader["DESTINATION"]).Replace(@"^", "\'");//目的地
data.NOBILL = Convert.ToString(reader["NOBILL"]);//提单份数
data.ISSUETYPE = Convert.ToString(reader["ISSUETYPE"]);//签单方式
if (reader["ISSUEDATE"] != DBNull.Value)
data.ISSUEDATE = Convert.ToDateTime(reader["ISSUEDATE"]).ToString("yyyy-MM-dd");//预抵日期
data.ISSUEPLACE = Convert.ToString(reader["ISSUEPLACE"]);//签单地点
data.ISSUEPLACEID = Convert.ToString(reader["ISSUEPLACEID"]);//签单地点
data.BLFRT = Convert.ToString(reader["BLFRT"]);//付费方式
data.PREPARDAT = Convert.ToString(reader["PREPARDAT"]);//预付地点
data.PAYABLEAT = Convert.ToString(reader["PAYABLEAT"]);//到付地点
data.SERVICE = Convert.ToString(reader["SERVICE"]);//运输条款
data.MARKS = Convert.ToString(reader["MARKS"]).Replace(@"\\\\", "\n").Replace(@"^", "\'").Replace(@"&-add-", "+"); //唛头
//data.NOPKGS = Convert.ToString(reader["NOPKGS"]).Replace(@"\\\\", "\n").Replace(@"^", "\'");//件数包装
string _pkgs = Convert.ToString(reader["PKGS"].ToString());
/*for (int iCount = 0; iCount < 5; iCount++)
{
int _lengthPkgs = _pkgs.Length;
char _tempPkgs = _pkgs[_lengthPkgs - 1];
if (_tempPkgs == '0') { _pkgs = _pkgs.Substring(0, _lengthPkgs - 1); }
else { break; }
}
if (_pkgs[_pkgs.Length - 1] == '.') { _pkgs = _pkgs.Substring(0, _pkgs.Length - 1); }*/
data.NOPKGS = Convert.ToString(_pkgs + reader["KINDPKGS"].ToString());//件数包装
data.DESCRIPTION = Convert.ToString(reader["DESCRIPTION"]).Replace(@"\\\\", "\n").Replace(@"^", "\'").Replace(@"&-add-", "+"); //货物描述
data.GOODSNAME = Convert.ToString(reader["GOODSNAME"]);//品名
//data.GROSSWEIGHT = Convert.ToString(reader["GROSSWEIGHT"]).Replace(@"\\\\", "\n").Replace(@"^", "\'"); //货物毛重
string _kgs = Convert.ToString(reader["KGS"]);
for (int iCount = 0; iCount < 5; iCount++)
{
int _lengthKgs = _kgs.Length;
char _tempKgs = _kgs[_lengthKgs - 1];
if (_tempKgs == '0') { _kgs = _kgs.Substring(0, _lengthKgs - 1); }
else { break; }
}
if (_kgs[_kgs.Length - 1] == '.') { _kgs = _kgs.Substring(0, _kgs.Length - 1); }
data.GROSSWEIGHT = _kgs + "KGS"; //货物毛重
//data.MEASUREMENT = Convert.ToString(reader["MEASUREMENT"]).Replace(@"\\\\", "\n").Replace(@"^", "\'"); //货物尺码
string _cbm = Convert.ToString(reader["CBM"]);
for (int iCount = 0; iCount < 5; iCount++)
{
int _lengthCbm = _cbm.Length;
char _tempCbm = _cbm[_lengthCbm - 1];
if (_tempCbm == '0') { _cbm = _cbm.Substring(0, _lengthCbm - 1); }
else { break; }
}
if (_cbm[_cbm.Length - 1] == '.') { _cbm = _cbm.Substring(0, _cbm.Length - 1); }
data.MEASUREMENT = _cbm + "CBM"; //货物尺码
data.PKGS = Convert.ToString(_pkgs);//件数
data.KINDPKGS = Convert.ToString(reader["KINDPKGS"]);//件数包装
data.KGS = Convert.ToString(_kgs);//毛重
data.CBM = Convert.ToString(_cbm);//立方数/尺码
data.TOTALNO = Convert.ToString(reader["TOTALNO"]);//件数大写
data.CNTRTOTAL = Convert.ToString(reader["CNTRTOTAL"]);//集装箱全部内容
data.INPUTBY = Convert.ToString(reader["INPUTBY"]);//录入人
data.OPERATORTEL = Convert.ToString(reader["SenderMobile"]);//录入人
data.OPERATOREMAIL = Convert.ToString(reader["SenderEmail"]);//录入人
data.INVNO = Convert.ToString(reader["INVNO"]);//发票号
data.CARGOID = Convert.ToString(reader["CARGOID"]);//货物标识
data.HSCODE = Convert.ToString(reader["HSCODE"]);
data.DCLASS = Convert.ToString(reader["DCLASS"]);//危险品分类/等级
data.DUNNO = Convert.ToString(reader["DUNNO"]);//危险品编号
data.DPAGE = Convert.ToString(reader["DPAGE"]);//危险品页号
data.DLABEL = Convert.ToString(reader["DLABEL"]);//危险品标签
data.LINKMAN = Convert.ToString(reader["LINKMAN"]);//危险品联系人
data.REEFERF = Convert.ToString(reader["REEFERF"]);//冷藏通风量
if (Convert.ToString(reader["TEMPID"]) != "undefined")
data.TEMPID = Convert.ToString(reader["TEMPID"]);//温度单位
data.TEMPSET = Convert.ToString(reader["TEMPSET"]);//设置温度
data.TEMPMAX = Convert.ToString(reader["TEMPMAX"]);//最高温度
data.TEMPMIN = Convert.ToString(reader["TEMPMIN"]);//最低温度
data.CUSTOMSNUM = Convert.ToInt32(reader["CUSTOMSNUM"]);//报关票数
data.REMARK = Convert.ToString(reader["REMARK"]).Replace(@"\\\\", "\n").Replace(@"^", "\'").Replace(@"&-add-", "+");//备注
if (reader["STATUS1"] != DBNull.Value)
data.STATUS1 = Convert.ToBoolean(reader["STATUS1"]);//状态1
if (reader["STATUS2"] != DBNull.Value)
data.STATUS2 = Convert.ToBoolean(reader["STATUS2"]);//状态2
if (reader["STATUS3"] != DBNull.Value)
data.STATUS3 = Convert.ToBoolean(reader["STATUS3"]);//状态3
if (reader["STATUS4"] != DBNull.Value)
data.STATUS4 = Convert.ToBoolean(reader["STATUS4"]);//状态4
if (reader["STATUS5"] != DBNull.Value)
data.STATUS5 = Convert.ToBoolean(reader["STATUS5"]);//状态5
if (reader["ISFUMIGATION"] != DBNull.Value)
data.ISFUMIGATION = Convert.ToBoolean(reader["ISFUMIGATION"]);//熏蒸
if (reader["ISSTORAGE"] != DBNull.Value)
data.ISSTORAGE = Convert.ToBoolean(reader["ISSTORAGE"]);//仓储
if (reader["ISLAND"] != DBNull.Value)
data.ISLAND = Convert.ToBoolean(reader["ISLAND"]);//陆运
if (reader["ISCUSTOMS"] != DBNull.Value)
data.ISCUSTOMS = Convert.ToBoolean(reader["ISCUSTOMS"]);//报关
if (reader["ISINSPECTION"] != DBNull.Value)
data.ISINSPECTION = Convert.ToBoolean(reader["ISINSPECTION"]);//报检
if (reader["ISBOOKING"] != DBNull.Value)
data.ISBOOKING = Convert.ToBoolean(reader["ISBOOKING"]);//订舱
if (reader["ISAGENT"] != DBNull.Value)
data.ISAGENT = Convert.ToBoolean(reader["ISAGENT"]);//使用代理
if (reader["ISHBLNO"] != DBNull.Value)
data.ISHBLNO = Convert.ToBoolean(reader["ISHBLNO"]);//分单签单
if (reader["SERVICE9"] != DBNull.Value)
data.SERVICE9 = Convert.ToBoolean(reader["SERVICE9"]);//服务项目9
if (reader["SERVICE10"] != DBNull.Value)
data.SERVICE10 = Convert.ToBoolean(reader["SERVICE10"]);//服务项目10
data.STLNAME = Convert.ToString(reader["STLNAME"]);//结算方式
if (reader["STLDATE"] != DBNull.Value)
data.STLDATE = Convert.ToDateTime(reader["STLDATE"]).ToString("yyyy-MM-dd");//结算时间
if (reader["OCEANFEE"] != DBNull.Value)
data.OCEANFEE = Convert.ToDecimal(reader["OCEANFEE"]);//
if (reader["ISUSD"] != DBNull.Value)
data.ISUSD = Convert.ToBoolean(reader["ISUSD"]);//
if (reader["ISCOMMISSIONBACK"] != DBNull.Value)
data.ISCOMMISSIONBACK = Convert.ToBoolean(reader["ISCOMMISSIONBACK"]);//
data.CARRIER = Convert.ToString(reader["CARRIER"]);//船公司
data.CARRIERATTN = Convert.ToString(reader["CARRIERATTN"]);//船公司
data.CARRIERTEL = Convert.ToString(reader["CARRIERTEL"]);//船公司
data.CARRIEREMAIL = Convert.ToString(reader["CARRIEREMAIL"]);//船公司
if (isNoForward)
{
}
else
{
data.FORWARDER = Convert.ToString(reader["FORWARDER"]);//订舱公司
data.FORWARDERATTN = Convert.ToString(reader["FORWARDERATTN"]);//订舱公司
data.FORWARDERTEL = Convert.ToString(reader["FORWARDERTEL"]);//订舱公司
data.FORWARDEREMAIL = Convert.ToString(reader["FORWARDEREMAIL"]);//订舱公司
}
data.SALE = Convert.ToString(reader["SALE"]);//揽货人
data.SALEDEPT = Convert.ToString(reader["SALEDEPT"]);//部门
data.DEFSALE = Convert.ToString(reader["DEFSALE"]);//揽货人
data.PACKINGTYPE = Convert.ToString(reader["PACKINGTYPE"]);//装箱类型
data.BLTYPE = Convert.ToString(reader["BLTYPE"]);//装运方式
data.OP = Convert.ToString(reader["OP"]);//操作员
data.CUSTSERVICE = Convert.ToString(reader["CUSTSERVICE"]);//客服员
data.FRCUSTSERVICE = Convert.ToString(reader["FRCUSTSERVICE"]);//客服员
data.DOC = Convert.ToString(reader["DOC"]);//单证
data.AUDITOPERATOR = Convert.ToString(reader["AUDITOPERATOR"]);//审核人
if (reader["AUDITDATE"] != DBNull.Value)
data.AUDITDATE = Convert.ToDateTime(reader["AUDITDATE"]).ToString("yyyy-MM-dd HH:mm:ss");//截港日期
if (reader["CONFIRMDATE"] != DBNull.Value)
//data.CONFIRMDATE = Convert.ToDateTime(reader["CONFIRMDATE"]).ToString("yyyy-MM-dd HH:mm:ss");//截港日期
data.CONFIRMDATE = BasicDataRefDAL.ReadDateTime(reader,"CONFIRMDATE");
data.CONFIRMOP = Convert.ToString(reader["CONFIRMOP"]);//确认人
//data.OPERATORTEL = Convert.ToString(reader["SenderMobile"]);//
//data.OPERATOREMAIL = Convert.ToString(reader["SenderEmail"]);//
if (reader["OPERATORTEL"] != DBNull.Value)
data.OPERATORTEL = Convert.ToString(reader["OPERATORTEL"]);//
if (reader["OPERATOREMAIL"] != DBNull.Value)
data.OPERATOREMAIL = Convert.ToString(reader["OPERATOREMAIL"]);//
data.OPERATOR = Convert.ToString(reader["OPERATOR"]);//
data.FBP = Convert.ToString(reader["FBP"]);//
data.DESTFBP = Convert.ToString(reader["DESTFBP"]);//
data.MAXWEIGHT = Convert.ToString(reader["MAXWEIGHT"]);//
data.PLANPROFIT = Convert.ToString(reader["PLANPROFIT"]);//
data.CONTRACTNO = Convert.ToString(reader["CONTRACTNO"]);
data.AMSShipper = Convert.ToString(reader["AMSSHIPPER"]).Replace(@"\\\\", "\n").Replace(@"^", "\'").Replace(@"&-add-", "+");
data.AMSConsignee = Convert.ToString(reader["AMSCONSIGNEE"]).Replace(@"\\\\", "\n").Replace(@"^", "\'").Replace(@"&-add-", "+");
data.AMSNotifyparty = Convert.ToString(reader["AMSNOTIFYPARTY"]).Replace(@"\\\\", "\n").Replace(@"^", "\'").Replace(@"&-add-", "+");
data.AGENTID = Convert.ToString(reader["AGENTID"]);//
data.AGENT = Convert.ToString(reader["AGENT"]);//
data.YARD = Convert.ToString(reader["YARD"]);//
data.DRFEESTATUS = getfeestatus(Convert.ToString(reader["DRFEESTATUS"]));
data.CRFEESTATUS = getfeestatus(Convert.ToString(reader["CRFEESTATUS"]));
data.BSSOURCE = Convert.ToString(reader["BSSOURCE"]);//
data.BSSOURCEDETAIL = Convert.ToString(reader["BSSOURCEDETAIL"]);//
data.SALECORPID= Convert.ToString(reader["SALECORPID"]);//
data.SALECORP = Convert.ToString(reader["SALECORP"]);//
if (reader["ETD2"] != DBNull.Value)
//data.ETD2 = Convert.ToDateTime(reader["ETD2"]).ToString("yyyy-MM-dd")== "1900-01-01"?"": Convert.ToDateTime(reader["ETD2"]).ToString("yyyy-MM-dd");//驳船到港日期
data.ETD2 = BasicDataRefDAL.ReadDateTime(reader, "ETD2");
data.AUDITOPERATOR2 = Convert.ToString(reader["AUDITOPERATOR2"]);//提单确认人
data.ISSUETYPE2 = Convert.ToString(reader["ISSUETYPE2"]);//H签单方式
data.STLNAME2 = Convert.ToString(reader["STLNAME2"]);//H付款方式
data.TIDANLEIXING = Convert.ToString(reader["TIDANLEIXING"]);//提单类型
if (reader["SUBMITDATE"] != DBNull.Value)
data.SUBMITDATE = Convert.ToDateTime(reader["SUBMITDATE"]);//提交审核日期
if (reader["TRADETERM"] != DBNull.Value)
data.TRADETERM = Convert.ToString(reader["TRADETERM"]);//
if (reader["BCNO"] != DBNull.Value)
data.BCNO = Convert.ToString(reader["BCNO"]);//
if (reader["DIANSHANGORDERNO"] != DBNull.Value)
data.DIANSHANGORDERNO = Convert.ToString(reader["DIANSHANGORDERNO"]);//
if (reader["CUSTOMERFULLNAME"] != DBNull.Value)
data.CUSTOMERFULLNAME = Convert.ToString(reader["CUSTOMERFULLNAME"]);//
if (reader["FEN_CUSTOMERNAME"] != DBNull.Value)
data.FEN_CUSTOMERNAME = Convert.ToString(reader["FEN_CUSTOMERNAME"]);//
if (reader["ISEI"] != DBNull.Value)
data.ISEI = Convert.ToString(reader["ISEI"]);//
try
{
if (reader["TEU"] != DBNull.Value)
data.TEU = Convert.ToDecimal(reader["TEU"]);//
} catch (Exception e) {
data.TEU = 0;
}
if (reader["COUNTRY"] != DBNull.Value)
data.COUNTRY = Convert.ToString(reader["COUNTRY"]);
if (reader["CHAU"] != DBNull.Value)
data.CHAU = Convert.ToString(reader["CHAU"]);
if (reader["ORDER_CUSTCODE"] != DBNull.Value)
data.ORDER_CUSTCODE = Convert.ToString(reader["ORDER_CUSTCODE"]);//
if (reader["ORDER_CUSTNAME"] != DBNull.Value)
data.ORDER_CUSTNAME = Convert.ToString(reader["ORDER_CUSTNAME"]);//
#endregion
headList.Add(data);
}
reader.Close();
}
return headList;
}
public static string getfeestatus(string feestatusint)
{
var result = "";
if (feestatusint == "0:")
{
return "审核通过";
}
else if (feestatusint == "1:")
{
return "录入状态";
}
else if (feestatusint == "2:")
{
return "提交审核";
}
else if (feestatusint == "8:")
{
return "部分结算";
}
else if (feestatusint == "9:")
{
return "结算完毕";
}
else if (feestatusint == "")
{
return "未录入";
}
else if (feestatusint == "3:")
{
return "申请修改";
}
else if (feestatusint == "4:")
{
return "申请删除";
}
else if (feestatusint == "6:")
{
return "驳回提交";
}
else if (feestatusint == "7:")
{
return "驳回申请";
}
else if (feestatusint.IndexOf("9:") > -1)
{
return "部分结算";
}
else if (feestatusint.IndexOf("8:") > -1)
{
return "部分结算";
}
else if (feestatusint.IndexOf("0:") > -1)
{
return "部分审核";
}
else if (feestatusint.IndexOf("2:") > -1)
{
return "部分提交";
}
else if (feestatusint.IndexOf("6:") > -1)
{
return "驳回提交";
}
else if (feestatusint.IndexOf("7:") > -1)
{
return "驳回申请";
}
return result;
}
#endregion
#region 明细表
static public List<MsSeaeOrderCtn> GetBodyList(string strCondition)
{
var strSql = new StringBuilder();
strSql.Append("SELECT [CTN_ID],[ORDNO],[CTNNUM],[CTNALL],[REMARK],KGS from crm_seaeorderctn");
if (strCondition.Trim() != String.Empty)
{
strSql.Append(" where " + strCondition);
}
strSql.Append(" order by ORDNO,CTNALL");
return SetBodyData(strSql);
}
private static List<MsSeaeOrderCtn> SetBodyData(StringBuilder strSql)
{
var bodyList = new List<MsSeaeOrderCtn>();
Database db = DatabaseFactory.CreateDatabase();
using (IDataReader reader = db.ExecuteReader(CommandType.Text, strSql.ToString()))
{
while (reader.Read())
{
MsSeaeOrderCtn data = new MsSeaeOrderCtn();
#region Set DB data to Object
data.CTN_ID = Convert.ToString(reader["CTN_ID"]);//编号
data.ORDNO = Convert.ToString(reader["ORDNO"]);//业务编号
data.CTNNUM = Convert.ToInt32(reader["CTNNUM"]);//箱量
data.CTNALL = Convert.ToString(reader["CTNALL"]);//表现形式
data.REMARK = Convert.ToString(reader["REMARK"]);//备注
data.KGS= string.IsNullOrWhiteSpace( Convert.ToString(reader["KGS"]))?0: Convert.ToDecimal(reader["KGS"]);
#endregion
bodyList.Add(data);
}
reader.Close();
}
return bodyList;
}
static public List<crm_seaeorder_fen_md> GetFenList(string MASTERNO)
{
var cdc = new CommonDataContext();
var list = new List<crm_seaeorder_fen_md>();
list = cdc.crm_seaeorder_fen.Where(x => x.MASTERNO == MASTERNO).OrderBy(o => o.ORDNO).ToList();
return list;
}
#endregion
#region 保存明细
public static DBResult SaveDetail(MsSeaeOrder headData, List<MsSeaeOrderCtn> bodyList, string userid)
{
var result = new DBResult();
Database db = DatabaseFactory.CreateDatabase();
using (var conn = db.CreateConnection())
{
conn.Open();
var tran = conn.BeginTransaction();
try
{
var cntr = "";
if (bodyList != null)
{
foreach (var enumValue in bodyList)
{
if (string.IsNullOrWhiteSpace( enumValue.KGS.ToString()) ){
enumValue.KGS = 0;
}
if (enumValue.ORDNO == "*")
{
var cmdInsert = db.GetSqlStringCommand(@"insert into crm_seaeorderctn (CTN_ID,ORDNO,CTNNUM,CTNALL,REMARK,KGS) values (newid(),'" + headData.ORDNO + "'," + enumValue.CTNNUM + ",'" + enumValue.CTNALL + "','" + enumValue.REMARK + "',"+ enumValue.KGS.ToString()+")");
db.ExecuteNonQuery(cmdInsert, tran);
}
else
{
var cmdUpdate = db.GetSqlStringCommand(@"update crm_seaeorderctn set CTNNUM=" + enumValue.CTNNUM + ",CTNALL='" + enumValue.CTNALL + "',REMARK='" + enumValue.REMARK + "',KGS=" + enumValue.KGS.ToString() + " where ORDNO='" + enumValue.ORDNO + "' AND CTN_ID='" + enumValue.CTN_ID + "'");
db.ExecuteNonQuery(cmdUpdate, tran);
}
cntr = cntr + enumValue.CTNALL + '*' + enumValue.CTNNUM + "/";
}
}
//
var cmdUpdateBs = db.GetSqlStringCommand(@"update crm_seaeorder set CNTRTOTAL='" + cntr + "' where ORDNO='" + headData.ORDNO + "'");
db.ExecuteNonQuery(cmdUpdateBs, tran);
tran.Commit();
}
catch (Exception)
{
tran.Rollback();
result.Success = false;
result.Message = "保存出现错误,请重试或联系系统管理员";
return result;
}
}
result.Success = true;
result.Message = "保存成功" + result.Message;
return result;
}
public static DBResult UpdateCtnTotal(string ORDNO)
{
var result = new DBResult();
Database db = DatabaseFactory.CreateDatabase();
using (var conn = db.CreateConnection())
{
conn.Open();
var tran = conn.BeginTransaction();
try
{
var bodyList = GetBodyList("ORDNO='"+ORDNO+"'");
var cntr = "";
if (bodyList != null)
{
foreach (var enumValue in bodyList)
{
cntr = cntr + enumValue.CTNALL + '*' + enumValue.CTNNUM + "/";
}
}
//
var cmdUpdateBs = db.GetSqlStringCommand(@"update crm_seaeorder set CNTRTOTAL='" + cntr + "' where ORDNO='" + ORDNO + "'");
db.ExecuteNonQuery(cmdUpdateBs, tran);
tran.Commit();
}
catch (Exception)
{
tran.Rollback();
result.Success = false;
result.Message = "保存出现错误,请重试或联系系统管理员";
return result;
}
}
result.Success = true;
result.Message = "保存成功" + result.Message;
return result;
}
//判断单号是否重复
static public int GetRdCount(string strCondition)
{
var strSql = new StringBuilder();
strSql.Append("SELECT Count(BSNO) AS CT from crm_seaeorder");
if (strCondition.Trim() != String.Empty)
{
strSql.Append(" where " + strCondition);
}
var ct=0;
Database db = DatabaseFactory.CreateDatabase();
using (IDataReader reader = db.ExecuteReader(CommandType.Text, strSql.ToString()))
{
while (reader.Read())
{
ct = Convert.ToInt16(reader["CT"]);
}
reader.Close();
}
return ct;
}
#endregion
#region 删除
public static DBResult DeleteDetail(MsSeaeOrder headData)
{
var result = new DBResult();
Database db = DatabaseFactory.CreateDatabase();
using (var conn = db.CreateConnection())
{
conn.Open();
var tran = conn.BeginTransaction();
try
{
var cmdDelete = db.GetSqlStringCommand("delete from crm_seaeorderctn where ORDNO='" + headData.ORDNO + "'");
db.ExecuteNonQuery(cmdDelete, tran);
tran.Commit();
}
catch (Exception)
{
tran.Rollback();
result.Success = false;
result.Message = "删除出现错误,请重试或联系系统管理员";
return result;
}
}
result.Success = true;
result.Message = "操作成功";
return result;
}
public static DBResult DeleteDetail2(MsSeaeOrderCtn headData)
{
var result = new DBResult();
Database db = DatabaseFactory.CreateDatabase();
using (var conn = db.CreateConnection())
{
conn.Open();
var tran = conn.BeginTransaction();
try
{
var cmdDelete = db.GetSqlStringCommand("delete from crm_seaeorderctn where CTN_ID='" + headData.CTN_ID + "'");
db.ExecuteNonQuery(cmdDelete, tran);
tran.Commit();
}
catch (Exception)
{
tran.Rollback();
result.Success = false;
result.Message = "删除出现错误,请重试或联系系统管理员";
return result;
}
}
UpdateCtnTotal(headData.ORDNO);
result.Success = true;
result.Message = "操作成功";
return result;
}
#endregion
#region 判断是否有费用
public static bool GetFeeCount(string BSNO)
{
var isfee = false;
var strSql = new StringBuilder();
strSql.Append("Select count(*) as count ");
strSql.Append(" from ch_fee ");
strSql.Append(" where BSNO='" + BSNO+"'");
Database db = DatabaseFactory.CreateDatabase();
using (IDataReader reader = db.ExecuteReader(CommandType.Text, strSql.ToString()))
{
while (reader.Read())
{
var evData = Convert.ToInt32(reader["count"]);
if (evData > 0) { isfee = true; };
}
reader.Close();
}
return isfee;
}
#endregion
#region 审核通过处理
static public List<MsSeaeOrder> GetAuditDataList(string strCondition, string userid, string usercode, string companyid,int start,int limit, string sort = null)
{
var rangstr = "";
SysRoleTaskQueryDAL.SaveQuery(userid, "modSeaeOrderAudit", "formMsSeaeOrderAudit", strCondition);
var ORDERAUDITMUSTBE = MsSysParamSetDAL.GetData("PARAMNAME='ORDERAUDITMUSTBE'");
if (ORDERAUDITMUSTBE.PARAMVALUE == "1")
{
rangstr = " AUDITOPERATOR='"+ usercode + "'";
}
else
{
rangstr = GetRangDAStr("audit", userid, usercode, companyid);
}
if (!string.IsNullOrEmpty(rangstr))
{
if (!string.IsNullOrEmpty(strCondition))
{
strCondition = strCondition + " and " + rangstr;
}
else
{
strCondition = rangstr;
}
}
var strSql = new StringBuilder();
strSql.Append(@"SELECT * from (SELECT row_number() over (");
var sortstring = DatasetSort.Getsortstring(sort);
if (!string.IsNullOrEmpty(sortstring))
{
strSql.Append(" order by " + sortstring);
}
else
{
var SeaeDefaultSort = MsSysParamSetDAL.GetData("PARAMNAME='SeaeOrderDefaultSort'");
if (SeaeDefaultSort.PARAMVALUE != "")
strSql.Append(" order by " + SeaeDefaultSort.PARAMVALUE);
else
strSql.Append(" order by BSDATE desc");
}
strSql.Append(@") as num , * from(select ");
//
strSql.Append(" ORDNO,BSNO,ORSTATUS,ORREASON,BSDATE,MBLNO,CUSTOMERNAME,ORDTYPE,SHIPPERID,CONSIGNEEID,NOTIFYPARTYID,YARD");
strSql.Append(",SHIPPER,CONSIGNEE,NOTIFYPARTY,VESSEL,VOYNO,ETD,PlACERECEIPT,PlACERECEIPTID,PORTLOADID,PORTLOAD,PORTDISCHARGEID,PORTDISCHARGE");
strSql.Append(",PLACEDELIVERYID,PLACEDELIVERY,DESTINATIONID,DESTINATION,NOBILL,ISSUETYPE,ISSUEDATE,ISSUEPLACE,ISSUEPLACEID,BLFRT");
strSql.Append(",PREPARDAT,PAYABLEAT,[SERVICE],MARKS,NOPKGS,[DESCRIPTION],GOODSNAME,GROSSWEIGHT,MEASUREMENT,PKGS,KINDPKGS");
strSql.Append(",KGS,CBM,TOTALNO,CNTRTOTAL,INPUTBY,INVNO,CARGOID,DCLASS,DUNNO,REEFERF,TEMPID,TEMPSET,TEMPMAX,TEMPMIN");
strSql.Append(",CUSTOMSNUM,REMARK,STATUS1,STATUS2,STATUS3,STATUS4,STATUS5,ISFUMIGATION,ISSTORAGE,ISLAND,ISCUSTOMS,ISINSPECTION");
strSql.Append(",ISBOOKING,ISAGENT,ISHBLNO,SERVICE9,SERVICE10,STLNAME,STLDATE,OCEANFEE,ISUSD,ISCOMMISSIONBACK,CARRIER,CARRIERATTN");
strSql.Append(",CARRIERTEL,CARRIEREMAIL,FORWARDER,FORWARDERATTN,FORWARDERTEL,FORWARDEREMAIL,SALE,PACKINGTYPE,BLTYPE,OP,FRCUSTSERVICE");
strSql.Append(",CUSTSERVICE,doc,AUDITOPERATOR,AUDITDATE,DPAGE,DLABEL,LINKMAN,BILLNUM,HSCODE,AGENTID,AGENT,TRANSPORT");
strSql.Append(",(CASE ORSTATUS WHEN '8' THEN '确认订舱' WHEN '0' THEN '审核通过' WHEN '1' THEN '提交审核' WHEN '2' THEN '驳回' WHEN '4' THEN '退舱' else '录入状态' end) as ORSTATUSREF ");
strSql.Append(",(SELECT CUSTNO FROM V_OP_BILL V WHERE V.BSNO=B.BSNO) as CUSTNO ");
strSql.Append(",(SELECT MBLNO FROM V_OP_BILL V WHERE V.BSNO=B.BSNO) as MBLNOREF,SALEDEPT,BSSOURCE,BSSOURCEDETAIL,(select top 1 sale from info_client where SHORTNAME=B.CUSTOMERNAME) DEFSALE ");
strSql.Append(",dbo.F_GetBillCrmFeeStatus(B.BSNO,1) DRFEESTATUS");
strSql.Append(",dbo.F_GetBillCrmFeeStatus(B.BSNO,2) CRFEESTATUS");
strSql.Append(",'' SenderMobile,'' SenderEmail,CONTRACTNO,'' AMSSHIPPER,'' AMSCONSIGNEE,'' AMSNOTIFYPARTY,CONFIRMOP,CONFIRMDATE,OPERATOR,OPERATORTEL,FBP,DESTFBP,MAXWEIGHT,PLANPROFIT,OPERATOREMAIL,B.LANE ");
strSql.Append(",SALECORPID,(select [NAME] from [company] where GID=B.SALECORPID) as SALECORP ");
strSql.Append(",B.AUDITOPERATOR2,B.ETD2,B.ISSUETYPE2,B.STLNAME2,B.TIDANLEIXING,B.SUBMITDATE ,TRADETERM,DIANSHANGORDERNO,BCNO ");
strSql.Append(",(select DESCRIPTION from info_client where shortname=B.customername) CUSTOMERFULLNAME ");
strSql.Append(",(select top 1 CUSTOMERNAME from crm_seaeorder_fen where MASTERNO = b.BSNO order by ordno) FEN_CUSTOMERNAME");
strSql.Append(",B.ISEI,B.TEU,cd.COUNTRY,cd.CHAU,B.ORDER_CUSTCODE,B.ORDER_CUSTNAME");
strSql.Append(" from crm_seaeorder B");
//strSql.Append(" left join (select t3.* from (select *,row_number() over (partition by EDICODE order by portid asc) as rownum from code_disport) t3 where t3.rownum = 1 ) cd on B.DESTINATIONID = cd.EDICODE ");
strSql.Append(" left join (select * from( select *,row_number() over (partition by EDICODE order by CHAU desc) as rownum from (select EDICODE,COUNTRY,CHAU from code_disport union all select PORTENAME EDICODE,COUNTRY,'' CHAU from code_air_port)t4) t3 where t3.rownum = 1) cd on B.DESTINATIONID = cd.EDICODE ");
if (!string.IsNullOrEmpty(strCondition))
{
strSql.Append(" where " + strCondition);
}
strSql.Append(@")as t2 )as t ");
strSql.Append(string.Format("where t.num>{0} and t.num<={1} order by t.num ", start, start + limit)); //
var isNoForward = MsBaseInfoDAL.MsBaseInfoDAL.GetUserModuleEnable("modMsNoForward", userid);
//return SetData(strSql, "", isNoForward);
return SetData(strSql);
}
public static DBResult AddOrderDetail(string bsno,string ordno,string userid,string companyid)
{
var result = new DBResult();
Database db = DatabaseFactory.CreateDatabase();
using (var conn = db.CreateConnection())
{
conn.Open();
var tran = conn.BeginTransaction();
try
{
var cmdInsert =
db.GetSqlStringCommand(
@"insert into op_ctn (CTN_ID,BSNO,CTNCODE,[SIZE],CTN,CTNNUM,TEU,CTNALL,CNTRNO,SEALNO,PKGS,KGS,CBM,REMARK,KINDPKGS,TAREWEIGHT,GOODSNAME)
values (@CTN_ID,@BSNO,@CTNCODE,@SIZE,@CTN,@CTNNUM,@TEU,@CTNALL,@CNTRNO,@SEALNO,@PKGS,@KGS,@CBM,@REMARK,@KINDPKGS,@TAREWEIGHT,@GOODSNAME) ");
var cmdInsertfee =
db.GetSqlStringCommand(
@"INSERT ch_fee (GID, BSNO, FEETYPE, FEENAME, FEEDESCRIPTION, CUSTOMERTYPE, CUSTOMERNAME, UNIT, UNITPRICE, QUANTITY, AMOUNT, CURRENCY,
EXCHANGERATE, REASON, REMARK, COMMISSIONRATE,ENTEROPERATOR, ENTERDATE,ISOPEN, ISADVANCEDPAY, SORT, FEESTATUS,TAXRATE,NOTAXAMOUNT,ACCTAXRATE,LINENUM,TAXUNITPRICE,FEEFRT,ISCRMORDERFEE)
SELECT NEWID(), @BSNO, FEETYPE, FEENAME, FEEDESCRIPTION, CUSTOMERTYPE, CUSTOMERNAME, UNIT, UNITPRICE, QUANTITY, AMOUNT, CURRENCY,
EXCHANGERATE, REASON, REMARK, COMMISSIONRATE,ENTEROPERATOR, ENTERDATE,ISOPEN, ISADVANCEDPAY, SORT, FEESTATUS,TAXRATE,NOTAXAMOUNT,ACCTAXRATE,LINENUM,TAXUNITPRICE,'PP',1
From ch_fee_order where BSNO=@ORDNO");
var bodyList = MsSeaeOrderDAL.GetBodyList("ORDNO='" +ordno + "'");
if (bodyList != null)
{
foreach (var enumValue in bodyList)
{
int SIZE = int.Parse(enumValue.CTNALL.ToString().Trim().Substring(0, 2));
string CTN = enumValue.CTNALL.ToString().Trim().Substring(2);
int TEU = enumValue.CTNNUM;
int iTEU = int.Parse(enumValue.CTNALL.ToString().Trim().Substring(0, 1));
if (iTEU == 4)
{
TEU = TEU * 2;
}
var feedoid = Guid.NewGuid().ToString();
cmdInsert.Parameters.Clear();
db.AddInParameter(cmdInsert, "@CTN_ID", DbType.String, feedoid);
db.AddInParameter(cmdInsert, "@BSNO", DbType.String,bsno);
db.AddInParameter(cmdInsert, "@CTNCODE", DbType.String,"");
db.AddInParameter(cmdInsert, "@SIZE", DbType.Int16, SIZE);
db.AddInParameter(cmdInsert, "@CTN", DbType.String, CTN);
db.AddInParameter(cmdInsert, "@CTNNUM", DbType.Int16, enumValue.CTNNUM);
db.AddInParameter(cmdInsert, "@TEU", DbType.Int16, TEU);
db.AddInParameter(cmdInsert, "@CTNALL", DbType.String, enumValue.CTNALL);
db.AddInParameter(cmdInsert, "@CNTRNO", DbType.String, "");
db.AddInParameter(cmdInsert, "@SEALNO", DbType.String, "");
db.AddInParameter(cmdInsert, "@PKGS", DbType.Int16, null);
db.AddInParameter(cmdInsert, "@KGS", DbType.Decimal, enumValue.KGS);
db.AddInParameter(cmdInsert, "@CBM", DbType.Decimal, null);
db.AddInParameter(cmdInsert, "@TAREWEIGHT", DbType.Int16, null);
db.AddInParameter(cmdInsert, "@REMARK", DbType.String, "");
db.AddInParameter(cmdInsert, "@KINDPKGS", DbType.String, "");
db.AddInParameter(cmdInsert, "@GOODSNAME", DbType.String, "");
db.ExecuteNonQuery(cmdInsert, tran);
}
}
cmdInsertfee.Parameters.Clear();
db.AddInParameter(cmdInsertfee, "@BSNO", DbType.String, bsno);
db.AddInParameter(cmdInsertfee, "@ORDNO", DbType.String, bsno);
db.ExecuteNonQuery(cmdInsertfee, tran);
tran.Commit();
var SALEORDERAUDITFEESUBMIT = MsSysParamSetDAL.GetData("PARAMNAME='SALEORDERAUDITFEESUBMIT'");
if (SALEORDERAUDITFEESUBMIT.PARAMVALUE == "1") {
var feelist = MsChFeeDAL.MsChFeeDAL.GetDataList("BSNO='" + bsno + "'", 0, "", "", "", "");
if (feelist != null) {
var ISSALEWORK = MsSysParamSetDAL.GetData("PARAMNAME='SALESUBMITFEE'");
Chfee_AuditDAL.Chfee_AuditDAL.SubmitAuditNew("op_Seae", userid, feelist, true, "", ISSALEWORK.PARAMVALUE,companyid);
}
}
result.Success = true;
result.Message = "保存成功" + result.Message;
return result;
}
catch (Exception)
{
tran.Rollback();
result.Success = false;
result.Message = "保存出现错误,请重试或联系系统管理员";
return result;
}
}
result.Success = true;
result.Message = "保存成功" + result.Message;
return result;
}
#endregion
#region 确认订舱
/// <summary>
/// 从销售订舱生成海运出口
/// </summary>
/// <param name="OrderData"></param>
/// <param name="accdate"></param>
/// <param name="op"></param>
/// <param name="custservice"></param>
/// <param name="FORWARDER"></param>
/// <param name="ORREMARK"></param>
/// <param name="OPNAME"></param>
/// <param name="COMPANYID"></param>
/// <param name="userid"></param>
/// <returns></returns>
public static DBResult OrderToOp(MsSeaeOrder _OrderData, string accdate, string op, string custservice, string FORWARDER, string ORREMARK,string OPNAME,string COMPANYID,string userid)
{
var OrderData = GetData("BSNO='" + _OrderData.BSNO + "'");
var result = new DBResult();
if (string.IsNullOrWhiteSpace(OrderData.ETD))
{
result.SetErrorInfo("ETD不能为空");
return result;
}
var headData = new MsOpSeae();
OrderData.CONFIRMOP = OPNAME;
OrderData.CONFIRMDATE = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
OrderData.ORSTATUS = "8";
if (OrderData.PKGS == "") OrderData.PKGS = "0";
if (OrderData.KGS == "") OrderData.KGS = "0";
if (OrderData.CBM == "") OrderData.CBM = "0";
OrderData.DbOperationType = DbOperationType.DbotUpd;
OrderData.ModelUIStatus = "E";
if (OrderData.ETD == "") OrderData.ETD = null;
if (OrderData.ETD2 == "") OrderData.ETD2 = null;
if (OrderData.STLDATE == "") OrderData.STLDATE = null;
if (OrderData.ISSUEDATE == "") OrderData.ISSUEDATE = null;
if (OrderData.CONFIRMDATE == "") OrderData.CONFIRMDATE = null;
if (OrderData.AUDITDATE == "") OrderData.AUDITDATE = null;
headData.CORPID = COMPANYID;
headData.INPUTBY = OPNAME;
headData.BSDATE = DateTime.Now;
headData.BSSTATUS = false;
headData.FEESTATUS = false;
headData.DbOperationType = DbOperationType.DbotIns;
if (FORWARDER != "")
headData.FORWARDER = FORWARDER;
else
headData.FORWARDER = OrderData.FORWARDER;
headData.BSNO = OrderData.BSNO;
headData.MBLNO = OrderData.MBLNO;
headData.CARRIER = OrderData.CARRIER;
headData.CUSTOMERNAME = OrderData.CUSTOMERNAME;
headData.OPERATOR = OrderData.OPERATOR;
//headData.OPERATORTEL = OrderData.OPERATORTEL;
//headData.OPERATOREMAIL = OrderData.OPERATOREMAIL;
headData.ORDERTYPE = "销售订舱";
headData.SHIPPERID = OrderData.SHIPPERID;
headData.CONSIGNEEID = OrderData.CONSIGNEEID;
headData.NOTIFYPARTYID = OrderData.NOTIFYPARTYID;
headData.SHIPPER = OrderData.SHIPPER;
headData.CONSIGNEE = OrderData.CONSIGNEE;
headData.NOTIFYPARTY = OrderData.NOTIFYPARTY;
headData.VESSEL = OrderData.VESSEL;
headData.VOYNO = OrderData.VOYNO;
headData.ETD = OrderData.ETD;//ETD字段显示为ATD 但其他逻辑仍不变
headData.ATD = OrderData.ETD;//ATD字段显示为ETD
if (OrderData.PORTLOADID != "")
headData.PORTLOADID = OrderData.PORTLOADID;
else headData.PORTLOADID = GetPortEDICodeByEname(OrderData.PORTLOAD);
headData.PORTLOAD = OrderData.PORTLOAD;
headData.PORTDISCHARGEID = OrderData.PORTDISCHARGEID;
headData.PORTDISCHARGE = OrderData.PORTDISCHARGE;
headData.PLACERECEIPT = OrderData.PLACERECEIPT;
headData.PLACERECEIPTID = OrderData.PLACERECEIPTID;
headData.PLACEDELIVERYID = OrderData.PLACEDELIVERYID;
headData.PLACEDELIVERY = OrderData.PLACEDELIVERY;
headData.DESTINATIONID = OrderData.DESTINATIONID;
headData.DESTINATION = OrderData.DESTINATION;
headData.TRANSPORT = OrderData.TRANSPORT;
headData.NOBILL = OrderData.NOBILL;
headData.ISSUETYPE = OrderData.ISSUETYPE;
headData.ISSUEDATE = OrderData.ISSUEDATE;
headData.ISSUEPLACE = OrderData.ISSUEPLACE;
headData.ISSUEPLACEID = OrderData.ISSUEPLACEID;
headData.BLFRT = OrderData.BLFRT;
headData.PREPARDAT = OrderData.PREPARDAT;
headData.PAYABLEAT = OrderData.PAYABLEAT;
headData.SERVICE = OrderData.SERVICE;
headData.SERVICECONTRACTNO = OrderData.SERVICECONTRACTNO;
headData.MARKS = OrderData.MARKS;
headData.NOPKGS = OrderData.NOPKGS;
headData.DESCRIPTION = OrderData.DESCRIPTION;
headData.GOODSNAME = OrderData.GOODSNAME;
if (OrderData.CBM == "0")
headData.GROSSWEIGHT = "";
else
headData.GROSSWEIGHT = OrderData.GROSSWEIGHT;
if (OrderData.KGS == "0")
headData.MEASUREMENT = "";
else
headData.MEASUREMENT = OrderData.MEASUREMENT;
headData.PKGS = Convert.ToDecimal(OrderData.PKGS).ToString();
headData.KINDPKGS = OrderData.KINDPKGS;
headData.KGS = Convert.ToDecimal(OrderData.KGS).ToString();
headData.CBM = Convert.ToDecimal(OrderData.CBM).ToString();
headData.TOTALNO = OrderData.TOTALNO;
headData.HSCODE = OrderData.HSCODE;
headData.CARGOID = OrderData.CARGOID;
headData.DCLASS = OrderData.DCLASS;
headData.DPAGE = OrderData.DPAGE;
headData.DUNNO = OrderData.DUNNO;
headData.DLABEL = OrderData.DLABEL;
headData.LINKMAN = OrderData.LINKMAN;
headData.REEFERF = OrderData.REEFERF;
headData.TEMPID = OrderData.TEMPID;
headData.TEMPSET = OrderData.TEMPSET;
headData.TEMPMAX = OrderData.TEMPMAX;
headData.TEMPMIN = OrderData.TEMPMIN;
headData.CUSTOMSNUM = OrderData.CUSTOMSNUM;
var remark = OrderData.REMARK;
if (OrderData.FBP != "0" && OrderData.FBP != "")
remark = remark + " 免箱天数:" + OrderData.FBP;
if (OrderData.DESTFBP != "0" && OrderData.DESTFBP != "")
remark = remark + " 目的港免箱天数:" + OrderData.DESTFBP;
if (OrderData.MAXWEIGHT != "")
remark = remark + " 限重:" + OrderData.MAXWEIGHT;
if (ORREMARK != "")
remark = remark + " 确认订舱备注:" + ORREMARK;
headData.OPERATORFAX = remark;//备注
headData.STATUS1 = OrderData.STATUS1;//状态1
headData.STATUS2 = OrderData.STATUS2;//状态2
headData.STATUS3 = OrderData.STATUS3;//状态3
headData.STATUS4 = OrderData.STATUS4;//状态4
headData.STATUS5 = OrderData.STATUS5;//状态5
headData.ISFUMIGATION = OrderData.ISFUMIGATION;//熏蒸
headData.ISSTORAGE = OrderData.ISSTORAGE;//仓储
headData.ISLAND = OrderData.ISLAND;//陆运
headData.ISCUSTOMS = OrderData.ISCUSTOMS;//报关
headData.ISINSPECTION = OrderData.ISINSPECTION;//报检
headData.ISBOOKING = OrderData.ISBOOKING;//订舱
headData.ISAGENT = OrderData.ISAGENT;//使用代理
headData.ISHBLNO = OrderData.ISHBLNO;//分单签单
headData.SERVICE9 = OrderData.SERVICE9;//服务项目9
headData.SERVICE10 = OrderData.SERVICE10;//服务项目10
headData.STLNAME = OrderData.STLNAME;//结算方式
headData.STLDATE = OrderData.STLDATE;//结算时间
headData.SALE = OrderData.SALE;//揽货人
headData.SALECORP = OrderData.SALECORP;
headData.SALECORPID = OrderData.SALECORPID;
headData.PACKINGTYPE = OrderData.PACKINGTYPE;//装箱类型
headData.BLTYPE = OrderData.BLTYPE;//装运方式
headData.OP = op;//操作员
headData.CUSTSERVICE = custservice;//客服员
headData.FRCUSTSERVICE = OrderData.FRCUSTSERVICE;//单证
headData.DOC = OrderData.DOC;//单证
headData.AGENTID = OrderData.AGENTID;//单证
headData.AGENT = OrderData.AGENT;//单证
headData.ORDERNO = OrderData.BCNO;
headData.APPLYNO = OrderData.DIANSHANGORDERNO;
headData.ETD2 = OrderData.ETD2;
if (string.IsNullOrWhiteSpace(headData.ETD2)) headData.ETD2 = null;
headData.TRADETERM= OrderData.TRADETERM;
var bodyList = MsSeaeOrderDAL.GetBodyList("ORDNO='" + OrderData.ORDNO + "'");
MsSeaeOrderDAL.SetCtnInfo(ref OrderData, bodyList);
headData.CNTRTOTAL = OrderData.CNTRTOTAL;
if (headData.MASTERNO == null || headData.MASTERNO == "") { headData.MASTERNO = headData.BSNO; }
if (headData.ETA == "") headData.ETA = null;
if (headData.ETD == "") headData.ETD = null;
if (headData.STLDATE == "") headData.STLDATE = null;
if (headData.ISSUEDATE == "") headData.ISSUEDATE = null;
if (headData.CLOSINGDATE == "") headData.CLOSINGDATE = null;
headData.LANE = OrderData.LANE;
headData.YARD = OrderData.YARD;
headData.SALEDEPT = OrderData.SALEDEPT;
headData.INVNO = OrderData.INVNO;
headData.BSSOURCE = OrderData.BSSOURCE;
headData.BSSOURCEDETAIL = OrderData.BSSOURCEDETAIL;
headData.CONTRACTNO = OrderData.CONTRACTNO;
headData.ORDERNO = OrderData.BCNO;
headData.APPLYNO = OrderData.DIANSHANGORDERNO;
headData.ISEI = OrderData.ISEI;
headData.ORDER_CUSTCODE = OrderData.ORDER_CUSTCODE;
headData.ORDER_CUSTNAME = OrderData.ORDER_CUSTNAME;
//var billnoset = MsSysBillNoSetDAL.GetData("OPLBNAME='海运出口' AND RULEBLNO='委托编号'",COMPANYID);
//if (billnoset.BILLTYPE != "")
// headData.CUSTNO = MsSysBillNoSetDAL.GetBillNo(billnoset, headData.ETD.ToString().Trim(), headData.ACCDATE.ToString().Trim(), "", headData.OP);
//T_ALL_DA T_ALL_DA = new T_ALL_DA();
//if (!string.IsNullOrEmpty(headData.SALECORPID))
//{
// headData.SALECORPID = OrderData.SALECORPID;
//}
//else
//{
// var SALECORPID = T_ALL_DA.GetStrSQL("COMPANYID", "select top 1 COMPANYID from [VW_user] where SHOWNAME='" + op + "'");
// headData.SALECORPID = SALECORPID;
//}
var cdc = new CommonDataContext();
var _sale = cdc.VW_user_all.FirstOrDefault(x => x.SHOWNAME == headData.SALE);
var isuse = MsBaseInfoDAL.MsBaseInfoDAL.GetRuleUse("委托编号", "1");
var billnoset = MsSysBillNoSetDAL.GetData("OPLBNAME='海运出口' AND RULEBLNO='委托编号'", headData.SALECORPID);
if (billnoset.BILLTYPE != "")
{
var etd = Convert.ToDateTime(headData.ETD);
headData.CUSTNO = MsSysBillNoSetDAL.GetBillNo(billnoset, etd.ToString("yyyy-MM-dd").Trim(), headData.ACCDATE.ToString().Trim(), "", headData.OP, headData.SALECORPID);
}
else
headData.CUSTNO = MsOpSeaeDAL.MsOpSeaeDAL.getCodeRule("委托编号", "CUSTNO", headData.BSDATE.ToString().Trim(), accdate, _sale.USERID, headData.SALECORPID);
headData.SALECORPID = OrderData.SALECORPID;
headData.CORPID = OrderData.SALECORPID;
headData.ACCDATE = accdate;
//20230411 确认订舱时 计算一次结算日期
if (headData.ETD != "" && headData.CUSTOMERNAME != "")// headData.STLDATE == "" &&
{
//根据客户、开船日计算账期
var _dmb = MsInfoClientDAL.GetSTLDATE(headData.CUSTOMERNAME, "海运出口", headData.ETD, headData.SALE);
headData.STLNAME = _dmb.STLNAME;
headData.STLDATE = _dmb.STLDATE;
if (_dmb.STLNAME == "")
{
headData.STLNAME = "现结买单";
headData.STLDATE = BasicDataRefDAL.(headData.ETD);
}
if (_dmb.BSSOURCE != "") headData.BSSOURCE = _dmb.BSSOURCE;
}
var modb = new ModelObjectDB();
result = modb.Save(headData);
var BSNO = headData.BSNO;
if (result.Success == true)
{
result = modb.Save(OrderData);
result = MsSeaeOrderDAL.AddOrderDetail(OrderData.BSNO, OrderData.ORDNO, userid, COMPANYID);
T_ALL_DA T_ALL_DA = new EntityDA.T_ALL_DA();
MsOpSeaeDAL.MsOpSeaeDAL.getCNTRTOTAL(OrderData.BSNO, "op_seae");
var USERID = T_ALL_DA.GetStrSQL("GID", "select top 1 GID from [user] where SHOWNAME='" + op + "'");
var Msgdata = new SYSMessagemb();
Msgdata.GID = Guid.NewGuid().ToString();
Msgdata.NAME = "SALEORDER";
Msgdata.DESCRIPTION = headData.SALE + "销售订舱";
Msgdata.MESSAGECONTENT = headData.SALE + "有新业务订舱," + " 委托编号:" + headData.CUSTNO;
Msgdata.RECEIVER = USERID;
Msgdata.CREATETIME = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
Msgdata.ISREAD = "0";
Msgdata.READCOUNT = "0";
Msgdata.TYPE = "0";
Msgdata.TASKURL = "";
Msgdata.TASKID = headData.BSNO;
Msgdata.NUMBER = "0";
Msgdata.RECVTYPE = "2";
Msgdata.DbOperationType = DbOperationType.DbotIns;
Msgdata.ModelUIStatus = "I";
var Msgmodb = new ModelObjectRepository();
Msgmodb.Save(Msgdata);
var blUpSQL = "insert into Op_SeaCover(CID,BSNO,COVERTITLE,COVERCONTEXT,OPERATOR,OPTIME,ISSYS) values(NEWID(),'" + BSNO + "','销售订舱确认','" + headData.REMARK + "','" + OPNAME+ "','" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + "','1')";
bool bl = T_ALL_DA.GetExecuteSqlCommand(blUpSQL);
USERID = T_ALL_DA.GetStrSQL("GID", "select top 1 GID from [user] where SHOWNAME='" + headData.SALE+ "'");
Msgdata = new SYSMessagemb();
Msgdata.GID = Guid.NewGuid().ToString();
Msgdata.NAME = "SALEORDER";
Msgdata.DESCRIPTION = headData.SALE + "销售订舱";
Msgdata.MESSAGECONTENT = "销售订舱号:" + OrderData.ORDNO+ "已订舱, 委托编号:" + headData.CUSTNO;
Msgdata.RECEIVER = USERID;
Msgdata.CREATETIME = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
Msgdata.ISREAD = "0";
Msgdata.READCOUNT = "0";
Msgdata.TYPE = "0";
Msgdata.TASKURL = "";
Msgdata.TASKID = headData.BSNO;
Msgdata.NUMBER = "0";
Msgdata.RECVTYPE = "2";
Msgdata.DbOperationType = DbOperationType.DbotIns;
Msgdata.ModelUIStatus = "I";
Msgmodb.Save(Msgdata);
var PARAMVALUE = MsSysParamSetDAL.GetData("PARAMNAME='ORDERSENDMAIL'");
if (PARAMVALUE.PARAMVALUE == "1")
{
var mailtitle = "NEW BOOKING:" + headData.CUSTNO+ " 操作主管已确认订舱";
var Body = new StringBuilder();
Body.Append("<html> <Body>");
Body.Append("<br />NEW BOOKING:<br />业务编号:" + headData.CUSTNO);
Body.Append("<br />客户名称:" + headData.CUSTOMERNAME);
Body.Append("<br />揽货人" + headData.SALE);
Body.Append("<br />录入人" + headData.INPUTBY);
Body.Append("<br />港口:" + headData.DESTINATION);
Body.Append("<br />船期:" + headData.ETD);
Body.Append("<br />船公司:" + headData.CARRIER);
Body.Append("<br />箱量:" + headData.CNTRTOTAL);
Body.Append("<br />备注:" + OrderData.REMARK);
Body.Append("</Body></html> ");
//var mailcontext = "NEW BOOKING:\r\n" + "业务编号:" + headData.CUSTNO + "\r\n客户名称" + headData.CUSTOMERNAME + "\r\n揽货人" + headData.SALE + "\r\n港口" + headData.DESTINATION
// + "\r\n船期" + headData.ETD + "\r\n船公司" + headData.CARRIER + "\r\n箱量" + headData.CNTRTOTAL + "\r\n备注" + OrderData.REMARK;
var mailto = "";
var oplist = SysUserDAL.GetDataList("U.SHOWNAME='" + op + "' or U.SHOWNAME='" + headData.SALE + "' or U.SHOWNAME='" + OrderData.INPUTBY + "' ");
foreach (var opbs in oplist)
{
if (opbs.EMAIL1 != "")
{
if (mailto == "")
mailto = opbs.EMAIL1;
else
mailto = mailto + ";" + opbs.EMAIL1;
}
}
if (mailto != "")
{
var doclist = ReceiptDocDAL.GetDocList("BSNO='" + headData.BSNO + "'", " MODIFIEDTIME DESC ");
var j = 0;
var filepath = "";
foreach (var doc in doclist)
{
if (j == 0)
{
filepath = doc.Driect_URL;
}
j = j = 1;
}
result = SendMailWithFile(mailtitle, Body.ToString(), filepath, mailto, OPNAME);
}
}
//20220719
OrderToOp_MakeFen(headData, OrderData, userid,COMPANYID);
}
return result;
}
/// <summary>
/// 根据crm_seaeorder_fen的信息 产生
/// </summary>
/// <param name="OrderData"></param>
public static void OrderToOp_MakeFen(MsOpSeae headdata, MsSeaeOrder orderhead,string userid,string companyid) {
//
//寻找对应的分单列表
var cdc = new CommonDataContext();
var fenlist = cdc.crm_seaeorder_fen.Where(x => x.MASTERNO == headdata.BSNO).ToList();
if (fenlist != null && fenlist.Count > 0) {
var _count = 0;
fenlist = fenlist.OrderBy(s => s.ORDNO).ToList();
foreach (var fen in fenlist) {
//20220811 改用提单管理来保存分单信息
/* headData.ORDERNO = OrderData.BCNO;
headData.APPLYNO = OrderData.DIANSHANGORDERNO;*/
var newrec = new OP_SEAE_BILLMANAGE_md();
newrec = AutoMapperHelper.MapTo<MsOpSeae, OP_SEAE_BILLMANAGE_md>(headdata);
GetFenValue(ref newrec,fen);
newrec.AGENT = headdata.CONSIGNEE;
newrec.AGENTID = headdata.CONSIGNEEID;
newrec.ORDERNO = orderhead.BCNO;
if (fenlist.Count == 1)
newrec.HBLNO = headdata.CUSTNO;
else
{
var _tail = "";
if (_count > 25)
{
_tail = BasicDataRefDAL.chrtostr(65 + _count / 25);
}
_tail += BasicDataRefDAL.chrtostr(65 + _count % 25);
newrec.HBLNO = headdata.CUSTNO + _tail;
_count++;
}
cdc.OP_SEAE_BILLMANAGE.Add(newrec);
var fenctnlist = cdc.crm_seaeorderctn.Where(x => x.ORDNO == fen.ORDNO);
foreach (var fenctn in fenctnlist) {
var newctn = new op_ctn_md();
newctn = AutoMapperHelper.MapTo<crm_seaeorderctn_md, op_ctn_md>(fenctn);
newctn.CTN_ID = Guid.NewGuid().ToString();
newctn.BSNO = newrec.AS_ID;
var codectn = BasicDataRefDAL.GetCodeCtn(newctn.CTNALL);
if (codectn == null)
newctn.TEU = 0;
else {
newctn.TEU = (int)(codectn.TEU * newctn.CTNNUM);
}
cdc.OP_CTN.Add(newctn);
}
//newrec.cus
//var newfenrec = AutoMapperHelper.MapTo<MsOpSeae, MsOpSeae>(headdata);
//newfenrec.DbOperationType = DbOperationType.DbotIns;
//newfenrec.BSNO = fen.BSNO;
//newfenrec.MASTERNO = fen.MASTERNO;
//newfenrec.CUSTOMERNAME = fen.CUSTOMERNAME;
////newfenrec.CUSTNO = fen.ORDNO;
//var billnoset = MsSysBillNoSetDAL.GetData("OPLBNAME='海运出口' AND RULEBLNO='委托编号'", companyid);
//if (billnoset.BILLTYPE != "")
// newfenrec.CUSTNO = MsSysBillNoSetDAL.GetBillNo(billnoset, headdata.ETD.ToString().Trim(), headdata.ACCDATE.ToString().Trim(), "", headdata.OP);
//else
// headdata.CUSTNO = MsOpSeaeDAL.MsOpSeaeDAL.getCodeRule("委托编号", "CUSTNO", headdata.BSDATE.ToString().Trim(), headdata.ACCDATE, userid, companyid);
//newfenrec.SHIPPERID = fen.SHIPPERID;
//newfenrec.SHIPPER = MsOpSeaeDAL.MsOpSeaeDAL.GetShipperDetailByShipperid(newfenrec.SHIPPERID);
//newfenrec.CONSIGNEEID = fen.CONSIGNEEID;
//newfenrec.CONSIGNEE = MsOpSeaeDAL.MsOpSeaeDAL.GetShipperDetailByShipperid(newfenrec.CONSIGNEEID);
//newfenrec.NOTIFYPARTYID = fen.NOTIFYPARTYID;
//newfenrec.NOTIFYPARTY = MsOpSeaeDAL.MsOpSeaeDAL.GetShipperDetailByShipperid(newfenrec.NOTIFYPARTYID);
//newfenrec.PKGS = fen.PKGS.ToString();
//newfenrec.KGS = fen.KGS.ToString();
//newfenrec.CBM = fen.CBM.ToString();
//if (string.IsNullOrEmpty(newfenrec.PKGS)) newfenrec.PKGS = "0";
//if (string.IsNullOrEmpty(newfenrec.KGS)) newfenrec.KGS = "0";
//if (string.IsNullOrEmpty(newfenrec.CBM)) newfenrec.CBM = "0";
//newfenrec.MARKS = fen.MARKS;
//newfenrec.DESCRIPTION = fen.DESCRIPTION;
////20220727 分单agent=主单consignee
//newfenrec.AGENT = headdata.CONSIGNEE;
//newfenrec.AGENTID = headdata.CONSIGNEEID;
//newfenrec.SHIPPERID = fen.SHIPPERID;
//newfenrec.CONSIGNEEID = fen.CONSIGNEEID;
//newfenrec.NOTIFYPARTYID = fen.NOTIFYPARTYID;
////newfenrec.EDI_TIME = null;
////newfenrec.VGM_TIME = null;
//var modb = new ModelObjectDB();
//var result = modb.Save(newfenrec);
//if (result.Success) {
// MsSeaeOrderDAL.AddOrderDetail(fen.BSNO, fen.ORDNO, userid, companyid);
//}
//var fenctnlist = cdc.crm_seaeorderctn.Where(x => x.ORDNO == fen.ORDNO).ToList();
//if (fenctnlist != null && fenctnlist.Count > 0) {
// foreach (var fenctn in fenctnlist) {
// var newctn = new op_ctn_md();
// newctn.CTN_ID = Guid.NewGuid().ToString();
// newctn.BSNO = newfenrec.BSNO;
// newctn.CTNNUM = fenctn.CTNNUM;
// newctn.CTNALL = fenctn.CTNALL;
// if (fenctn.CTNALL.Length == 4) {
// newctn.SIZE = fenctn.CTNALL.Substring(0, 2);
// newctn.CTN = fenctn.CTNALL.Substring(2, 2);
// }
// newctn.REMARK= fenctn.REMARK;
// newctn.vgmconncom = "";
// newctn.TEU = 0;
// newctn.WEIGHKGS = 0;
// cdc.OP_CTN.Add(newctn);
// }
//}
//cdc.SaveChanges();
}
cdc.SaveChanges();
}
}
public static void GetFenValue( ref OP_SEAE_BILLMANAGE_md newrec,crm_seaeorder_fen_md fenitem)
{
newrec.AS_ID = Guid.NewGuid().ToString();
newrec.SHIPPERID = "";
newrec.SHIPPER = "";
newrec.CONSIGNEEID = "";
newrec.CONSIGNEE = "";
newrec.NOTIFYPARTYID = "";
newrec.NOTIFYPARTY = "";
newrec.OPERATOR = "";
newrec.OPERATORTEL = "";
newrec.OPERATOREMAIL = "";
newrec.SHIPPERID = fenitem.SHIPPERID;
var _shipper = v_info_shipper_md.GetShipper(newrec.SHIPPERID);
if (_shipper != null)
{
newrec.SHIPPER = _shipper.shipperdetail;
}
newrec.CONSIGNEEID = fenitem.CONSIGNEEID;
var _CONSIGNEE = v_info_shipper_md.GetShipper(newrec.CONSIGNEEID);
if (_CONSIGNEE != null)
{
newrec.CONSIGNEE = _CONSIGNEE.shipperdetail;
}
newrec.NOTIFYPARTYID = fenitem.NOTIFYPARTYID;
var _NOTIFYPARTY = v_info_shipper_md.GetShipper(newrec.NOTIFYPARTYID);
if (_NOTIFYPARTY != null)
{
newrec.NOTIFYPARTY = _NOTIFYPARTY.shipperdetail;
}
newrec.CUSTOMERNAME = fenitem.CUSTOMERNAME;
newrec.OPERATOR = fenitem.OPERATOR;
newrec.OPERATORTEL = fenitem.OPERATORTEL;
newrec.OPERATOREMAIL = fenitem.OPERATOREMAIL;
newrec.PKGS = fenitem.PKGS ;
newrec.KGS = fenitem.KGS;
newrec.CBM = fenitem.CBM;
newrec.NOPKGS = newrec.PKGS.ToString();
newrec.GROSSWEIGHT = newrec.KGS.ToString();
newrec.MEASUREMENT = newrec.CBM.ToString();
}
#endregion
public static DBResult SendMailWithFile(string title, string context, string filePath, string MailToAddress,string username)
{
var result = new DBResult();
if (MailToAddress == "")
{
result.Success = false;
result.Message = "邮箱不能为空!";
return result;
}
var MAILTONAME = "admin@dongshengsoft.com";
var PARAMVALUE = MsSysParamSetDAL.GetData("PARAMNAME='MAILTONAME'");
if (PARAMVALUE.PARAMVALUE != "") MAILTONAME = PARAMVALUE.PARAMVALUE;
var MAILTOPASSWORD = "ds!@#)(*";
PARAMVALUE = MsSysParamSetDAL.GetData("PARAMNAME='MAILTOPASSWORD'");
if (PARAMVALUE.PARAMVALUE != "") MAILTOPASSWORD = PARAMVALUE.PARAMVALUE;
var MAILTOSERVER = "smtpcom.263xmail.com";
PARAMVALUE = MsSysParamSetDAL.GetData("PARAMNAME='MAILTOSERVER'");
if (PARAMVALUE.PARAMVALUE != "") MAILTOSERVER = PARAMVALUE.PARAMVALUE;
var MAILTOPORT = "465";
PARAMVALUE = MsSysParamSetDAL.GetData("PARAMNAME='MAILTOPORT'");
if (PARAMVALUE.PARAMVALUE != "") MAILTOPORT = PARAMVALUE.PARAMVALUE;
var MAILISSSL = false;
PARAMVALUE = MsSysParamSetDAL.GetData("PARAMNAME='MAILISSSL'");
if (PARAMVALUE.PARAMVALUE == "1") MAILISSSL = true;
filePath = System.Web.HttpContext.Current.Server.MapPath(filePath);
try
{
var recipients = new List<string>();
var ccList = new List<string>();
string[] emailList = MailToAddress.Split(';');
foreach (var m in emailList)
{
if (m.Trim() != "")
recipients.Add(m);
}
var filename = Path.GetFileName(filePath);
var fileExt = Path.GetExtension(filename);
var mailBodyEntity = new MailBodyEntity()
{
Body = context,
MailBodyType = TextFormat.Html,
Cc = ccList,
//MailBodyType = "html",
MailFiles = new List<MailFile>() {
new MailFile { MailFilePath = filePath, MailFileSubType = fileExt, MailFileType =fileExt }
},
Recipients = recipients,
Sender = MAILTONAME,
SenderAddress = MAILTONAME,
Subject = title,
};
var sendServerConfiguration = new SendServerConfigurationEntity()
{
SenderPassword = MAILTOPASSWORD,
SmtpPort = Convert.ToInt32(MAILTOPORT),
IsSsl = MAILISSSL,
MailEncoding = "utf-8",
SenderAccount = MAILTONAME,
SmtpHost = MAILTOSERVER,
};
var Mailresult = MailHelper.SendMail(mailBodyEntity, sendServerConfiguration);
if (Mailresult.ResultStatus == true)
{
var head = new OpMailLog();
head.BSNO = "";
head.BLTYPE = "销售订舱审核通过";
head.RECEIVER = MailToAddress;
head.SUBJECT = title;
head.DESCRIPTION = context;
head.ATTACHMENT = "../../ AutoDuiFiles / Excels" + filename;
head.SENDER = username;
head.SENDTIME = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
head.DbOperationType = DbOperationType.DbotIns;
var modb = new ModelObjectDB();
modb.Save(head);
}
else
{
result.Success = Mailresult.ResultStatus;
result.Message = Mailresult.ResultInformation;
return result;
}
}
catch (Exception ex)
{
result.Success = false;
result.Message = ex.Message;
return result;
}
result.Success = true;
result.Message = "发送成功!";
return result;
}
static public string GetPortEDICodeByEname(string port)
{
string EDICODE = "";
var strSql = new StringBuilder();
strSql.Append("select EDICODE from code_disport where PORT='" + port + "'");
Database db = DatabaseFactory.CreateDatabase();
using (IDataReader reader = db.ExecuteReader(CommandType.Text, strSql.ToString()))
{
while (reader.Read())
{
EDICODE = Convert.ToString(reader["EDICODE"]).Trim();
}
reader.Close();
}
if (EDICODE.Trim() == "")
{
var strSql2 = new StringBuilder();
strSql2.Append("select EDICODE from code_loadport where PORT='" + port + "' ");
db = DatabaseFactory.CreateDatabase();
using (IDataReader reader = db.ExecuteReader(CommandType.Text, strSql2.ToString()))
{
while (reader.Read())
{
EDICODE = Convert.ToString(reader["EDICODE"]).Trim();
}
reader.Close();
}
}
return EDICODE;
}
#region 网上订舱处理
static public List<MsSeaeOrder> GetWebDataList(string strCondition, string sort = null)
{
var strSql = new StringBuilder();
strSql.AppendLine("SELECT top 20 BSNO ORDNO,BSNO,BSSTATUS as ORSTATUS,BLTYPE,BSDATE, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='MBLNO' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then MBLNO else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='MBLNO' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS MBLNO, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='SHIPPER' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then SHIPPER else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='SHIPPER' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS SHIPPER, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='CONSIGNEE' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then CONSIGNEE else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='CONSIGNEE' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS CONSIGNEE, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='NOTIFYPARTY' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then NOTIFYPARTY else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='NOTIFYPARTY' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS NOTIFYPARTY, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='VESSEL' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then VESSEL else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='VESSEL' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS VESSEL, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='VOYNO' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then VOYNO else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='VOYNO' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS VOYNO, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='PlACERECEIPT' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then PlACERECEIPT else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='PlACERECEIPT' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS PlACERECEIPT, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='PORTLOAD' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then PORTLOAD else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='PORTLOAD' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS PORTLOAD, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='PORTDISCHARGE' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then PORTDISCHARGE else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='PORTDISCHARGE' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS PORTDISCHARGE, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='PLACEDELIVERY' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then PLACEDELIVERY else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='PLACEDELIVERY' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS PLACEDELIVERY, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='BLFRT' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then BLFRT else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='BLFRT' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS BLFRT, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='SERVICE' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then [SERVICE] else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='SERVICE' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS [SERVICE], ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='MARKS' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then MARKS else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='MARKS' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS MARKS, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='DESCRIPTION' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then [DESCRIPTION] else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='DESCRIPTION' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS [DESCRIPTION], ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='GOODSNAME' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then GOODSNAME else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='GOODSNAME' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS GOODSNAME, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='GROSSWEIGHT' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then GROSSWEIGHT else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='GROSSWEIGHT' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS GROSSWEIGHT, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='MEASUREMENT' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then MEASUREMENT else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='MEASUREMENT' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS MEASUREMENT, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='PKGS' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then PKGS else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='PKGS' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS PKGS, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='KINDPKGS' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then KINDPKGS else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='KINDPKGS' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS KINDPKGS, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='KGS' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then KGS else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='KGS' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS KGS, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='CBM' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then CBM else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='CBM' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS CBM, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='TOTALNO' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then TOTALNO else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='TOTALNO' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS TOTALNO, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='CNTR' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then CNTR else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='CNTR' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS CNTRTOTAL, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='CARGOID' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then CARGOID else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='CARGOID' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS CARGOID, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='DCLASS' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then DCLASS else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='DCLASS' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS DCLASS, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='DUNNO' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then DUNNO else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='DUNNO' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS DUNNO, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='REEFERF' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then REEFERF else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='REEFERF' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS REEFERF, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='TEMPID' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then TEMPID else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='TEMPID' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS TEMPID, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='TEMPSET' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then TEMPSET else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='TEMPSET' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS TEMPSET, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='BOOKINGDESCRIPTION' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then BOOKINGDESCRIPTION else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='BOOKINGDESCRIPTION' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS REMARK, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='DPAGE' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then DPAGE else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='DPAGE' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS DPAGE, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='DLABEL' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then DLABEL else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='DLABEL' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS DLABEL, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='LINKMAN' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then LINKMAN else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='LINKMAN' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS LINKMAN, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='ISSUEWAY' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then ISSUEWAY else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='ISSUEWAY' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS ISSUETYPE, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='BILLNUM' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then BILLNUM else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='BILLNUM' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS BILLNUM, ");
strSql.AppendLine("(Select name from Company where companyID=B.companyID) as CUSTOMERNAME, ");
strSql.AppendLine("'网上订舱' ORDTYPE,SHIPPERID,CONSIGNEEID,NOTIFYPARTYID,ETD,PORTLOADID,PORTDISCHARGEID, ");
strSql.AppendLine("PLACEDELIVERYID,DESTINATIONID,DESTINATION,ISSUEDATE,ISSUEPLACE,PREPARDAT,PAYABLEAT,HSCODE, ");//NOBILL,ISSUETYPE,
strSql.AppendLine("NOPKGS,(SELECT userName FROM UserInfo WHERE userID=B.INPUTBY) INPUTBY, ");
strSql.AppendLine("'' INVNO,0 CUSTOMSNUM,STATUS1,STATUS2,STATUS3,STATUS4,STATUS5,0 ISFUMIGATION,TEMPMAX,TEMPMIN, ");
strSql.AppendLine("0 ISSTORAGE,0 ISLAND,0 ISCUSTOMS,0 ISINSPECTION,0 ISBOOKING,0 ISAGENT,0 ISHBLNO, ");
strSql.AppendLine("0 SERVICE9,0 SERVICE10,'' STLNAME,null STLDATE,0 OCEANFEE,0 ISUSD, ");
strSql.AppendLine("0 ISCOMMISSIONBACK,CARRIER,'' CARRIERATTN,'' CARRIERTEL,'' CARRIEREMAIL, ");
strSql.AppendLine("'' FORWARDER,'' FORWARDERATTN,'' FORWARDERTEL,'' FORWARDEREMAIL,'' SALE, ");
strSql.AppendLine("PACKINGTYPE,'' BLTYPE,OP,'' CUSTSERVICE,'' doc,ISSUEWAY,BILLNUM,'' AGENTID,'' AGENT, ");
strSql.AppendLine("(SELECT userName FROM UserInfo WHERE userID=B.AUDITOR) AUDITOPERATOR, ");
strSql.AppendLine("'' AUDITDATE, ");
strSql.AppendLine("(Select className from InfoClass where classID=B.BSSTATUS) as ORSTATUSREF , ");
strSql.AppendLine("(select top 1 Remark from BookingCargoSpaceStatus where flowid=B.BSSTATUS and bsno=B.bsno order by subdate desc) ORREASON , ");
strSql.AppendLine("(select mobile from userinfo where userid=inputby) SenderMobile, ");
strSql.AppendLine("(select email from userinfo where userid=inputby) SenderEmail ,CUSTNO, ");
strSql.AppendLine("CONTRACTNO,AMSSHIPPER,AMSCONSIGNEE,AMSNOTIFYPARTY,'' CONFIRMOP,null CONFIRMDATE,'' OPERATOR,'' OPERATORTEL,'0' FBP,'0' DESTFBP,'' MAXWEIGHT,'' PLANPROFIT,'' OPERATOREMAIL ");
strSql.AppendLine(" from BookingCargoSpace B");
if (!string.IsNullOrEmpty(strCondition))
{
strSql.AppendLine(" where " + strCondition);
}
//
var sortstring = DatasetSort.Getsortstring(sort);
if (!string.IsNullOrEmpty(sortstring))
{
strSql.AppendLine(" order by " + sortstring);
}
else
{
strSql.AppendLine(" order by BSDATE desc");
}
return SetWebData(strSql,"SHIPPINGBOX");
}
private static List<MsSeaeOrder> SetWebData(StringBuilder strSql, string dbstr = "")
{
var headList = new List<MsSeaeOrder>();
Database db = null;
if (dbstr != "")
db = DatabaseFactory.CreateDatabase(dbstr);
else
db = DatabaseFactory.CreateDatabase();
SqlCommand cmd = new SqlCommand();
cmd.CommandText = strSql.ToString();
cmd.CommandTimeout = 120000; //要加这一句
using (IDataReader reader = db.ExecuteReader(cmd))
{
while (reader.Read())
{
MsSeaeOrder data = new MsSeaeOrder();
#region Set DB data to Object
data.ORDNO = Convert.ToString(reader["ORDNO"]);//委托
data.BSNO = Convert.ToString(reader["BSNO"]);//业务编号
data.BLTYPE = Convert.ToString(reader["BLTYPE"]);//装运方式
data.ORSTATUS = Convert.ToString(reader["ORSTATUS"]);//主编号
data.ORSTATUSREF = Convert.ToString(reader["ORSTATUSREF"]);//委托编号
data.ORREASON = Convert.ToString(reader["ORREASON"]);//分提单号
data.BSDATE = Convert.ToDateTime(reader["BSDATE"]);//接单日期
data.MBLNO = Convert.ToString(reader["MBLNO"]);//主提单号
data.CUSTNO = Convert.ToString(reader["CUSTNO"]);//主提单号
data.CUSTOMERNAME = Convert.ToString(reader["CUSTOMERNAME"]);//委托单位
data.ORDTYPE = Convert.ToString(reader["ORDTYPE"]);//业务状态
data.SHIPPERID = Convert.ToString(reader["SHIPPERID"]);//发货人
data.CONSIGNEEID = Convert.ToString(reader["CONSIGNEEID"]);//收货人
data.NOTIFYPARTYID = Convert.ToString(reader["NOTIFYPARTYID"]);//通知人
data.SHIPPER = Convert.ToString(reader["SHIPPER"]).Replace(@"\\\\", "\n").Replace(@"^", "\'").Replace(@"&-add-", "+"); //发货人内容
data.CONSIGNEE = Convert.ToString(reader["CONSIGNEE"]).Replace(@"\\\\", "\n").Replace(@"^", "\'").Replace(@"&-add-", "+");//收货人内容
data.NOTIFYPARTY = Convert.ToString(reader["NOTIFYPARTY"]).Replace(@"\\\\", "\n").Replace(@"^", "\'").Replace(@"&-add-", "+");//通知人内容
data.VESSEL = Convert.ToString(reader["VESSEL"]);//船名
data.VOYNO = Convert.ToString(reader["VOYNO"]);//航次
if (reader["ETD"] != DBNull.Value)
data.ETD = Convert.ToDateTime(reader["ETD"]).ToString("yyyy-MM-dd");//到港日期
data.PORTLOADID = Convert.ToString(reader["PORTLOADID"]);//装货港代码
data.PORTLOAD = Convert.ToString(reader["PORTLOAD"]);//装货港
data.PORTDISCHARGEID = Convert.ToString(reader["PORTDISCHARGEID"]);//卸货港代码
data.PORTDISCHARGE = Convert.ToString(reader["PORTDISCHARGE"]).Replace(@"^", "\'");//卸货港
data.PLACERECEIPT = Convert.ToString(reader["PlACERECEIPT"]).Replace(@"^", "\'");//收货地
data.PLACEDELIVERYID = Convert.ToString(reader["PLACEDELIVERYID"]);//交货地代码
data.PLACEDELIVERY = Convert.ToString(reader["PLACEDELIVERY"]).Replace(@"^", "\'");//交货地
data.DESTINATIONID = Convert.ToString(reader["DESTINATIONID"]);//目的地代码
data.DESTINATION = Convert.ToString(reader["DESTINATION"]).Replace(@"^", "\'");//目的地
data.NOBILL = Convert.ToString(reader["BILLNUM"]);//提单份数
data.ISSUETYPE = Convert.ToString(reader["ISSUETYPE"]);//签单方式
if (reader["ISSUEDATE"] != DBNull.Value)
data.ISSUEDATE = Convert.ToDateTime(reader["ISSUEDATE"]).ToString("yyyy-MM-dd");//预抵日期
data.ISSUEPLACE = Convert.ToString(reader["ISSUEPLACE"]);//签单地点
data.BLFRT = Convert.ToString(reader["BLFRT"]);//付费方式
data.PREPARDAT = Convert.ToString(reader["PREPARDAT"]);//预付地点
data.PAYABLEAT = Convert.ToString(reader["PAYABLEAT"]);//到付地点
data.SERVICE = Convert.ToString(reader["SERVICE"]);//运输条款
data.MARKS = Convert.ToString(reader["MARKS"]).Replace(@"\\\\", "\n").Replace(@"^", "\'").Replace(@"&-add-", "+"); //唛头
//data.NOPKGS = Convert.ToString(reader["NOPKGS"]).Replace(@"\\\\", "\n").Replace(@"^", "\'");//件数包装
string _pkgs = Convert.ToString(reader["PKGS"].ToString());
/*for (int iCount = 0; iCount < 5; iCount++)
{
int _lengthPkgs = _pkgs.Length;
char _tempPkgs = _pkgs[_lengthPkgs - 1];
if (_tempPkgs == '0') { _pkgs = _pkgs.Substring(0, _lengthPkgs - 1); }
else { break; }
}
if (_pkgs[_pkgs.Length - 1] == '.') { _pkgs = _pkgs.Substring(0, _pkgs.Length - 1); }*/
data.NOPKGS = Convert.ToString(_pkgs + reader["KINDPKGS"].ToString());//件数包装
data.DESCRIPTION = Convert.ToString(reader["DESCRIPTION"]).Replace(@"\\\\", "\n").Replace(@"^", "\'").Replace(@"&-add-", "+"); //货物描述
data.GOODSNAME = Convert.ToString(reader["GOODSNAME"]);//品名
//data.GROSSWEIGHT = Convert.ToString(reader["GROSSWEIGHT"]).Replace(@"\\\\", "\n").Replace(@"^", "\'"); //货物毛重
string _kgs = Convert.ToString(reader["KGS"]);
for (int iCount = 0; iCount < 5; iCount++)
{
int _lengthKgs = _kgs.Length;
char _tempKgs = _kgs[_lengthKgs - 1];
if (_tempKgs == '0') { _kgs = _kgs.Substring(0, _lengthKgs - 1); }
else { break; }
}
if (_kgs[_kgs.Length - 1] == '.') { _kgs = _kgs.Substring(0, _kgs.Length - 1); }
data.GROSSWEIGHT = _kgs + "KGS"; //货物毛重
//data.MEASUREMENT = Convert.ToString(reader["MEASUREMENT"]).Replace(@"\\\\", "\n").Replace(@"^", "\'"); //货物尺码
string _cbm = Convert.ToString(reader["CBM"]);
for (int iCount = 0; iCount < 5; iCount++)
{
int _lengthCbm = _cbm.Length;
char _tempCbm = _cbm[_lengthCbm - 1];
if (_tempCbm == '0') { _cbm = _cbm.Substring(0, _lengthCbm - 1); }
else { break; }
}
if (_cbm[_cbm.Length - 1] == '.') { _cbm = _cbm.Substring(0, _cbm.Length - 1); }
data.MEASUREMENT = _cbm + "CBM"; //货物尺码
data.PKGS = Convert.ToString(_pkgs);//件数
data.KINDPKGS = Convert.ToString(reader["KINDPKGS"]);//件数包装
data.KGS = Convert.ToString(_kgs);//毛重
data.CBM = Convert.ToString(_cbm);//立方数/尺码
data.TOTALNO = Convert.ToString(reader["TOTALNO"]);//件数大写
data.CNTRTOTAL = Convert.ToString(reader["CNTRTOTAL"]);//集装箱全部内容
data.INPUTBY = Convert.ToString(reader["INPUTBY"]);//录入人
//data.OPERATORTEL = Convert.ToString(reader["SenderMobile"]);//录入人
//data.OPERATOREMAIL = Convert.ToString(reader["SenderEmail"]);//录入人
data.OPERATORTEL = Convert.ToString(reader["OPERATORTEL"]);//录入人
data.OPERATOREMAIL = Convert.ToString(reader["OPERATOREMAIL"]);//录入人
data.INVNO = Convert.ToString(reader["INVNO"]);//发票号
data.CARGOID = Convert.ToString(reader["CARGOID"]);//货物标识
data.HSCODE = Convert.ToString(reader["HSCODE"]);
data.DCLASS = Convert.ToString(reader["DCLASS"]);//危险品分类/等级
data.DUNNO = Convert.ToString(reader["DUNNO"]);//危险品编号
data.DPAGE = Convert.ToString(reader["DPAGE"]);//危险品页号
data.DLABEL = Convert.ToString(reader["DLABEL"]);//危险品标签
data.LINKMAN = Convert.ToString(reader["LINKMAN"]);//危险品联系人
data.REEFERF = Convert.ToString(reader["REEFERF"]);//冷藏通风量
if (Convert.ToString(reader["TEMPID"]) != "undefined")
data.TEMPID = Convert.ToString(reader["TEMPID"]);//温度单位
data.TEMPSET = Convert.ToString(reader["TEMPSET"]);//设置温度
data.TEMPMAX = Convert.ToString(reader["TEMPMAX"]);//最高温度
data.TEMPMIN = Convert.ToString(reader["TEMPMIN"]);//最低温度
data.CUSTOMSNUM = Convert.ToInt32(reader["CUSTOMSNUM"]);//报关票数
data.REMARK = Convert.ToString(reader["REMARK"]).Replace(@"\\\\", "\n").Replace(@"^", "\'").Replace(@"&-add-", "+");//备注
if (reader["STATUS1"] != DBNull.Value)
data.STATUS1 = Convert.ToBoolean(reader["STATUS1"]);//状态1
if (reader["STATUS2"] != DBNull.Value)
data.STATUS2 = Convert.ToBoolean(reader["STATUS2"]);//状态2
if (reader["STATUS3"] != DBNull.Value)
data.STATUS3 = Convert.ToBoolean(reader["STATUS3"]);//状态3
if (reader["STATUS4"] != DBNull.Value)
data.STATUS4 = Convert.ToBoolean(reader["STATUS4"]);//状态4
if (reader["STATUS5"] != DBNull.Value)
data.STATUS5 = Convert.ToBoolean(reader["STATUS5"]);//状态5
if (reader["ISFUMIGATION"] != DBNull.Value)
data.ISFUMIGATION = Convert.ToBoolean(reader["ISFUMIGATION"]);//熏蒸
if (reader["ISSTORAGE"] != DBNull.Value)
data.ISSTORAGE = Convert.ToBoolean(reader["ISSTORAGE"]);//仓储
if (reader["ISLAND"] != DBNull.Value)
data.ISLAND = Convert.ToBoolean(reader["ISLAND"]);//陆运
if (reader["ISCUSTOMS"] != DBNull.Value)
data.ISCUSTOMS = Convert.ToBoolean(reader["ISCUSTOMS"]);//报关
if (reader["ISINSPECTION"] != DBNull.Value)
data.ISINSPECTION = Convert.ToBoolean(reader["ISINSPECTION"]);//报检
if (reader["ISBOOKING"] != DBNull.Value)
data.ISBOOKING = Convert.ToBoolean(reader["ISBOOKING"]);//订舱
if (reader["ISAGENT"] != DBNull.Value)
data.ISAGENT = Convert.ToBoolean(reader["ISAGENT"]);//使用代理
if (reader["ISHBLNO"] != DBNull.Value)
data.ISHBLNO = Convert.ToBoolean(reader["ISHBLNO"]);//分单签单
if (reader["SERVICE9"] != DBNull.Value)
data.SERVICE9 = Convert.ToBoolean(reader["SERVICE9"]);//服务项目9
if (reader["SERVICE10"] != DBNull.Value)
data.SERVICE10 = Convert.ToBoolean(reader["SERVICE10"]);//服务项目10
data.STLNAME = Convert.ToString(reader["STLNAME"]);//结算方式
if (reader["STLDATE"] != DBNull.Value)
data.STLDATE = Convert.ToDateTime(reader["STLDATE"]).ToString("yyyy-MM-dd");//结算时间
if (reader["OCEANFEE"] != DBNull.Value)
data.OCEANFEE = Convert.ToDecimal(reader["OCEANFEE"]);//
if (reader["ISUSD"] != DBNull.Value)
data.ISUSD = Convert.ToBoolean(reader["ISUSD"]);//
if (reader["ISCOMMISSIONBACK"] != DBNull.Value)
data.ISCOMMISSIONBACK = Convert.ToBoolean(reader["ISCOMMISSIONBACK"]);//
data.CARRIER = Convert.ToString(reader["CARRIER"]);//船公司
data.CARRIERATTN = Convert.ToString(reader["CARRIERATTN"]);//船公司
data.CARRIERTEL = Convert.ToString(reader["CARRIERTEL"]);//船公司
data.CARRIEREMAIL = Convert.ToString(reader["CARRIEREMAIL"]);//船公司
data.FORWARDER = Convert.ToString(reader["FORWARDER"]);//订舱公司
data.FORWARDERATTN = Convert.ToString(reader["FORWARDERATTN"]);//订舱公司
data.FORWARDERTEL = Convert.ToString(reader["FORWARDERTEL"]);//订舱公司
data.FORWARDEREMAIL = Convert.ToString(reader["FORWARDEREMAIL"]);//订舱公司
data.SALE = Convert.ToString(reader["SALE"]);//揽货人
data.PACKINGTYPE = Convert.ToString(reader["PACKINGTYPE"]);//装箱类型
data.BLTYPE = Convert.ToString(reader["BLTYPE"]);//装运方式
data.OP = Convert.ToString(reader["OP"]);//操作员
data.CUSTSERVICE = Convert.ToString(reader["CUSTSERVICE"]);//客服员
data.DOC = Convert.ToString(reader["DOC"]);//单证
data.AUDITOPERATOR = Convert.ToString(reader["AUDITOPERATOR"]);//审核人
if (reader["AUDITDATE"] != DBNull.Value)
data.AUDITDATE = Convert.ToDateTime(reader["AUDITDATE"]).ToString("yyyy-MM-dd HH:mm:ss");//截港日期
if (reader["CONFIRMDATE"] != DBNull.Value)
data.CONFIRMDATE = Convert.ToDateTime(reader["CONFIRMDATE"]).ToString("yyyy-MM-dd HH:mm:ss");//截港日期
data.CONFIRMOP = Convert.ToString(reader["CONFIRMOP"]);//确认人
//data.OPERATORTEL = Convert.ToString(reader["SenderMobile"]);//
//data.OPERATOREMAIL = Convert.ToString(reader["SenderEmail"]);//
//if (data.OPERATORTEL != "")
// data.OPERATORTEL = Convert.ToString(reader["OPERATORTEL"]);//
//if (data.OPERATOREMAIL != "")
// data.OPERATOREMAIL = Convert.ToString(reader["OPERATOREMAIL"]);//
data.OPERATOR = Convert.ToString(reader["OPERATOR"]);//
data.FBP = Convert.ToString(reader["FBP"]);//
data.DESTFBP = Convert.ToString(reader["DESTFBP"]);//
data.MAXWEIGHT = Convert.ToString(reader["MAXWEIGHT"]);//
data.PLANPROFIT = Convert.ToString(reader["PLANPROFIT"]);//
data.CONTRACTNO = Convert.ToString(reader["CONTRACTNO"]);
data.AMSShipper = Convert.ToString(reader["AMSSHIPPER"]).Replace(@"\\\\", "\n").Replace(@"^", "\'").Replace(@"&-add-", "+");
data.AMSConsignee = Convert.ToString(reader["AMSCONSIGNEE"]).Replace(@"\\\\", "\n").Replace(@"^", "\'").Replace(@"&-add-", "+");
data.AMSNotifyparty = Convert.ToString(reader["AMSNOTIFYPARTY"]).Replace(@"\\\\", "\n").Replace(@"^", "\'").Replace(@"&-add-", "+");
data.AGENTID = Convert.ToString(reader["AGENTID"]);//
data.AGENT = Convert.ToString(reader["AGENT"]);//
#endregion
headList.Add(data);
}
reader.Close();
}
return headList;
}
static public MsSeaeOrder GetWebData(string condition)
{
var strSql = new StringBuilder();
strSql.Append("SELECT top 50 BSNO ORDNO,BSNO,BSSTATUS as ORSTATUS,BLTYPE,BSDATE, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='MBLNO' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then MBLNO else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='MBLNO' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS MBLNO, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='SHIPPER' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then SHIPPER else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='SHIPPER' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS SHIPPER, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='CONSIGNEE' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then CONSIGNEE else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='CONSIGNEE' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS CONSIGNEE, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='NOTIFYPARTY' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then NOTIFYPARTY else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='NOTIFYPARTY' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS NOTIFYPARTY, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='VESSEL' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then VESSEL else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='VESSEL' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS VESSEL, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='VOYNO' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then VOYNO else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='VOYNO' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS VOYNO, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='PlACERECEIPT' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then PlACERECEIPT else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='PlACERECEIPT' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS PlACERECEIPT, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='PORTLOAD' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then PORTLOAD else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='PORTLOAD' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS PORTLOAD, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='PORTDISCHARGE' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then PORTDISCHARGE else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='PORTDISCHARGE' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS PORTDISCHARGE, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='PLACEDELIVERY' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then PLACEDELIVERY else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='PLACEDELIVERY' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS PLACEDELIVERY, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='BLFRT' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then BLFRT else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='BLFRT' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS BLFRT, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='SERVICE' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then [SERVICE] else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='SERVICE' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS [SERVICE], ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='MARKS' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then MARKS else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='MARKS' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS MARKS, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='DESCRIPTION' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then [DESCRIPTION] else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='DESCRIPTION' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS [DESCRIPTION], ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='GOODSNAME' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then GOODSNAME else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='GOODSNAME' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS GOODSNAME, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='GROSSWEIGHT' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then GROSSWEIGHT else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='GROSSWEIGHT' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS GROSSWEIGHT, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='MEASUREMENT' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then MEASUREMENT else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='MEASUREMENT' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS MEASUREMENT, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='PKGS' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then PKGS else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='PKGS' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS PKGS, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='KINDPKGS' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then KINDPKGS else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='KINDPKGS' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS KINDPKGS, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='KGS' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then KGS else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='KGS' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS KGS, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='CBM' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then CBM else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='CBM' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS CBM, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='TOTALNO' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then TOTALNO else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='TOTALNO' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS TOTALNO, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='CNTR' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then CNTR else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='CNTR' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS CNTRTOTAL, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='CARGOID' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then CARGOID else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='CARGOID' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS CARGOID, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='DCLASS' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then DCLASS else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='DCLASS' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS DCLASS, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='DUNNO' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then DUNNO else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='DUNNO' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS DUNNO, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='REEFERF' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then REEFERF else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='REEFERF' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS REEFERF, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='TEMPID' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then TEMPID else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='TEMPID' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS TEMPID, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='TEMPSET' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then TEMPSET else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='TEMPSET' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS TEMPSET, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='BOOKINGDESCRIPTION' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then BOOKINGDESCRIPTION else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='BOOKINGDESCRIPTION' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS REMARK, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='DPAGE' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then DPAGE else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='DPAGE' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS DPAGE, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='DLABEL' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then DLABEL else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='DLABEL' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS DLABEL, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='LINKMAN' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then LINKMAN else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='LINKMAN' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS LINKMAN, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='ISSUEWAY' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then ISSUEWAY else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='ISSUEWAY' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS ISSUETYPE, ");
strSql.AppendLine("case when (select COUNT(*) from dbo.BookingCargoSpaceChange where userID != '' and fieldName='BILLNUM' and isContainer=0 and dbo.BookingCargoSpaceChange.BSNO=B.BSNO and del_sign=0)=0 then BILLNUM else (select fieldValue from dbo.BookingCargoSpaceChange where userID != '' and fieldName='BILLNUM' and isContainer=0 and BSNO=B.BSNO and del_sign=0) end AS BILLNUM, ");
strSql.Append("(Select name from Company where companyID=B.companyID) as CUSTOMERNAME, ");
strSql.Append("'网上订舱' ORDTYPE,SHIPPERID,CONSIGNEEID,NOTIFYPARTYID,ETD,PORTLOADID,PORTDISCHARGEID, ");
strSql.Append("PLACEDELIVERYID,DESTINATIONID,DESTINATION,ISSUEDATE,ISSUEPLACE,PREPARDAT,PAYABLEAT,HSCODE,'' AGENTID,'' AGENT, ");//NOBILL,ISSUETYPE,
strSql.Append("NOPKGS,(SELECT userName FROM UserInfo WHERE userID=B.INPUTBY) INPUTBY, ");
strSql.Append("'' INVNO,0 CUSTOMSNUM,STATUS1,STATUS2,STATUS3,STATUS4,STATUS5,0 ISFUMIGATION,TEMPMAX,TEMPMIN, ");
strSql.Append("0 ISSTORAGE,0 ISLAND,0 ISCUSTOMS,0 ISINSPECTION,0 ISBOOKING,0 ISAGENT,0 ISHBLNO, ");
strSql.Append("0 SERVICE9,0 SERVICE10,'' STLNAME,null STLDATE,0 OCEANFEE,0 ISUSD, ");
strSql.Append("0 ISCOMMISSIONBACK,CARRIER,'' CARRIERATTN,'' CARRIERTEL,'' CARRIEREMAIL, ");
strSql.Append("'' FORWARDER,'' FORWARDERATTN,'' FORWARDERTEL,'' FORWARDEREMAIL,'' SALE, ");
strSql.Append("PACKINGTYPE,'' BLTYPE,OP,'' CUSTSERVICE,'' doc, ");
strSql.Append("(SELECT userName FROM UserInfo WHERE userID=B.AUDITOR) AUDITOPERATOR, ");
strSql.Append("'' AUDITDATE, ");
strSql.Append("(Select className from InfoClass where classID=B.BSSTATUS) as ORSTATUSREF , ");
strSql.Append("(select top 1 Remark from BookingCargoSpaceStatus where flowid=B.BSSTATUS and bsno=B.bsno order by subdate desc) ORREASON , ");
strSql.Append("(select mobile from userinfo where userid=inputby) SenderMobile, ");
strSql.Append("(select email from userinfo where userid=inputby) SenderEmail ,CUSTNO, ");
strSql.Append("CONTRACTNO,AMSSHIPPER,AMSCONSIGNEE,AMSNOTIFYPARTY,'' CONFIRMOP,null CONFIRMDATE,'' OPERATOR,'' OPERATORTEL,'0' FBP,'0' DESTFBP,'' MAXWEIGHT,'' PLANPROFIT,'' OPERATOREMAIL ");
strSql.Append(" from BookingCargoSpace B");
if (!string.IsNullOrEmpty(condition))
{
strSql.Append(" where " + condition);
}
var list = SetWebData(strSql, "SHIPPINGBOX");
if (list.Count > 0)
return list[0];
return new MsSeaeOrder();
}
static public List<MsOpSeaeWebOrderCtn> GetWebBodyList(string strCondition)
{
var strSql = new StringBuilder();
/*strSql.AppendLine("if(exists(select * from BookingCargoContainer where " + strCondition + " and del_sign is null)) ");
strSql.AppendLine("begin ");
strSql.AppendLine("select CTN_ID as id,BSNO,CTN,CTNNUM,CNTRNO,SEALNO,PKGS,KGS,CBM,KINDPKGS,[CTN_EXHIBIT] as CTNALL,CTNCODE,SIZE,REMARK ");
strSql.AppendLine("from BookingCargoContainer where " + strCondition + " and (del_sign=0 or del_sign is null) ");
strSql.AppendLine("end ");
strSql.AppendLine("else ");
strSql.AppendLine("begin ");
strSql.AppendLine("select CTN_ID as id,BSNO,CTN,CTNNUM,CNTRNO,SEALNO,PKGS,KGS,CBM,KINDPKGS,[CTN_EXHIBIT] as CTNALL,CTNCODE,SIZE,REMARK ");
strSql.AppendLine("from BookingCargoContainer where " + strCondition + " and (del_sign!=1) ");
strSql.AppendLine("UNION ");
strSql.AppendLine("select distinct A.CTN_ID as id,A.BSNO, ");
strSql.AppendLine("(select B.fieldValue from BookingCargoSpaceChange as B where B.changeID=A.changeID and B.isContainer=1 and B.fieldName='CTN' ) as CTN, ");
strSql.AppendLine("(select B.fieldValue from BookingCargoSpaceChange as B where B.changeID=A.changeID and B.isContainer=1 and B.fieldName='CTNNUM' ) as CTNNUM, ");
strSql.AppendLine("(select B.fieldValue from BookingCargoSpaceChange as B where B.changeID=A.changeID and B.isContainer=1 and B.fieldName='CNTRNO' ) as CNTRNO, ");
strSql.AppendLine("(select B.fieldValue from BookingCargoSpaceChange as B where B.changeID=A.changeID and B.isContainer=1 and B.fieldName='SEALNO' ) as SEALNO, ");
strSql.AppendLine("(select B.fieldValue from BookingCargoSpaceChange as B where B.changeID=A.changeID and B.isContainer=1 and B.fieldName='PKGS' ) as PKGS, ");
strSql.AppendLine("(select B.fieldValue from BookingCargoSpaceChange as B where B.changeID=A.changeID and B.isContainer=1 and B.fieldName='KGS' ) as KGS, ");
strSql.AppendLine("(select B.fieldValue from BookingCargoSpaceChange as B where B.changeID=A.changeID and B.isContainer=1 and B.fieldName='CBM' ) as CBM, ");
strSql.AppendLine("(select B.fieldValue from BookingCargoSpaceChange as B where B.changeID=A.changeID and B.isContainer=1 and B.fieldName='KINDPKGS' ) as KINDPKGS, ");
strSql.AppendLine("(select top 1 C.boxType from BookingCargoSpaceChange as B left join BoxTypeInfo as C on B.fieldValue=C.boxTypeID where B.changeID=A.changeID and B.isContainer=1 and B.fieldName='CTN' and C.del_sign=0 ) as CTNALL, ");
strSql.AppendLine("'' as CTNCODE,'' as SIZE,'' as REMARK ");
strSql.AppendLine("from BookingCargoSpaceChange as A ");
strSql.AppendLine("where A." + strCondition + " and A.del_sign=0 and A.CTN_ID!='' ");
strSql.AppendLine("end ");*/
strSql.AppendLine("if(exists(select * from BookingCargoSpaceChange where " + strCondition + " and isContainer=1 and del_sign=0)) ");
strSql.AppendLine("begin ");
strSql.AppendLine("select distinct A.CTN_ID as id,A.BSNO, ");
strSql.AppendLine("(select B.fieldValue from BookingCargoSpaceChange as B where B.changeID=A.changeID and B.isContainer=1 and B.fieldName='CTN' ) as CTN, ");
strSql.AppendLine("(select B.fieldValue from BookingCargoSpaceChange as B where B.changeID=A.changeID and B.isContainer=1 and B.fieldName='CTNNUM' ) as CTNNUM, ");
strSql.AppendLine("(select B.fieldValue from BookingCargoSpaceChange as B where B.changeID=A.changeID and B.isContainer=1 and B.fieldName='CNTRNO' ) as CNTRNO, ");
strSql.AppendLine("(select B.fieldValue from BookingCargoSpaceChange as B where B.changeID=A.changeID and B.isContainer=1 and B.fieldName='SEALNO' ) as SEALNO, ");
strSql.AppendLine("(select B.fieldValue from BookingCargoSpaceChange as B where B.changeID=A.changeID and B.isContainer=1 and B.fieldName='PKGS' ) as PKGS, ");
strSql.AppendLine("(select B.fieldValue from BookingCargoSpaceChange as B where B.changeID=A.changeID and B.isContainer=1 and B.fieldName='KGS' ) as KGS, ");
strSql.AppendLine("(select B.fieldValue from BookingCargoSpaceChange as B where B.changeID=A.changeID and B.isContainer=1 and B.fieldName='CBM' ) as CBM, ");
strSql.AppendLine("(select B.fieldValue from BookingCargoSpaceChange as B where B.changeID=A.changeID and B.isContainer=1 and B.fieldName='KINDPKGS' ) as KINDPKGS, ");
strSql.AppendLine("(select top 1 C.boxType from BookingCargoSpaceChange as B left join BoxTypeInfo as C on B.fieldValue=C.boxTypeID where B.changeID=A.changeID and B.isContainer=1 and B.fieldName='CTN' and C.del_sign=0 ) as CTNALL, ");
strSql.AppendLine("'' as CTNCODE,'' as SIZE,'' as REMARK ");
strSql.AppendLine("from BookingCargoSpaceChange as A ");
strSql.AppendLine("where A." + strCondition + " and A.del_sign=0 and A.CTN_ID!='' ");
strSql.AppendLine("union ");
strSql.AppendLine("select CTN_ID,BSNO, ");
strSql.AppendLine("CTN,CTNNUM,CNTRNO,SEALNO,PKGS,KGS,CBM,KINDPKGS, ");
strSql.AppendLine("(select top 1 boxType from BoxTypeInfo where boxTypeID=A.CTN) as CTNALL, ");
strSql.AppendLine("'' as CTNCODE,'' as SIZE,'' as REMARK ");
strSql.AppendLine("from BookingCargoContainer as A ");
strSql.AppendLine("where " + strCondition + " and del_sign=0 ");
strSql.AppendLine("UNION ");
strSql.AppendLine("select CTN_ID,BSNO, ");
strSql.AppendLine("CTN,CTNNUM,CNTRNO,SEALNO,PKGS,KGS,CBM,KINDPKGS, ");
strSql.AppendLine("(select top 1 boxType from BoxTypeInfo where boxTypeID=A.CTN) as CTNALL, ");
strSql.AppendLine("'' as CTNCODE,'' as SIZE,'' as REMARK ");
strSql.AppendLine("from BookingCargoContainer as A ");
strSql.AppendLine("where " + strCondition + " and del_sign IS NULL ");
strSql.AppendLine("end");
strSql.AppendLine("else");
strSql.AppendLine("begin ");
strSql.AppendLine("select CTN_ID as id,BSNO,CTN,CTNNUM,CNTRNO,SEALNO,PKGS,KGS,CBM,KINDPKGS, ");
strSql.AppendLine("(select top 1 C.boxType from BoxTypeInfo as C where C.boxTypeID=A.CTN ) as CTNALL,");
strSql.AppendLine("'' as CTNCODE,'' as SIZE,'' as REMARK ");
strSql.AppendLine("from BookingCargoContainer as A where " + strCondition + " and (del_sign=0 or del_sign is null) ");
strSql.AppendLine("end");
return SetWebBodyData(strSql);
}
private static List<MsOpSeaeWebOrderCtn> SetWebBodyData(StringBuilder strSql)
{
var bodyList = new List<MsOpSeaeWebOrderCtn>();
Database db = DatabaseFactory.CreateDatabase("SHIPPINGBOX");
using (IDataReader reader = db.ExecuteReader(CommandType.Text, strSql.ToString()))
{
while (reader.Read())
{
MsOpSeaeWebOrderCtn data = new MsOpSeaeWebOrderCtn();
#region Set DB data to Object
data.CTN_ID = Convert.ToString(reader["id"]);//编号 CTN_ID
data.BSNO = Convert.ToString(reader["BSNO"]);//业务编号
data.CTNCODE = Convert.ToString(reader["CTNCODE"]);//箱型代码
data.SIZE = Convert.ToString(reader["SIZE"]);//尺寸
data.CTN = Convert.ToString(reader["CTN"]);//箱型
data.CTNEXHIBIT = Convert.ToString(reader["CTNALL"]);//箱型
data.CTNALL = Convert.ToString(reader["CTNALL"]);//CTNALL
data.CTNNUM = Convert.ToInt32(reader["CTNNUM"]);//箱量
data.CNTRNO = Convert.ToString(reader["CNTRNO"]);//箱号
data.SEALNO = Convert.ToString(reader["SEALNO"]);//封号
if (reader["PKGS"] != DBNull.Value)
data.PKGS = Convert.ToInt32(reader["PKGS"]);//件数
if (reader["KGS"] != DBNull.Value)
data.KGS = Convert.ToDecimal(reader["KGS"]);//重量(货重)
if (reader["CBM"] != DBNull.Value)
data.CBM = Convert.ToDecimal(reader["CBM"]);//尺码
data.REMARK = Convert.ToString(reader["REMARK"]);//备注
data.KINDPKGS = Convert.ToString(reader["KINDPKGS"]);//包装类型
#endregion
bodyList.Add(data);
}
reader.Close();
}
return bodyList;
}
static public List<MsSeaeOrderStatus> GetOrderStatus(string strCondition)
{
var strSql = new StringBuilder();
strSql.Append("SELECT classID,className from InfoClass where parentID='CI20150711000001' OR parentID='CI_BLC' ");
strSql.Append(" order by classID ");
return SetOrderStatusData(strSql);
}
private static List<MsSeaeOrderStatus> SetOrderStatusData(StringBuilder strSql)
{
var bodyList = new List<MsSeaeOrderStatus>();
Database db = DatabaseFactory.CreateDatabase("SHIPPINGBOX");
using (IDataReader reader = db.ExecuteReader(CommandType.Text, strSql.ToString()))
{
while (reader.Read())
{
MsSeaeOrderStatus data = new MsSeaeOrderStatus();
#region Set DB data to Object
data.STATUS_ID = Convert.ToString(reader["classID"]);//编号
data.STATUSSTR = Convert.ToString(reader["className"]);//业务编号
#endregion
bodyList.Add(data);
}
reader.Close();
}
return bodyList;
}
/*********************************************/
/* */
/*********************************************/
public static DBResult WebAddOrderDetail(string bsno, List<MsOpSeaeWebOrderCtn> orderCtnlist)
{
var result = new DBResult();
Hashtable ht = new Hashtable();
Database db = DatabaseFactory.CreateDatabase();
Database db2=DatabaseFactory.CreateDatabase();
using (var conn = db.CreateConnection())
{
conn.Open();
var tran = conn.BeginTransaction();
try
{
var cmdInsert =
db.GetSqlStringCommand(
@"insert into op_ctn (CTN_ID,BSNO,CTNCODE,[SIZE],CTN,CTNNUM,TEU,CTNALL,CNTRNO,SEALNO,PKGS,KGS,CBM,REMARK,KINDPKGS,TAREWEIGHT,GOODSNAME,CTNSTATUS)
values (@CTN_ID,@BSNO,@CTNCODE,@SIZE,@CTN,@CTNNUM,@TEU,@CTNALL,@CNTRNO,@SEALNO,@PKGS,@KGS,@CBM,@REMARK,@KINDPKGS,@TAREWEIGHT,@GOODSNAME,'F') ");
if (orderCtnlist != null)
{
foreach (var enumValue in orderCtnlist)
{
int SIZE = int.Parse(enumValue.CTNALL.ToString().Trim().Substring(0, 2));
string CTN = enumValue.CTN.ToString().Trim().Substring(2);
int TEU = enumValue.CTNNUM;
int iTEU = int.Parse(enumValue.CTNALL.ToString().Trim().Substring(0, 1));
if (iTEU == 4)
{
TEU = TEU * 2;
}
var feedoid = Guid.NewGuid().ToString();
cmdInsert.Parameters.Clear();
db.AddInParameter(cmdInsert, "@CTN_ID", DbType.String, feedoid);
db.AddInParameter(cmdInsert, "@BSNO", DbType.String, bsno);
db.AddInParameter(cmdInsert, "@CTNCODE", DbType.String, "");
db.AddInParameter(cmdInsert, "@SIZE", DbType.Int16, SIZE);
db.AddInParameter(cmdInsert, "@CTN", DbType.String, CTN);
db.AddInParameter(cmdInsert, "@CTNNUM", DbType.Int16, enumValue.CTNNUM);
db.AddInParameter(cmdInsert, "@TEU", DbType.Int16, TEU);
db.AddInParameter(cmdInsert, "@CTNALL", DbType.String, enumValue.CTNALL);
db.AddInParameter(cmdInsert, "@CNTRNO", DbType.String, "");
db.AddInParameter(cmdInsert, "@SEALNO", DbType.String, "");
db.AddInParameter(cmdInsert, "@PKGS", DbType.Int16,enumValue.PKGS);
db.AddInParameter(cmdInsert, "@KGS", DbType.Decimal, enumValue.KGS);
db.AddInParameter(cmdInsert, "@CBM", DbType.Decimal, enumValue.CBM);
db.AddInParameter(cmdInsert, "@TAREWEIGHT", DbType.Int16, null);
db.AddInParameter(cmdInsert, "@REMARK", DbType.String, "");
db.AddInParameter(cmdInsert, "@KINDPKGS", DbType.String, "");
db.AddInParameter(cmdInsert, "@GOODSNAME", DbType.String, "");
db.ExecuteNonQuery(cmdInsert, tran);
if (!ht.Contains(enumValue.CTNALL))
{
ht.Add(enumValue.CTNALL, enumValue.CTNNUM);
}
}
}
string cntrno = "";
foreach (DictionaryEntry de in ht)
{
cntrno += de.Key.ToString() + "*" + de.Value.ToString() + " ";
}
cntrno = cntrno.Substring(0, cntrno.Length - 1);
var cmdUpdate =
db.GetSqlStringCommand(
@"update op_seae set CNTRTOTAL=@CNTRTOTAL where BSNO=@BSNO ");
cmdUpdate.Parameters.Clear();
db2.AddInParameter(cmdUpdate, "@CNTRTOTAL", DbType.String, cntrno);
db2.AddInParameter(cmdUpdate,"@BSNO",DbType.String,bsno);
db2.ExecuteNonQuery(cmdUpdate, tran);
tran.Commit();
result.Success = true;
result.Message = "保存成功" + result.Message;
return result;
}
catch (Exception)
{
tran.Rollback();
result.Success = false;
result.Message = "保存出现错误,请重试或联系系统管理员";
return result;
}
}
result.Success = true;
result.Message = "保存成功" + result.Message;
return result;
}
public static DBResult AuditWebOrder(string bsno, string mblno, string vessel, string voyno)
{
var result = new DBResult();
Database db = DatabaseFactory.CreateDatabase("SHIPPINGBOX");
using (var conn = db.CreateConnection())
{
conn.Open();
var tran = conn.BeginTransaction();
try
{
var cmdUpdate =
db.GetSqlStringCommand(
@" Update BookingCargoSpace set BookingTYPE=1,bsstatus='CI20150711000006',MBLNO=@MBLNO,VESSEL=@VESSEL,VOYNO=@VOYNO where bsno=@BSNO ");
cmdUpdate.Parameters.Clear();
db.AddInParameter(cmdUpdate, "@BSNO", DbType.String, bsno);
db.AddInParameter(cmdUpdate, "@MBLNO", DbType.String, mblno);
db.AddInParameter(cmdUpdate, "@VESSEL", DbType.String, vessel);
db.AddInParameter(cmdUpdate, "@VOYNO", DbType.String, voyno);
db.ExecuteNonQuery(cmdUpdate, tran);
tran.Commit();
}
catch (Exception)
{
tran.Rollback();
result.Success = false;
result.Message = "保存出现错误,请重试或联系系统管理员";
return result;
}
}
result.Success = true;
result.Message = "保存成功" + result.Message;
return result;
}
internal static DBResult ShenModify(MsOpSeae NewData, MsOpSeae OldData, List<MsOpSeaeDetail> bodyList, List<MsOpSeaeDetail> oldbodyList, string bstype,string bsno, string userid)
{
var result = new DBResult();
Database db = DatabaseFactory.CreateDatabase();
using (var conn = db.CreateConnection())
{
conn.Open();
var tran = conn.BeginTransaction();
try
{
//var cmdUpdateOld =
// db.GetSqlStringCommand(
// @"update op_seae_modify set APPLYSTATUS=0 WHERE BSNO=@BSNO ");
var cmdInsert =
db.GetSqlStringCommand(
@"insert into op_seae_modify ([GID],[APPLYTYPE],[BSTYPE],[REASON],[BSNO] ,CUSTOMERNAME,[MBLNO],[HBLNO],[OP]
,[CUSTSERVICE],[SALE],[CARRIER],[FORWARDER],[TRUCKER],[DOC],[FRCUSTSERVICE]
,[VESSEL],[VOYNO],[YARD],[ETD],[PORTDISCHARGEID],[PORTDISCHARGE],[PLACEDELIVERYID]
,[PLACEDELIVERY],[DESTINATIONID],[DESTINATION],[LANE],ISSUETYPE
,[APPLYID],[APPLYUSER],[APPLYTIME],[APPLYSTATUS])
values (@GID,@APPLYTYPE,@BSTYPE,@REASON,@BSNO ,@CUSTOMERNAME,@MBLNO,@HBLNO,@OP
,@CUSTSERVICE,@SALE,@CARRIER,@FORWARDER,@TRUCKER,@DOC,@FRCUSTSERVICE
,@VESSEL,@VOYNO,@YARD,@ETD,@PORTDISCHARGEID,@PORTDISCHARGE,@PLACEDELIVERYID
,@PLACEDELIVERY,@DESTINATIONID,@DESTINATION,@LANE,@ISSUETYPE
,@APPLYID,@APPLYUSER,@APPLYTIME,@APPLYSTATUS) ");
//var cmdUpdate =
//db.GetSqlStringCommand(
// @"UPDATE CH_FEE SET FEESTATUS=3 WHERE GID=@GID ");
var GROUPID = Guid.NewGuid().ToString();
//cmdUpdateOld.Parameters.Clear();
//db.AddInParameter(cmdUpdateOld, "@BSNO", DbType.String, OldData.BSNO);
//db.ExecuteNonQuery(cmdUpdateOld, tran);
cmdInsert.Parameters.Clear();
db.AddInParameter(cmdInsert, "@GID", DbType.String, GROUPID);
db.AddInParameter(cmdInsert, "@APPLYTYPE", DbType.Int16, 2);
db.AddInParameter(cmdInsert, "@BSTYPE", DbType.String, bstype);
db.AddInParameter(cmdInsert, "@REASON", DbType.String, NewData.REMARK);
db.AddInParameter(cmdInsert, "@BSNO", DbType.String, bsno);
db.AddInParameter(cmdInsert, "@CUSTOMERNAME", DbType.String, NewData.CUSTOMERNAME);
db.AddInParameter(cmdInsert, "@MBLNO", DbType.String, NewData.MBLNO);
db.AddInParameter(cmdInsert, "@HBLNO", DbType.String, NewData.HBLNO);
db.AddInParameter(cmdInsert, "@OP", DbType.String, NewData.OP);
db.AddInParameter(cmdInsert, "@CUSTSERVICE", DbType.String, NewData.CUSTSERVICE);
db.AddInParameter(cmdInsert, "@SALE", DbType.String, NewData.SALE);
db.AddInParameter(cmdInsert, "@CARRIER", DbType.String, NewData.CARRIER);
db.AddInParameter(cmdInsert, "@FORWARDER", DbType.String, NewData.FORWARDER);
db.AddInParameter(cmdInsert, "@TRUCKER", DbType.String, NewData.TRUCKER);
db.AddInParameter(cmdInsert, "@DOC", DbType.String, NewData.DOC);
db.AddInParameter(cmdInsert, "@FRCUSTSERVICE", DbType.String, NewData.FRCUSTSERVICE);
db.AddInParameter(cmdInsert, "@VESSEL", DbType.String, NewData.VESSEL);
db.AddInParameter(cmdInsert, "@VOYNO", DbType.String, NewData.VOYNO);
db.AddInParameter(cmdInsert, "@YARD", DbType.String, NewData.YARD);
db.AddInParameter(cmdInsert, "@ETD", DbType.String, NewData.ETD);
db.AddInParameter(cmdInsert, "@PORTDISCHARGEID", DbType.String, NewData.PORTDISCHARGEID);
db.AddInParameter(cmdInsert, "@PORTDISCHARGE", DbType.String, NewData.PORTDISCHARGE);
db.AddInParameter(cmdInsert, "@PLACEDELIVERYID", DbType.String, NewData.PLACEDELIVERYID);
db.AddInParameter(cmdInsert, "@PLACEDELIVERY", DbType.String, NewData.PLACEDELIVERY);
db.AddInParameter(cmdInsert, "@DESTINATIONID", DbType.String, NewData.DESTINATIONID);
db.AddInParameter(cmdInsert, "@DESTINATION", DbType.String, NewData.DESTINATION);
db.AddInParameter(cmdInsert, "@LANE", DbType.String, NewData.LANE);
db.AddInParameter(cmdInsert, "@ISSUETYPE", DbType.String, NewData.ISSUETYPE);
db.AddInParameter(cmdInsert, "@APPLYID", DbType.String, GROUPID);
db.AddInParameter(cmdInsert, "@APPLYUSER", DbType.String, userid);
db.AddInParameter(cmdInsert, "@APPLYTIME", DbType.String, DateTime.Now.ToString());
db.AddInParameter(cmdInsert, "@APPLYSTATUS", DbType.Int16, 1);
db.ExecuteNonQuery(cmdInsert, tran);
var OLDDATAID = Guid.NewGuid().ToString();
cmdInsert.Parameters.Clear();
db.AddInParameter(cmdInsert, "@GID", DbType.String, OLDDATAID);
db.AddInParameter(cmdInsert, "@APPLYTYPE", DbType.Int16, 1);
db.AddInParameter(cmdInsert, "@BSTYPE", DbType.String, bstype);
db.AddInParameter(cmdInsert, "@REASON", DbType.String, "");
db.AddInParameter(cmdInsert, "@BSNO", DbType.String, bsno);
db.AddInParameter(cmdInsert, "@CUSTOMERNAME", DbType.String, OldData.CUSTOMERNAME);
db.AddInParameter(cmdInsert, "@MBLNO", DbType.String, OldData.MBLNO);
db.AddInParameter(cmdInsert, "@HBLNO", DbType.String, OldData.HBLNO);
db.AddInParameter(cmdInsert, "@OP", DbType.String, OldData.OP);
db.AddInParameter(cmdInsert, "@CUSTSERVICE", DbType.String, OldData.CUSTSERVICE);
db.AddInParameter(cmdInsert, "@SALE", DbType.String, OldData.SALE);
db.AddInParameter(cmdInsert, "@CARRIER", DbType.String, OldData.CARRIER);
db.AddInParameter(cmdInsert, "@FORWARDER", DbType.String, OldData.FORWARDER);
db.AddInParameter(cmdInsert, "@TRUCKER", DbType.String, OldData.TRUCKER);
db.AddInParameter(cmdInsert, "@DOC", DbType.String, OldData.DOC);
db.AddInParameter(cmdInsert, "@FRCUSTSERVICE", DbType.String, OldData.FRCUSTSERVICE);
db.AddInParameter(cmdInsert, "@VESSEL", DbType.String, OldData.VESSEL);
db.AddInParameter(cmdInsert, "@VOYNO", DbType.String, OldData.VOYNO);
db.AddInParameter(cmdInsert, "@YARD", DbType.String, OldData.YARD);
db.AddInParameter(cmdInsert, "@ETD", DbType.String, OldData.ETD);
db.AddInParameter(cmdInsert, "@PORTDISCHARGEID", DbType.String, OldData.PORTDISCHARGEID);
db.AddInParameter(cmdInsert, "@PORTDISCHARGE", DbType.String, OldData.PORTDISCHARGE);
db.AddInParameter(cmdInsert, "@PLACEDELIVERYID", DbType.String, OldData.PLACEDELIVERYID);
db.AddInParameter(cmdInsert, "@PLACEDELIVERY", DbType.String, OldData.PLACEDELIVERY);
db.AddInParameter(cmdInsert, "@DESTINATIONID", DbType.String, OldData.DESTINATIONID);
db.AddInParameter(cmdInsert, "@DESTINATION", DbType.String, OldData.DESTINATION);
db.AddInParameter(cmdInsert, "@LANE", DbType.String, OldData.LANE);
db.AddInParameter(cmdInsert, "@ISSUETYPE", DbType.String, OldData.ISSUETYPE);
db.AddInParameter(cmdInsert, "@APPLYID", DbType.String, GROUPID);
db.AddInParameter(cmdInsert, "@APPLYUSER", DbType.String, userid);
db.AddInParameter(cmdInsert, "@APPLYTIME", DbType.String, DateTime.Now.ToString());
db.AddInParameter(cmdInsert, "@APPLYSTATUS", DbType.Int16, 1);
db.ExecuteNonQuery(cmdInsert, tran);
if (bodyList != null)
{
//var StrSerialNo = "('1000'";
foreach (var enumValue in bodyList)
{
var SIZE = enumValue.CTNALL.ToString().Trim().Substring(0, 2);
string CTN = enumValue.CTNALL.ToString().Trim().Substring(2);
int TEU = enumValue.CTNNUM;
var iTEU = enumValue.CTNALL.ToString().Trim().Substring(0, 1);
if (iTEU == "4")
{
TEU = TEU * 2;
}
else if (iTEU == "L")
{
TEU = 0;
}
if (enumValue.TRUCKFEE == "") enumValue.TRUCKFEE = "0";
if (enumValue.FREESTORAGEDAY == "") enumValue.FREESTORAGEDAY = "0";
if (enumValue.STORAGEDAY == "") enumValue.STORAGEDAY = "0";
if (enumValue.STORAGEPRICE == "") enumValue.STORAGEPRICE = "0";
if (enumValue.STORAGEFEE == "") enumValue.STORAGEFEE = "0";
if (enumValue.FREECTNDAY == "") enumValue.FREECTNDAY = "0";
if (enumValue.CTNDAY == "") enumValue.CTNDAY = "0";
if (enumValue.CTNPRICE == "") enumValue.CTNPRICE = "0";
if (enumValue.CTNFEE == "") enumValue.CTNFEE = "0";
var cmdInsertCtn = db.GetSqlStringCommand(@"insert into op_ctn_modify (GID,APPLYTYPE,MODIFYID,CTN_ID,BSNO,CTNCODE,[SIZE],CTN,CTNNUM,TEU,CTNALL,CNTRNO,SEALNO,PKGS,KGS,CBM,REMARK,KINDPKGS,TAREWEIGHT,GOODSNAME,CTNSTATUS,MASTERNO,WEIGHTYPE,WEIGHKGS,WEIGHATTN,WEIGHTEL,WEIGHSIGN,WEIGHDATE,TRUCKER,TRUCKFEE,FREESTORAGEDAY,STORAGEDAY,STORAGEPRICE,STORAGEFEE,
FREECTNDAY,CTNDAY,CTNPRICE,CTNFEE,TRUCKNO,VGMCONNCOM,VGMADDR,VGMEMAIL) values (NEWID(),2,'"+GROUPID+"','" + enumValue.CTN_ID
+ "','" + enumValue.BSNO + "','" + enumValue.CTNCODE + "','" + SIZE + "','" + CTN + "'," + enumValue.CTNNUM + "," + TEU + ",'" + enumValue.CTNALL + "','" + enumValue.CNTRNO + "','" + enumValue.SEALNO + "','" + enumValue.PKGS + "'," + enumValue.KGS + "," + enumValue.CBM + ",'" + enumValue.REMARK + "','" + enumValue.KINDPKGS + "'," + enumValue.TAREWEIGHT + ",'','"
+ enumValue.CTNSTATUS + "','" + enumValue.MASTERNO + "','" + enumValue.WEIGHTYPE + "'," + enumValue.WEIGHKGS + ",'" + enumValue.WEIGHATTN + "','" + enumValue.WEIGHTEL + "','" + enumValue.WEIGHSIGN + "','" + enumValue.WEIGHDATE + "','" + enumValue.TRUCKER + "'," + enumValue.TRUCKFEE
+ "," + enumValue.FREESTORAGEDAY + "," + enumValue.STORAGEDAY + "," + enumValue.STORAGEPRICE + "," + enumValue.STORAGEFEE + "," + enumValue.FREECTNDAY + "," + enumValue.CTNDAY + "," + enumValue.CTNPRICE + "," + enumValue.CTNFEE + ",'" + enumValue.TRUCKNO + "','" + enumValue.VGMCONNCOM + "','" + enumValue.VGMADDR + "','" + enumValue.VGMEMAIL + "')");
db.ExecuteNonQuery(cmdInsertCtn, tran);
}
}
if (oldbodyList != null)
{
//var StrSerialNo = "('1000'";
foreach (var enumValue in oldbodyList)
{
var SIZE = enumValue.CTNALL.ToString().Trim().Substring(0, 2);
string CTN = enumValue.CTNALL.ToString().Trim().Substring(2);
int TEU = enumValue.CTNNUM;
var iTEU = enumValue.CTNALL.ToString().Trim().Substring(0, 1);
if (iTEU == "4")
{
TEU = TEU * 2;
}
else if (iTEU == "L")
{
TEU = 0;
}
if (enumValue.TRUCKFEE == "") enumValue.TRUCKFEE = "0";
if (enumValue.FREESTORAGEDAY == "") enumValue.FREESTORAGEDAY = "0";
if (enumValue.STORAGEDAY == "") enumValue.STORAGEDAY = "0";
if (enumValue.STORAGEPRICE == "") enumValue.STORAGEPRICE = "0";
if (enumValue.STORAGEFEE == "") enumValue.STORAGEFEE = "0";
if (enumValue.FREECTNDAY == "") enumValue.FREECTNDAY = "0";
if (enumValue.CTNDAY == "") enumValue.CTNDAY = "0";
if (enumValue.CTNPRICE == "") enumValue.CTNPRICE = "0";
if (enumValue.CTNFEE == "") enumValue.CTNFEE = "0";
var cmdInsertCtn = db.GetSqlStringCommand(@"insert into op_ctn_modify (GID,APPLYTYPE,MODIFYID,CTN_ID,BSNO,CTNCODE,[SIZE],CTN,CTNNUM,TEU,CTNALL,CNTRNO,SEALNO,PKGS,KGS,CBM,REMARK,KINDPKGS,TAREWEIGHT,GOODSNAME,CTNSTATUS,MASTERNO,WEIGHTYPE,WEIGHKGS,WEIGHATTN,WEIGHTEL,WEIGHSIGN,WEIGHDATE,TRUCKER,TRUCKFEE,FREESTORAGEDAY,STORAGEDAY,STORAGEPRICE,STORAGEFEE,
FREECTNDAY,CTNDAY,CTNPRICE,CTNFEE,TRUCKNO,VGMCONNCOM,VGMADDR,VGMEMAIL) values (NEWID(),1,'" + OLDDATAID + "','" + enumValue.CTN_ID
+ "','" + enumValue.BSNO + "','" + enumValue.CTNCODE + "','" + SIZE + "','" + CTN + "'," + enumValue.CTNNUM + "," + TEU + ",'" + enumValue.CTNALL + "','" + enumValue.CNTRNO + "','" + enumValue.SEALNO + "','" + enumValue.PKGS + "'," + enumValue.KGS + "," + enumValue.CBM + ",'" + enumValue.REMARK + "','" + enumValue.KINDPKGS + "'," + enumValue.TAREWEIGHT + ",'','"
+ enumValue.CTNSTATUS + "','" + enumValue.MASTERNO + "','" + enumValue.WEIGHTYPE + "'," + enumValue.WEIGHKGS + ",'" + enumValue.WEIGHATTN + "','" + enumValue.WEIGHTEL + "','" + enumValue.WEIGHSIGN + "','" + enumValue.WEIGHDATE + "','" + enumValue.TRUCKER + "'," + enumValue.TRUCKFEE
+ "," + enumValue.FREESTORAGEDAY + "," + enumValue.STORAGEDAY + "," + enumValue.STORAGEPRICE + "," + enumValue.STORAGEFEE + "," + enumValue.FREECTNDAY + "," + enumValue.CTNDAY + "," + enumValue.CTNPRICE + "," + enumValue.CTNFEE + ",'" + enumValue.TRUCKNO + "','" + enumValue.VGMCONNCOM + "','" + enumValue.VGMADDR + "','" + enumValue.VGMEMAIL + "')");
db.ExecuteNonQuery(cmdInsertCtn, tran);
}
}
//Resultmb WorkResult = WorkFlowDAL.WorkFlowStart(WorkFlowName, NewFee.GId, saleid, mblno, OldFee.BsNo, "");
//if (WorkResult.Success == true)
//{
// cmdUpdate.Parameters.Clear();
// db.AddInParameter(cmdUpdate, "@GID", DbType.String, NewFee.GId);
// db.ExecuteNonQuery(cmdUpdate, tran);
// if (WorkResult.islast == true)
// {
// var cmdupdate = db.GetSqlStringCommand(@"update ch_fee set FEENAME=a.FEENAME,CUSTOMERNAME=a.CUSTOMERNAME,UNIT=a.UNIT,UNITPRICE=a.UNITPRICE,
// QUANTITY=a.QUANTITY,AMOUNT=a.AMOUNT,CURRENCY=a.CURRENCY,EXCHANGERATE=a.EXCHANGERATE,REASON=a.REASON,REMARK=a.REMARK,
// TAXRATE=a.TAXRATE,NOTAXAMOUNT=a.NOTAXAMOUNT,ACCTAXRATE=a.ACCTAXRATE,TAXUNITPRICE=a.TAXUNITPRICE,MANAGER=a.MANAGER,FEESTATUS=0
// from ch_fee left join ch_fee_modify a on (a.FEEID=ch_fee.GID and a.APPLYSTATUS=1 AND a.APPLYTYPE=2 ) where ch_fee.GID=@GID");
// db.AddInParameter(cmdupdate, "@GID", DbType.String, NewFee.GId);
// db.ExecuteNonQuery(cmdupdate, tran);
// var cmdupdateModify = db.GetSqlStringCommand("update ch_fee_modify set applystatus=2,audituser=@audituser,audittime=@audittime where FEEID=@GID and applystatus=1");
// cmdupdateModify.Parameters.Clear();
// db.AddInParameter(cmdupdateModify, "@GID", DbType.String, NewFee.GId);
// db.AddInParameter(cmdupdateModify, "@audituser", DbType.String, userid);
// db.AddInParameter(cmdupdateModify, "@audittime", DbType.Date, DateTime.Now);
// db.ExecuteNonQuery(cmdupdateModify, tran);
// }
//}
//else
//{
// tran.Rollback();
// result.Success = false;
// result.Message = "申请修改出现错误,请重试或联系系统管理员";
// return result;
//}
//}
result = new DBResult();
result.Success = true;
result.Message = "申请修改成功";
tran.Commit();
}
catch (Exception)
{
tran.Rollback();
result.Success = false;
result.Message = "申请修改出现错误,请重试或联系系统管理员";
return result;
}
}
result.Success = true;
result.Message = "申请修改成功";
return result;
}
internal static DBResult AuditModifyList(List<MsSeaeModify> NewDataList, string userid)
{
var result = new DBResult();
var SALEORDERDEPTBYOP= MsSysParamSetDAL.GetData("PARAMNAME='SALEORDERDEPTBYOP'").PARAMVALUE;
Database db = DatabaseFactory.CreateDatabase();
using (var conn = db.CreateConnection())
{
conn.Open();
var tran = conn.BeginTransaction();
try
{
if (NewDataList != null)
{
foreach (var NewData in NewDataList)
{
var MsOpSeae = MsOpSeaeDAL.MsOpSeaeDAL.GetData("BSNO='" + NewData.BSNO + "'");
if (MsOpSeae.CUSTNO != "")
{
var strSql = new StringBuilder();
if (NewData.MBLNO != MsOpSeae.MBLNO && NewData.MBLNO != null)
strSql.Append(",MBLNO='" + NewData.MBLNO + "'");
if (NewData.SALE != MsOpSeae.SALE && NewData.SALE != null)
strSql.Append(",SALE='" + NewData.SALE + "'");
if (NewData.OP != MsOpSeae.OP && NewData.OP != null)
{
strSql.Append(",OP='" + NewData.OP + "'");
if (SALEORDERDEPTBYOP=="1") strSql.Append(",SALEDEPT=(SELECT TOP 1 DEPTNAME FROM VW_user WHERE SHOWNAME='" + NewData.OP + "') ");
}
if (NewData.CUSTSERVICE != MsOpSeae.CUSTSERVICE && NewData.CUSTSERVICE != null)
strSql.Append(",CUSTSERVICE='" + NewData.CUSTSERVICE + "'");
if (NewData.DOC != MsOpSeae.DOC && NewData.DOC != null)
strSql.Append(",DOC='" + NewData.DOC + "'");
if (NewData.CUSTOMERNAME != MsOpSeae.CUSTOMERNAME && NewData.CUSTOMERNAME != null)
strSql.Append(",CUSTOMERNAME='" + NewData.CUSTOMERNAME + "'");
if (NewData.CARRIER != MsOpSeae.CARRIER && NewData.CARRIER != null)
strSql.Append(",CARRIER='" + NewData.CARRIER + "'");
if (NewData.FORWARDER != MsOpSeae.FORWARDER && NewData.FORWARDER != null)
strSql.Append(",FORWARDER='" + NewData.FORWARDER + "'");
if (NewData.ETD != MsOpSeae.ETD && NewData.ETD != null)
strSql.Append(",ETD='" + NewData.ETD + "'");
if (NewData.PORTDISCHARGE != MsOpSeae.PORTDISCHARGE && NewData.PORTDISCHARGE != null)
strSql.Append(",PORTDISCHARGE='" + NewData.PORTDISCHARGE + "'");
if (NewData.DESTINATION != MsOpSeae.DESTINATION && NewData.DESTINATION != null)
strSql.Append(",DESTINATION='" + NewData.DESTINATION + "'");
if (NewData.PLACEDELIVERY != MsOpSeae.PLACEDELIVERY && NewData.PLACEDELIVERY != null)
strSql.Append(",PLACEDELIVERY='" + NewData.PLACEDELIVERY + "'");
if (NewData.LANE != MsOpSeae.LANE && NewData.LANE != null)
strSql.Append(",LANE='" + NewData.LANE + "'");
if (NewData.ISSUETYPE != MsOpSeae.ISSUETYPE && NewData.ISSUETYPE != null)
strSql.Append(",ISSUETYPE='" + NewData.ISSUETYPE + "'");
if (NewData.YARD != MsOpSeae.YARD && NewData.YARD != null)
strSql.Append(",YARD='" + NewData.YARD + "'");
if (NewData.VESSEL != MsOpSeae.VESSEL && NewData.VESSEL != null)
strSql.Append(",VESSEL='" + NewData.VESSEL + "'");
if (NewData.VOYNO != MsOpSeae.VOYNO && NewData.VOYNO != null)
strSql.Append(",VOYNO='" + NewData.VOYNO + "'");
if (strSql.ToString() != "")
{
strSql.Append(" where BSNO='" + NewData.BSNO + "' ");
var cmdupdate =
db.GetSqlStringCommand("update op_seae set bsno=bsno" + strSql.ToString());
db.ExecuteNonQuery(cmdupdate, tran);
var cmdupdate2 =
db.GetSqlStringCommand("update crm_seaeorder set bsno=bsno" + strSql.ToString());
db.ExecuteNonQuery(cmdupdate2, tran);
var cmdupdate3 =
db.GetSqlStringCommand("update op_seae_modify set APPLYSTATUS=0,AUDITUSER='" + userid + "',AUDITTIME=GETDATE() where APPLYID='" + NewData.APPLYID + "'");
db.ExecuteNonQuery(cmdupdate3, tran);
}
var cmddeleteCtn =
db.GetSqlStringCommand("delete from op_ctn where BSNO='"+NewData.BSNO+"'");
db.ExecuteNonQuery(cmddeleteCtn, tran);
var cmdInsertCtn = db.GetSqlStringCommand(@"insert into op_ctn (CTN_ID,BSNO,CTNCODE,[SIZE],CTN,CTNNUM,TEU,CTNALL,CNTRNO,SEALNO,PKGS,KGS,CBM,REMARK,KINDPKGS,TAREWEIGHT,GOODSNAME,CTNSTATUS,MASTERNO,WEIGHTYPE,WEIGHKGS,WEIGHATTN,WEIGHTEL,WEIGHSIGN,WEIGHDATE,TRUCKER,TRUCKFEE,FREESTORAGEDAY,STORAGEDAY,STORAGEPRICE,STORAGEFEE,
FREECTNDAY,CTNDAY,CTNPRICE,CTNFEE,TRUCKNO,VGMCONNCOM,VGMADDR,VGMEMAIL) SELECT CTN_ID,BSNO,CTNCODE,[SIZE],CTN,CTNNUM,TEU,CTNALL,CNTRNO,SEALNO,PKGS,KGS,CBM,REMARK,KINDPKGS,TAREWEIGHT,GOODSNAME,CTNSTATUS,MASTERNO,WEIGHTYPE,WEIGHKGS,WEIGHATTN,WEIGHTEL,WEIGHSIGN,WEIGHDATE,TRUCKER,TRUCKFEE,FREESTORAGEDAY,STORAGEDAY,STORAGEPRICE,STORAGEFEE,
FREECTNDAY,CTNDAY,CTNPRICE,CTNFEE,TRUCKNO,VGMCONNCOM,VGMADDR,VGMEMAIL FROM op_ctn_modify where APPLYTYPE=2 AND MODIFYID='"+NewData.GID+"'");
db.ExecuteNonQuery(cmdInsertCtn, tran);
var cmddeleteorderCtn =
db.GetSqlStringCommand("delete from crm_seaeorderctn where ORDNO in (select ORDNO from crm_seaeorder where BSNO='" + NewData.BSNO + "')");
db.ExecuteNonQuery(cmddeleteorderCtn, tran);
var cmdInsertorderCtn = db.GetSqlStringCommand(@"insert into crm_seaeorderctn (CTN_ID,ORDNO,CTNALL,CTNNUM)
SELECT NEWID(),(select TOP 1 ORDNO from crm_seaeorder where BSNO='" + NewData.BSNO + "'),CTNALL,SUM(CTNNUM) FROM op_ctn_modify where APPLYTYPE=2 AND MODIFYID='" + NewData.GID + "' GROUP BY CTNALL");
db.ExecuteNonQuery(cmdInsertorderCtn, tran);
}
}
tran.Commit();
}
}
catch (Exception e)
{
tran.Rollback();
result.Success = false;
result.Message = "修改出现错误,请重试或联系系统管理员"+e.Message;
return result;
}
}
result.Success = true;
result.Message = "申请修改成功";
return result;
}
public static DBResult AuditBackModifyList(List<MsSeaeModify> NewDataList,string reason, string userid)
{
var result = new DBResult();
Database db = DatabaseFactory.CreateDatabase();
using (var conn = db.CreateConnection())
{
conn.Open();
var tran = conn.BeginTransaction();
try
{
if (NewDataList != null)
{
foreach (var NewData in NewDataList)
{
var cmdupdate3 =
db.GetSqlStringCommand("update op_seae_modify set APPLYSTATUS=4,AUDITREMARK='"+reason+"',AUDITUSER='" + userid + "',AUDITTIME=GETDATE() where APPLYID='" + NewData.APPLYID + "'");
db.ExecuteNonQuery(cmdupdate3, tran);
}
}
tran.Commit();
}
catch (Exception)
{
tran.Rollback();
result.Success = false;
result.Message = "驳回出现错误,请重试或联系系统管理员";
return result;
}
}
result.Success = true;
result.Message = "驳回成功";
return result;
}
public static DBResult AuditBackWebOrder(string bsno,string reason)
{
var result = new DBResult();
Database db = DatabaseFactory.CreateDatabase("SHIPPINGBOX");
using (var conn = db.CreateConnection())
{
conn.Open();
var tran = conn.BeginTransaction();
try
{
var cmdUpdate =
db.GetSqlStringCommand( //驳回 05
@" Update BookingCargoSpace set bsstatus='CI20150711000005' where bsno=@BSNO "
+ " Insert into BookingCargoSpaceStatus (BSNO,FLowType,FlowID,Remark,subdate,del_sign) values("
+ " @BSNO3,'CI20150711000001','CI20150711000005',@PendingReason,getdate(),0) ");
cmdUpdate.Parameters.Clear();
db.AddInParameter(cmdUpdate, "@BSNO", DbType.String, bsno);
db.AddInParameter(cmdUpdate, "@BSNO3", DbType.String, bsno);
db.AddInParameter(cmdUpdate, "@PendingReason", DbType.String, reason);
db.ExecuteNonQuery(cmdUpdate, tran);
tran.Commit();
}
catch (Exception)
{
tran.Rollback();
result.Success = false;
result.Message = "保存出现错误,请重试或联系系统管理员";
return result;
}
}
result.Success = true;
result.Message = "保存成功" + result.Message;
return result;
}
/*static private bool IsNotEqual(string strCondition)
{
bool _equal = false;
var ordercontainer = GetWebBodyList(strCondition);
var opcontainer = MsOpSeaeDAL.MsOpSeaeDAL.GetBodyList(strCondition);
if (ordercontainer[1].ToString() != opcontainer[1].ToString())
{
_equal = true;
}
if (ordercontainer[2].ToString() != opcontainer[4].ToString())
{
_equal = true;
}
if (ordercontainer[3].ToString() != opcontainer[5].ToString())
{
_equal = true;
}
if (ordercontainer[4].ToString() != opcontainer[8].ToString())
{
_equal = true;
}
if (ordercontainer[5].ToString() != opcontainer[9].ToString())
{
_equal = true;
}
if (ordercontainer[6].ToString() != opcontainer[10].ToString())
{
_equal = true;
}
if (ordercontainer[7].ToString() != opcontainer[11].ToString())
{
_equal = true;
}
if (ordercontainer[8].ToString() != opcontainer[12].ToString())
{
_equal = true;
}
if (ordercontainer[9].ToString() != opcontainer[14].ToString())
{
_equal = true;
}
return _equal;
}*/
static public MsSeaeOrderBill GetWebBillData(string strCondition, string sort = null)
{
var orderbill = GetWebData(strCondition);
var opbill = MsOpSeaeDAL.MsOpSeaeDAL.GetData(strCondition);
MsSeaeOrderBill data = new MsSeaeOrderBill();
data.ORDNO = orderbill.ORDNO;//委托
data.BSNO = orderbill.BSNO;//业务编号
//data.BSSOURCE = orderbill.BSSOURCE;
data.ORSTATUS =orderbill.ORSTATUS;//
data.ORSTATUSREF =orderbill.ORSTATUSREF;//
data.ORREASON =orderbill.ORREASON;//分提单号
data.BSDATE = orderbill.BSDATE;//接单日期
data.MBLNO = orderbill.MBLNO;//主提单号
data.CUSTNO =orderbill.CUSTNO;//主提单号
data.CUSTOMERNAME =orderbill.CUSTOMERNAME;//委托单位
data.ORDTYPE =orderbill.ORDTYPE;//业务状态
data.SHIPPER =orderbill.SHIPPER; //发货人内容
data.CONSIGNEE =orderbill.CONSIGNEE;//收货人内容
data.NOTIFYPARTY =orderbill.NOTIFYPARTY;//通知人内容
data.VESSEL = orderbill.VESSEL;//船名
data.VOYNO = orderbill.VOYNO;//航次
data.ETD = orderbill.ETD;//到港日期
data.PORTLOADID = orderbill.PORTLOADID;//装货港代码
data.PORTLOAD = orderbill.PORTLOAD;//装货港
data.PORTDISCHARGEID = orderbill.PORTDISCHARGEID;//卸货港代码
data.PORTDISCHARGE = orderbill.PORTDISCHARGE.Replace("^", "'");//卸货港
data.PLACERECEIPT = orderbill.PLACERECEIPT.Replace("^", "'");//收货地
data.PLACEDELIVERYID = orderbill.PLACEDELIVERYID;//交货地代码
data.PLACEDELIVERY = orderbill.PLACEDELIVERY.Replace("^", "'");//交货地
data.DESTINATIONID = orderbill.DESTINATIONID;//目的地代码
data.DESTINATION = orderbill.DESTINATION.Replace("^", "'");//目的地
data.NOBILL = orderbill.NOBILL;//提单份数
data.ISSUETYPE =orderbill.ISSUETYPE;//签单方式
data.ISSUEDATE =orderbill.ISSUEDATE;//预抵日期
data.ISSUEPLACE =orderbill.ISSUEPLACE;//签单地点
data.BLFRT =orderbill.BLFRT;//付费方式
data.PREPARDAT =orderbill.PREPARDAT;//预付地点
data.PAYABLEAT =orderbill.PAYABLEAT;//到付地点
data.SERVICE =orderbill.SERVICE;//运输条款
data.MARKS = orderbill.MARKS.Replace("^", "'");//唛头
data.NOPKGS =orderbill.NOPKGS;//件数包装
data.DESCRIPTION =orderbill.DESCRIPTION.Replace("^","'");//货物描述
data.GOODSNAME =orderbill.GOODSNAME;//品名
data.GROSSWEIGHT =orderbill.GROSSWEIGHT;//货物毛重
data.MEASUREMENT =orderbill.MEASUREMENT;//货物尺码
data.PKGS = Convert.ToDecimal(orderbill.PKGS);//件数
data.KINDPKGS =orderbill.KINDPKGS;//件数包装
data.KGS =Convert.ToDecimal(orderbill.KGS);//毛重
data.CBM =Convert.ToDecimal( orderbill.CBM);//立方数/尺码
data.TOTALNO =orderbill.TOTALNO;//件数大写
data.CNTRTOTAL = orderbill.CNTRTOTAL;//集装箱全部内容
data.INPUTBY =orderbill.INPUTBY;//录入人
data.OPERATORTEL = orderbill.OPERATORTEL;//录入人
data.OPERATOREMAIL =orderbill.OPERATOREMAIL;//录入人
data.CARGOID =orderbill.CARGOID;//货物标识
data.HSCODE = orderbill.HSCODE;
data.DCLASS =orderbill.DCLASS;//危险品分类/等级
data.DUNNO =orderbill.DUNNO;//危险品编号
data.DPAGE =orderbill.DPAGE;//危险品页号
data.DLABEL =orderbill.DLABEL;//危险品标签
data.LINKMAN =orderbill.LINKMAN;//危险品联系人
data.REEFERF = orderbill.REEFERF;//冷藏通风量
data.TEMPID = orderbill.TEMPID;//温度单位
data.TEMPSET = orderbill.TEMPSET;//设置温度
data.TEMPMAX =orderbill.TEMPMAX;//最高温度
data.TEMPMIN =orderbill.TEMPMIN;//最低温度
data.REMARK = orderbill.REMARK;//备注
data.BLTYPE =orderbill.BLTYPE;//装运方式
data.OP =orderbill.OP;//操作员
data.CUSTSERVICE = orderbill.CUSTSERVICE;//客服员
data.DOC =orderbill.DOC;//单证
data.AUDITOPERATOR =orderbill.AUDITDATE;//审核人
data.AUDITDATE =orderbill.AUDITDATE;//审核日期
data.OPERATORTEL =orderbill.OPERATORTEL;//
data.OPERATOREMAIL =orderbill.OPERATOREMAIL;//
if (orderbill.SHIPPER != opbill.SHIPPER)
data.UPSHIPPER = true;
data.ASSHIPPER = opbill.SHIPPER;
if (orderbill.CONSIGNEE != opbill.CONSIGNEE)
data.UPCONSIGNEE = true;
data.ASCONSIGNEE = opbill.CONSIGNEE;
if (orderbill.NOTIFYPARTY != opbill.NOTIFYPARTY)
data.UPNOTIFYPARTY = true;
data.ASNOTIFYPARTY = opbill.NOTIFYPARTY;
if (orderbill.VESSEL != opbill.VESSEL)
data.UPVESSEL= true;
data.ASVESSEL = opbill.VESSEL;
if (orderbill.VOYNO != opbill.VOYNO)
data.UPVOYNO = true;
data.ASVOYNO = opbill.VOYNO;
if (orderbill.PORTLOAD != opbill.PORTLOAD)
data.UPPORTLOAD = true;
data.ASPORTLOAD= opbill.PORTLOAD;
if (orderbill.PORTDISCHARGE != opbill.PORTDISCHARGE)
data.UPPORTDISCHARGE = true;
data.ASPORTDISCHARGE = opbill.PORTDISCHARGE;
if (orderbill.PLACEDELIVERY != opbill.PLACEDELIVERY)
data.UPPLACEDELIVERY = true;
data.ASPLACEDELIVERY = opbill.PLACEDELIVERY;
if (orderbill.DESTINATION != opbill.DESTINATION)
data.UPDESTINATION = true;
data.ASDESTINATION = opbill.DESTINATION;
if (orderbill.PKGS != opbill.PKGS)
data.UPPKGS = true;
data.ASPKGS =Convert.ToString(opbill.PKGS);
if (orderbill.KINDPKGS != opbill.KINDPKGS)
data.UPKINDPKGS = true;
data.ASKINDPKGS = Convert.ToString(opbill.KINDPKGS);
if (orderbill.KGS != opbill.KGS)
data.UPKGS = true;
data.ASKGS = Convert.ToString(opbill.KGS);
if (orderbill.CBM!= opbill.CBM)
data.UPCBM = true;
data.ASCBM = Convert.ToString(opbill.CBM);
if (orderbill.TOTALNO != opbill.TOTALNO)
data.UPTOTALNO = true;
data.ASTOTALNO = opbill.TOTALNO;
if (orderbill.MARKS != opbill.MARKS)
data.UPMARKS = true;
data.ASMARKS = opbill.MARKS;
if (orderbill.DESCRIPTION != opbill.DESCRIPTION)
data.UPDESCRIPTION = true;
data.ASDESCRIPTION = opbill.DESCRIPTION;
if (orderbill.SERVICE != opbill.SERVICE)
data.UPSERVICE = true;
data.ASSERVICE = opbill.SERVICE;
if (orderbill.CARGOID != opbill.CARGOID)
data.UPCARGOID = true;
data.ASCARGOID = opbill.CARGOID;
if (orderbill.HSCODE != opbill.HSCODE)
data.UPHSCODE = true;
data.ASHSCODE = opbill.HSCODE;
if (orderbill.DCLASS != opbill.DCLASS)
data.UPDCLASS = true;
data.ASDCLASS = opbill.DCLASS;
if (orderbill.DUNNO != opbill.DUNNO)
data.UPDUNNO = true;
data.ASDUNNO = opbill.DUNNO;
if (orderbill.DPAGE != opbill.DPAGE)
data.UPDPAGE = true;
data.ASDPAGE = opbill.DPAGE;
if (orderbill.DLABEL != opbill.DLABEL)
data.UPDLABEL = true;
data.ASDLABEL = opbill.DLABEL;
if (orderbill.LINKMAN != opbill.LINKMAN)
data.UPLINKMAN = true;
data.ASLINKMAN = opbill.LINKMAN;
if (orderbill.REEFERF != opbill.REEFERF)
data.UPREEFERF = true;
data.ASREEFERF = opbill.REEFERF;
if (orderbill.TEMPID != opbill.TEMPID)
data.UPTEMPID = true;
data.ASTEMPID = opbill.TEMPID;
if (orderbill.TEMPSET != opbill.TEMPSET)
data.UPTEMPSET = true;
data.ASTEMPSET = opbill.TEMPSET;
if (orderbill.TEMPMAX != opbill.TEMPMAX)
data.UPTEMPMAX = true;
data.ASTEMPMAX = opbill.TEMPMAX;
if (orderbill.TEMPMIN != opbill.TEMPMIN)
data.UPTEMPMIN = true;
data.ASTEMPMIN = opbill.TEMPMIN;
if (orderbill.BLFRT != opbill.BLFRT)
data.UPBLFRT = true;
data.ASBLFRT = opbill.BLFRT;
if (orderbill.PREPARDAT != opbill.PREPARDAT)
data.UPPREPARDAT = true;
data.ASPREPARDAT = opbill.PREPARDAT;
if (orderbill.PAYABLEAT != opbill.PAYABLEAT)
data.UPPAYABLEAT = true;
data.ASPAYABLEAT = opbill.PAYABLEAT;
if (orderbill.ISSUETYPE != opbill.ISSUETYPE)
data.UPISSUETYPE = true;
data.ASISSUETYPE = opbill.ISSUETYPE;
if (orderbill.ISSUEDATE != opbill.ISSUEDATE)
data.UPISSUEDATE = true;
data.ASISSUEDATE = opbill.ISSUEDATE;
if (orderbill.ISSUEPLACE != opbill.ISSUEPLACE)
data.UPISSUEPLACE = true;
data.ASISSUEPLACE = opbill.ISSUEPLACE;
data.UPCTN = true;
return data;
}
public static DBResult WebAddOrderBillDetail(string bsno, List<MsOpSeaeWebOrderCtn> orderCtnlist)
{
var result = new DBResult();
Database db = DatabaseFactory.CreateDatabase();
using (var conn = db.CreateConnection())
{
conn.Open();
var tran = conn.BeginTransaction();
try
{
var cmdDelete =
db.GetSqlStringCommand(
@" delete from op_ctn where BSNO=@BSNO ");
cmdDelete.Parameters.Clear();
db.AddInParameter(cmdDelete, "@BSNO", DbType.String, bsno);
db.ExecuteNonQuery(cmdDelete, tran);
var cmdInsert =
db.GetSqlStringCommand(
@"insert into op_ctn (CTN_ID,BSNO,CTNCODE,[SIZE],CTN,CTNNUM,TEU,CTNALL,CNTRNO,SEALNO,PKGS,KGS,CBM,REMARK,KINDPKGS,TAREWEIGHT,GOODSNAME,CTNSTATUS)
values (@CTN_ID,@BSNO,@CTNCODE,@SIZE,@CTN,@CTNNUM,@TEU,@CTNALL,@CNTRNO,@SEALNO,@PKGS,@KGS,@CBM,@REMARK,@KINDPKGS,@TAREWEIGHT,@GOODSNAME,'F') ");
if (orderCtnlist != null)
{
foreach (var enumValue in orderCtnlist)
{
int SIZE = int.Parse(enumValue.CTN.ToString().Trim().Substring(0, 2));
string CTN = enumValue.CTNALL.ToString().Trim().Substring(2);
int TEU = enumValue.CTNNUM;
int iTEU = int.Parse(enumValue.CTN.ToString().Trim().Substring(0, 1));
if (iTEU == 4)
{
TEU = TEU * 2;
}
var feedoid = Guid.NewGuid().ToString();
cmdInsert.Parameters.Clear();
db.AddInParameter(cmdInsert, "@CTN_ID", DbType.String, feedoid);
db.AddInParameter(cmdInsert, "@BSNO", DbType.String, bsno);
db.AddInParameter(cmdInsert, "@CTNCODE", DbType.String, "");
db.AddInParameter(cmdInsert, "@SIZE", DbType.Int16, SIZE);
db.AddInParameter(cmdInsert, "@CTN", DbType.String, CTN);
db.AddInParameter(cmdInsert, "@CTNNUM", DbType.Int16, enumValue.CTNNUM);
db.AddInParameter(cmdInsert, "@TEU", DbType.Int16, TEU);
db.AddInParameter(cmdInsert, "@CTNALL", DbType.String, enumValue.CTNALL);
db.AddInParameter(cmdInsert, "@CNTRNO", DbType.String, enumValue.CNTRNO);
db.AddInParameter(cmdInsert, "@SEALNO", DbType.String,enumValue.SEALNO);
db.AddInParameter(cmdInsert, "@PKGS", DbType.Int16, enumValue.PKGS);
db.AddInParameter(cmdInsert, "@KGS", DbType.Decimal, enumValue.KGS);
db.AddInParameter(cmdInsert, "@CBM", DbType.Decimal, enumValue.CBM);
db.AddInParameter(cmdInsert, "@TAREWEIGHT", DbType.Int16, null);
db.AddInParameter(cmdInsert, "@REMARK", DbType.String, enumValue.REMARK);
db.AddInParameter(cmdInsert, "@KINDPKGS", DbType.String, enumValue.KINDPKGS);
db.AddInParameter(cmdInsert, "@GOODSNAME", DbType.String, "");
db.ExecuteNonQuery(cmdInsert, tran);
}
}
tran.Commit();
result.Success = true;
result.Message = "保存成功" + result.Message;
return result;
}
catch (Exception)
{
tran.Rollback();
result.Success = false;
result.Message = "保存出现错误,请重试或联系系统管理员";
return result;
}
}
result.Success = true;
result.Message = "保存成功" + result.Message;
return result;
}
public static DBResult AuditWebOrderBill(string bsno,string mblno)
{
var result = new DBResult();
Database db = DatabaseFactory.CreateDatabase("SHIPPINGBOX");
using (var conn = db.CreateConnection())
{
conn.Open();
var tran = conn.BeginTransaction();
try
{
var cmdUPD =
db.GetSqlStringCommand(
@" Update BookingCargoSpaceStatus set FlowID='CI_BLC_Rec' where bsno=@BSNO and FlowType='CI_BLC'
Update BookingCargoSpace set BSSTATUS='CI_BLC_Rec' where bsno=@BSNO2 and BSSTATUS='CI_BLC_Send'
");
cmdUPD.Parameters.Clear();
db.AddInParameter(cmdUPD, "@BSNO", DbType.String, bsno);
db.AddInParameter(cmdUPD, "@BSNO2", DbType.String, bsno);
db.ExecuteNonQuery(cmdUPD, tran);
tran.Commit();
}
catch (Exception)
{
tran.Rollback();
result.Success = false;
result.Message = "保存出现错误,请重试或联系系统管理员";
//return result;
}
}
Database db2 = DatabaseFactory.CreateDatabase();
using (var conn2 = db2.CreateConnection())
{
conn2.Open();
var tran2 = conn2.BeginTransaction();
try
{
var cmd2 =
db2.GetSqlStringCommand(
@" update op_seae set MBLNO=@MBLNO where BSNO=@BSNO ");
cmd2.Parameters.Clear();
db2.AddInParameter(cmd2, "@BSNO", DbType.String, bsno);
db2.AddInParameter(cmd2, "@MBLNO", DbType.String, mblno);
db2.ExecuteNonQuery(cmd2, tran2);
tran2.Commit();
result.Success = true;
result.Message = "保存成功" + result.Message;
//return result;
}
catch (Exception)
{
tran2.Rollback();
result.Success = false;
result.Message = "保存出现错误,请重试或联系系统管理员";
//return result;
}
}
result.Success = true;
result.Message = "保存成功" + result.Message;
return result;
}
public static DBResult AuditBackWebOrderBill(string bsno, string reason)
{
var result = new DBResult();
Database db = DatabaseFactory.CreateDatabase("SHIPPINGBOX");
using (var conn = db.CreateConnection())
{
conn.Open();
var tran = conn.BeginTransaction();
try
{
var cmdUpdate =
db.GetSqlStringCommand(
@" Insert into BookingCargoSpaceStatus (BSNO,FLowType,FlowID,Remark,subdate,del_sign) values(@BSNO,'CI20150711000001','CI20150711000005',@PendingReason,getdate(),0)"
+ "Update BookingCargoSpace set BSSTATUS='CI_BLC_Refuse' where bsno=@BSNO2");// and FlowType='CI_BLC'
cmdUpdate.Parameters.Clear();
db.AddInParameter(cmdUpdate, "@BSNO", DbType.String, bsno);
db.AddInParameter(cmdUpdate, "@BSNO2", DbType.String, bsno);
db.AddInParameter(cmdUpdate, "@PendingReason", DbType.String, reason);
db.ExecuteNonQuery(cmdUpdate, tran);
tran.Commit();
}
catch (Exception)
{
tran.Rollback();
result.Success = false;
result.Message = "保存出现错误,请重试或联系系统管理员";
return result;
}
}
result.Success = true;
result.Message = "保存成功" + result.Message;
return result;
}
#endregion
public static void SendMailLocalhost(string MailType, MsSeaeOrder Opseae, string ORREASON)
{
System.Net.Mail.MailMessage msg = new System.Net.Mail.MailMessage();
//首先获取发件人 发件公司 发件邮箱(委托方) // 收件人 收件公司 收件邮箱(承运方)
var strSql = new StringBuilder();
strSql.Append(" select case AUDITOR WHEN '' then ");
strSql.Append(" (select email from userinfo where userid in (select userid from login where companyID=FORWARDER) and departmentID='CompanyMaster') ");
strSql.Append(" else (select email from userinfo where userid=AUDITOR) end ReceiverEmail ");
strSql.Append(" ,case AUDITOR WHEN '' then ");
strSql.Append(" (select username from userinfo where userid in (select userid from login where companyID=FORWARDER) and departmentID='CompanyMaster') ");
strSql.Append(" else (select username from userinfo where userid=AUDITOR) end Receivername ");
strSql.Append(" ,u.username sendername,u.email senderEmail ");
strSql.Append(" ,(select fullname from company where companyid=bcs.forwarder) receiverCompany ");
strSql.Append(" ,(select fullname from company where companyid=bcs.companyid) sendercompany ");
strSql.Append(" ,(select Mobile from userinfo where userid=bcs.inputby) senderMobile ");
strSql.Append(" ,(select Mobile from userinfo where userid=bcs.Auditor) receiverMobile ");
strSql.Append(" ,bcs.* ");
strSql.Append(" from BookingCargoSpace bcs ");
strSql.Append(" left join userinfo U on u.userid = bcs.inputby ");
strSql.Append(" where bsno='" + Opseae.BSNO + "' ");
DataSet ds = new DataSet();
Database db = DatabaseFactory.CreateDatabase("SHIPPINGBOX");
var SenderName = "";
var SenderEmail = "";
var SenderCompany = "";
var SenderMobile = "";
var ReceiverName = "";
var ReceiverEmail = "";
var ReceiverCompany = "";
var ReceiverMobile = "";
var EmailText = new StringBuilder();
var EmailTitle = new StringBuilder();
try
{
using (IDataReader reader = db.ExecuteReader(CommandType.Text, strSql.ToString()))
{
while (reader.Read())
{
SenderName = Convert.ToString(reader["SenderName"]);
SenderEmail = Convert.ToString(reader["SenderEmail"]);
SenderCompany = Convert.ToString(reader["SenderCompany"]);
SenderMobile = Convert.ToString(reader["SenderMobile"]);
ReceiverName = Convert.ToString(reader["ReceiverName"]);
ReceiverEmail = Convert.ToString(reader["ReceiverEmail"]);
ReceiverCompany = Convert.ToString(reader["ReceiverCompany"]);
ReceiverMobile = Convert.ToString(reader["ReceiverMobile"]);
EmailTitle.Clear();
EmailTitle.Append("");
}
reader.Close();
}
}
catch (Exception)
{
}
finally
{
}
if (MailType == "拒绝订舱" || MailType == "待定" || MailType == "拒绝提单确认")
{
msg.To.Add(SenderEmail);
msg.From = new MailAddress(ReceiverEmail, ReceiverName, System.Text.Encoding.UTF8);
}
else
{
msg.To.Add(ReceiverEmail);
msg.From = new MailAddress(SenderEmail, SenderName, System.Text.Encoding.UTF8);
}
/* 上面3个参数分别是发件人地址可以随便写发件人姓名编码*/
var Subject = "";
var Body = new StringBuilder();
if (MailType == "拒绝订舱")
{
Subject = " 拒绝订舱提醒:From " + ReceiverCompany;
if (Opseae.ETD != "")
Subject = Subject + " 船期" + Opseae.ETD;
if (Opseae.CNTRTOTAL != "")
Subject = Subject + " 箱型箱量" + Opseae.CNTRTOTAL;
if (Opseae.DESTINATION != "")
Subject = Subject + " 目的地" + Opseae.DESTINATION;
Body.Append("<html> <Body>");
Body.Append("<br />您好您通过ShippingBox所订业务被拒绝理由如下<br />" + REHH(ORREASON));
Body.Append("<br />订舱代理公司:" + ReceiverCompany);
Body.Append("<br />操作人:" + ReceiverName + "&nbsp;&nbsp;&nbsp;电话:" + ReceiverMobile + "&nbsp;&nbsp;&nbsp;邮箱:" + ReceiverEmail);
if (Opseae.CNTRTOTAL != "")
Body.Append("<br />箱型箱量:" + Opseae.CNTRTOTAL);
if (Opseae.ETD != "")
Body.Append("<br />船期:" + Opseae.ETD);
if (Opseae.DESTINATION != "")
Body.Append("<br />目的地:" + Opseae.DESTINATION);
if (Opseae.REMARK != "")
Body.Append("<br />订舱说明:" + Opseae.REMARK);
}
if (MailType == "拒绝提单确认")
{
Subject = " 拒绝提单确认:From " + ReceiverCompany;
if (Opseae.ETD != "")
Subject = Subject + " 船期" + Opseae.ETD;
if (Opseae.CNTRTOTAL != "")
Subject = Subject + " 箱型箱量" + Opseae.CNTRTOTAL;
if (Opseae.DESTINATION != "")
Subject = Subject + " 目的地" + Opseae.DESTINATION;
Body.Append("<html> <Body>");
Body.Append("<br />您好您通过ShippingBox所提交提单确认被拒绝理由如下<br />" + REHH(ORREASON));
Body.Append("<br />订舱代理公司:" + ReceiverCompany);
Body.Append("<br />操作人:" + ReceiverName + "&nbsp;&nbsp;&nbsp;电话:" + ReceiverMobile + "&nbsp;&nbsp;&nbsp;邮箱:" + ReceiverEmail);
if (Opseae.CNTRTOTAL != "")
Body.Append("<br />箱型箱量:" + Opseae.CNTRTOTAL);
if (Opseae.ETD != "")
Body.Append("<br />船期:" + Opseae.ETD);
if (Opseae.DESTINATION != "")
Body.Append("<br />目的地:" + Opseae.DESTINATION);
if (Opseae.REMARK != "")
Body.Append("<br />订舱说明:" + Opseae.REMARK);
}
//Body = SetBottom(Body, Opseae.BSNO);
msg.Subject = Subject;//邮件标题
msg.SubjectEncoding = System.Text.Encoding.UTF8;//邮件标题编码
msg.Body = Body.ToString();//邮件内容
msg.BodyEncoding = System.Text.Encoding.UTF8;//邮件内容编码
msg.IsBodyHtml = true;//是否是HTML邮件
msg.Priority = MailPriority.High;//邮件优先级
var content = "";
AlternateView htmlBody = AlternateView.CreateAlternateViewFromString(content, null, "text/html");
/*
LinkedResource lrImage = new LinkedResource(@"D:\DSWebservice\a.jpg", "image/gif");
lrImage.ContentId = "Email001";
htmlBody.LinkedResources.Add(lrImage);
msg.AlternateViews.Add(htmlBody);*/
SmtpClient client = new SmtpClient();
client.Credentials = new System.Net.NetworkCredential("admin@dongshengsoft.com", "ds!@#)(*");
//在71info.com注册的邮箱和密码
client.Host = "smtpcom.263xmail.com";
client.EnableSsl = false;
client.Port = 465;
object userState = msg;
var Result = "";
try
{
//client.SendAsync(msg, userState);
//简单一点儿可以
client.Send(msg);
//MessageBox.Show("发送成功");
}
catch (System.Net.Mail.SmtpException ex)
{
Result = ex.Message;
}
}
public static string REHH(string str)
{
var _s = "";
if (!string.IsNullOrEmpty(str))
{
_s = str.Replace("\n", "<br />");
}
return _s;
}
public static void SetCtnInfo(ref MsSeaeOrder headData, List<MsSeaeOrderCtn> bodyList) {
var cntr = "";
var teu = 0M;
if (bodyList != null)
{
foreach (var enumValue in bodyList)
{
if (cntr != "") cntr += " / ";
cntr = cntr + enumValue.CTNALL + '*' + enumValue.CTNNUM + "";
if (enumValue.CTNALL.IndexOf("20") >= 0) {
teu += 1 * enumValue.CTNNUM;
}
if (enumValue.CTNALL.IndexOf("40") >= 0 || enumValue.CTNALL.IndexOf("45") >= 0)
{
teu += 2 * enumValue.CTNNUM;
}
}
}
headData.CNTRTOTAL = cntr;
headData.TEU = teu;
}
//public static StringBuilder SetBottom(StringBuilder Body, string BSNO)
//{
// Body.Append("<br />ShippingBoxNO." + BSNO);
// Body.Append("<br /> **********本邮件由<a href=http://www.shippingbox.cc style=\"color:blue;\">ShippingBox订舱平台</a>自动发送 *************");
// Body.Append("<br />本邮件仅提供当前货物部分摘要信息,详情请以双方约定为准!");
// Body.Append("<br /> <img src=\"http://123.57.17.72:8027/images/public/logo01.png\" />");
// Body.Append(" </Body></html>");
// Body.Append("<br /> <a href=http://www.shippingbox.cc style=\"color:blue;\">www.shippingbox.cc</a>");
// return Body;
//}
#region 权限范围
public static string GetRangDAStr(string tb, string userid, string username, string companyid)
{
//20220714 改为 tb=audit时 审核人或确认订舱人等于本人的业务
string str = "";
var strSql = new StringBuilder();
strSql.Append("SELECT ");
strSql.Append(" VISIBLERANGE,OPERATERANGE,AUTHORITYID,VSSQL ");
strSql.Append(" from VW_User_Authority ");
if (tb == "audit")
{
//strSql.Append(" where [NAME]='modSeaeOrderAudit' and USERID='" + userid + "' and ISDELETE=0");
str=" (AUDITOPERATOR='" + username + "' OR AUDITOPERATOR2='" + username + "' )";
return str;
}
else
{
strSql.Append(" where [NAME]='modSeaeOrderList' and USERID='" + userid + "' and ISDELETE=0");
}
string visiblerange = "4";
string operaterange = "4";
string AUTHORITYID = "";
string VSSQL = "";
Database db = DatabaseFactory.CreateDatabase();
using (IDataReader reader = db.ExecuteReader(CommandType.Text, strSql.ToString()))
{
while (reader.Read())
{
visiblerange = Convert.ToString(reader["VISIBLERANGE"]);
operaterange = Convert.ToString(reader["OPERATERANGE"]);
AUTHORITYID = Convert.ToString(reader["AUTHORITYID"]);
VSSQL = Convert.ToString(reader["VSSQL"]);
break;
}
reader.Close();
}
if (visiblerange == "4")
{
str = "1=2";
}
else if (visiblerange == "3")
{
str = " (OP='" + username + "' OR SALE='" + username + "' or CUSTSERVICE='" + username + "' or DOC='" + username + "' or INPUTBY='" + username + "')";
}
else if (visiblerange == "5")
{
var userstr = new StringBuilder();
userstr.Append(" select SHOWNAME from VW_user where COMPANYID in (select COMPANYID from user_authority_range_company where userid='" + userid + "' and AUTHORITYID='" + AUTHORITYID + "' and VISIBLERANGE=1)");
Database userdb = DatabaseFactory.CreateDatabase();
using (IDataReader reader = userdb.ExecuteReader(CommandType.Text, userstr.ToString()))
{
str = "";
while (reader.Read())
{
if (str == "")
{
str = " (OP='" + Convert.ToString(reader["SHOWNAME"]) + "' OR SALE='" + Convert.ToString(reader["SHOWNAME"]) + "' OR CUSTSERVICE='" + Convert.ToString(reader["SHOWNAME"]) + "' OR DOC='" + Convert.ToString(reader["SHOWNAME"]) + "' OR INPUTBY='" + Convert.ToString(reader["SHOWNAME"]) + "' ";
}
else
{
str = str + " or OP='" + Convert.ToString(reader["SHOWNAME"]) + "' OR SALE='" + Convert.ToString(reader["SHOWNAME"]) + "' OR CUSTSERVICE='" + Convert.ToString(reader["SHOWNAME"]) + "' OR DOC='" + Convert.ToString(reader["SHOWNAME"]) + "' OR INPUTBY='" + Convert.ToString(reader["SHOWNAME"]) + "' ";
};
}
str = str + ")";
reader.Close();
}
}
else if (visiblerange == "6")
{
var userstr = new StringBuilder();
userstr.Append(" select OPID,(select SHOWNAME from [user] where GID=user_authority_range_op.OPID) SHOWNAME from user_authority_range_op where userid='" + userid + "' and AUTHORITYID='" + AUTHORITYID + "' and VISIBLERANGE=1");
Database userdb = DatabaseFactory.CreateDatabase();
using (IDataReader reader = userdb.ExecuteReader(CommandType.Text, userstr.ToString()))
{
str = "";
while (reader.Read())
{
if (str == "")
{
str = " (OP='" + Convert.ToString(reader["SHOWNAME"]) + "' OR SALE='" + Convert.ToString(reader["SHOWNAME"]) + "' OR CUSTSERVICE='" + Convert.ToString(reader["SHOWNAME"]) + "' OR DOC='" + Convert.ToString(reader["SHOWNAME"]) + "' OR INPUTBY='" + Convert.ToString(reader["SHOWNAME"]) + "' ";
}
else
{
str = str + " or OP='" + Convert.ToString(reader["SHOWNAME"]) + "' OR SALE='" + Convert.ToString(reader["SHOWNAME"]) + "' OR CUSTSERVICE='" + Convert.ToString(reader["SHOWNAME"]) + "' OR DOC='" + Convert.ToString(reader["SHOWNAME"]) + "' OR INPUTBY='" + Convert.ToString(reader["SHOWNAME"]) + "' ";
};
}
str = str + ")";
reader.Close();
}
}
else if (visiblerange == "2")
{
var rangeDa = new RangeDA();
var deptname = rangeDa.GetDEPTNAME(userid);
var userstr = new StringBuilder();
userstr.Append(" select SHOWNAME from [user] where GID in (select USERID from user_company where COMPANYID='" + companyid + "') and GID in (select userid from user_baseinfo where DEPTNAME='" + deptname + "')");
Database userdb = DatabaseFactory.CreateDatabase();
using (IDataReader reader = userdb.ExecuteReader(CommandType.Text, userstr.ToString()))
{
str = "";
while (reader.Read())
{
if (str == "")
{
str = " (OP='" + Convert.ToString(reader["SHOWNAME"]) + "' OR SALE='" + Convert.ToString(reader["SHOWNAME"]) + "' OR CUSTSERVICE='" + Convert.ToString(reader["SHOWNAME"]) + "' OR DOC='" + Convert.ToString(reader["SHOWNAME"]) + "' OR INPUTBY='" + Convert.ToString(reader["SHOWNAME"]) + "' ";
}
else
{
str = str + " or OP='" + Convert.ToString(reader["SHOWNAME"]) + "' OR SALE='" + Convert.ToString(reader["SHOWNAME"]) + "' OR CUSTSERVICE='" + Convert.ToString(reader["SHOWNAME"]) + "' OR DOC='" + Convert.ToString(reader["SHOWNAME"]) + "' OR INPUTBY='" + Convert.ToString(reader["SHOWNAME"]) + "' ";
};
}
str = str + ")";
reader.Close();
}
}
else if (visiblerange == "1")
{
var rangeDa = new RangeDA();
var userstr = new StringBuilder();
userstr.Append(" select SHOWNAME from [user] where GID in (select USERID from user_company where COMPANYID='" + companyid + "') ");
Database userdb = DatabaseFactory.CreateDatabase();
using (IDataReader reader = userdb.ExecuteReader(CommandType.Text, userstr.ToString()))
{
str = "";
while (reader.Read())
{
if (str == "")
{
str = " (OP='" + Convert.ToString(reader["SHOWNAME"]) + "' OR SALE='" + Convert.ToString(reader["SHOWNAME"]) + "' OR CUSTSERVICE='" + Convert.ToString(reader["SHOWNAME"]) + "' OR DOC='" + Convert.ToString(reader["SHOWNAME"]) + "' OR INPUTBY='" + Convert.ToString(reader["SHOWNAME"]) + "' ";
}
else
{
str = str + " or OP='" + Convert.ToString(reader["SHOWNAME"]) + "' OR SALE='" + Convert.ToString(reader["SHOWNAME"]) + "' OR CUSTSERVICE='" + Convert.ToString(reader["SHOWNAME"]) + "' OR DOC='" + Convert.ToString(reader["SHOWNAME"]) + "' OR INPUTBY='" + Convert.ToString(reader["SHOWNAME"]) + "'";
};
}
str = str + ")";
reader.Close();
}
}
VSSQL = VSSQL.Trim();
if (!string.IsNullOrEmpty(VSSQL))
{
if (!string.IsNullOrEmpty(str))
{
str = str + " and (" + VSSQL + ") ";
}
else
{
str = " (" + VSSQL + ") ";
}
}
return str;
}
public static string GetModifyRangDAStr(string userid, string username, string companyid)
{
string str = "";
var strSql = new StringBuilder();
strSql.Append("SELECT ");
strSql.Append(" VISIBLERANGE,OPERATERANGE,AUTHORITYID,VSSQL ");
strSql.Append(" from VW_User_Authority ");
strSql.Append(" where [NAME]='modSeaeModifyList' and USERID='" + userid + "' and ISDELETE=0");
string visiblerange = "4";
string operaterange = "4";
string AUTHORITYID = "";
string VSSQL = "";
Database db = DatabaseFactory.CreateDatabase();
using (IDataReader reader = db.ExecuteReader(CommandType.Text, strSql.ToString()))
{
while (reader.Read())
{
visiblerange = Convert.ToString(reader["VISIBLERANGE"]);
operaterange = Convert.ToString(reader["OPERATERANGE"]);
AUTHORITYID = Convert.ToString(reader["AUTHORITYID"]);
VSSQL = Convert.ToString(reader["VSSQL"]);
break;
}
reader.Close();
}
if (visiblerange == "4")
{
str = "1=2";
}
else if (visiblerange == "3")
{
str = " APPLYUSER='" + userid + "' ";
}
else if (visiblerange == "5")
{
var userstr = new StringBuilder();
userstr.Append(" select userid from VW_user where COMPANYID in (select COMPANYID from user_authority_range_company where userid='" + userid + "' and AUTHORITYID='" + AUTHORITYID + "' and VISIBLERANGE=1)");
Database userdb = DatabaseFactory.CreateDatabase();
using (IDataReader reader = userdb.ExecuteReader(CommandType.Text, userstr.ToString()))
{
str = "";
while (reader.Read())
{
if (str == "")
{
str = " (APPLYUSER='" + Convert.ToString(reader["userid"]) + "' ";
}
else
{
str = str + " or APPLYUSER='" + Convert.ToString(reader["userid"]) + "' ";
};
}
str = str + ")";
reader.Close();
}
}
else if (visiblerange == "6")
{
var userstr = new StringBuilder();
userstr.Append(" select OPID,(select SHOWNAME from [user] where GID=user_authority_range_op.OPID) SHOWNAME from user_authority_range_op where userid='" + userid + "' and AUTHORITYID='" + AUTHORITYID + "' and VISIBLERANGE=1");
Database userdb = DatabaseFactory.CreateDatabase();
using (IDataReader reader = userdb.ExecuteReader(CommandType.Text, userstr.ToString()))
{
str = "";
while (reader.Read())
{
if (str == "")
{
str = " (APPLYUSER='" + Convert.ToString(reader["OPID"]) + "' ";
}
else
{
str = str + " or APPLYUSER='" + Convert.ToString(reader["OPID"]) + "' ";
};
}
str = str + ")";
reader.Close();
}
}
else if (visiblerange == "2")
{
var rangeDa = new RangeDA();
var deptname = rangeDa.GetDEPTNAME(userid);
var userstr = new StringBuilder();
userstr.Append(" select GID from [user] where GID in (select USERID from user_company where COMPANYID='" + companyid + "') and GID in (select userid from user_baseinfo where DEPTNAME='" + deptname + "')");
Database userdb = DatabaseFactory.CreateDatabase();
using (IDataReader reader = userdb.ExecuteReader(CommandType.Text, userstr.ToString()))
{
str = "";
while (reader.Read())
{
if (str == "")
{
str = " (APPLYUSER='" + Convert.ToString(reader["GID"]) + "' ";
}
else
{
str = str + " or APPLYUSER='" + Convert.ToString(reader["GID"]) + "'";
};
}
str = str + ")";
reader.Close();
}
}
else if (visiblerange == "1")
{
var rangeDa = new RangeDA();
var userstr = new StringBuilder();
userstr.Append(" select USERID from user_company where COMPANYID='" + companyid + "' ");
Database userdb = DatabaseFactory.CreateDatabase();
using (IDataReader reader = userdb.ExecuteReader(CommandType.Text, userstr.ToString()))
{
str = "";
while (reader.Read())
{
if (str == "")
{
str = " (APPLYUSER='" + Convert.ToString(reader["USERID"]) + "'";
}
else
{
str = str + " or APPLYUSER='" + Convert.ToString(reader["USERID"]) + "' ";
};
}
str = str + ")";
reader.Close();
}
}
VSSQL = VSSQL.Trim();
if (!string.IsNullOrEmpty(VSSQL))
{
if (!string.IsNullOrEmpty(str))
{
str = str + " and (" + VSSQL + ") ";
}
else
{
str = " (" + VSSQL + ") ";
}
}
return str;
}
#endregion
}
}