/// <summary>
        /// 更新一条数据
        /// </summary>
        public void Update(XH_CapitalAccountFreezeTableInfo model, ReckoningTransaction tm)
        {
            StringBuilder strSql = new StringBuilder();

            strSql.Append("update XH_CapitalAccountFreezeTable set ");
            strSql.Append("FreezeTime=@FreezeTime,");
            strSql.Append("FreezeCapitalAmount=@FreezeCapitalAmount,");
            strSql.Append("ThawTime=@ThawTime,");
            strSql.Append("FreezeTypeLogo=@FreezeTypeLogo,");
            strSql.Append("EntrustNumber=@EntrustNumber,");
            strSql.Append("CapitalAccountLogo=@CapitalAccountLogo,");
            strSql.Append("OweCosting=@OweCosting,");
            strSql.Append("FreezeCost=@FreezeCost");
            strSql.Append(" where CapitalFreezeLogoId=@CapitalFreezeLogoId ");
            Database  db        = tm.Database;
            DbCommand dbCommand = db.GetSqlStringCommand(strSql.ToString());

            db.AddInParameter(dbCommand, "FreezeTime", DbType.DateTime, model.FreezeTime);
            db.AddInParameter(dbCommand, "FreezeCapitalAmount", DbType.Decimal, model.FreezeCapitalAmount);
            db.AddInParameter(dbCommand, "CapitalFreezeLogoId", DbType.Int32, model.CapitalFreezeLogoId);
            db.AddInParameter(dbCommand, "ThawTime", DbType.DateTime, model.ThawTime);
            db.AddInParameter(dbCommand, "FreezeTypeLogo", DbType.Int32, model.FreezeTypeLogo);
            db.AddInParameter(dbCommand, "EntrustNumber", DbType.AnsiString, model.EntrustNumber);
            db.AddInParameter(dbCommand, "CapitalAccountLogo", DbType.Int32, model.CapitalAccountLogo);
            db.AddInParameter(dbCommand, "OweCosting", DbType.Decimal, model.OweCosting);
            db.AddInParameter(dbCommand, "FreezeCost", DbType.Decimal, model.FreezeCost);
            db.ExecuteNonQuery(dbCommand, tm.Transaction);
        }
        /// <summary>
        /// 增加一条数据
        /// </summary>
        public bool AddRecord(XH_CapitalAccountFreezeTableInfo model, Database db, DbTransaction transaction)
        {
            StringBuilder strSql = new StringBuilder();

            strSql.Append("insert into XH_CapitalAccountFreezeTable(");
            strSql.Append(
                "FreezeTime,FreezeCapitalAmount,ThawTime,FreezeTypeLogo,EntrustNumber,CapitalAccountLogo,OweCosting,FreezeCost)");

            strSql.Append(" values (");
            strSql.Append(
                "@FreezeTime,@FreezeCapitalAmount,@ThawTime,@FreezeTypeLogo,@EntrustNumber,@CapitalAccountLogo,@OweCosting,@FreezeCost)");
            strSql.Append(";select @@IDENTITY");
            DbCommand dbCommand = db.GetSqlStringCommand(strSql.ToString());

            db.AddInParameter(dbCommand, "FreezeTime", DbType.DateTime, model.FreezeTime);
            db.AddInParameter(dbCommand, "FreezeCapitalAmount", DbType.Decimal, model.FreezeCapitalAmount);
            db.AddInParameter(dbCommand, "ThawTime", DbType.DateTime, model.ThawTime);
            db.AddInParameter(dbCommand, "FreezeTypeLogo", DbType.Int32, model.FreezeTypeLogo);
            db.AddInParameter(dbCommand, "EntrustNumber", DbType.AnsiString, model.EntrustNumber);
            db.AddInParameter(dbCommand, "CapitalAccountLogo", DbType.Int32, model.CapitalAccountLogo);
            db.AddInParameter(dbCommand, "OweCosting", DbType.Decimal, model.OweCosting);
            db.AddInParameter(dbCommand, "FreezeCost", DbType.Decimal, model.FreezeCost);
            int    result;
            object obj = db.ExecuteScalar(dbCommand, transaction);

            if (!int.TryParse(obj.ToString(), out result))
            {
                return(false);
            }

            model.CapitalFreezeLogoId = result;
            return(true);
        }
Beispiel #3
0
        /// <summary>
        /// 插入一条空的资金冻结记录
        /// </summary>
        /// <param name="capitalAccountId"></param>
        /// <param name="entrustNumber"></param>
        /// <returns></returns>
        public static int InsertNullCapitalFreeze(int capitalAccountId, string entrustNumber)
        {
            XH_CapitalAccountFreezeTableInfo caf = new XH_CapitalAccountFreezeTableInfo();

            caf.CapitalAccountLogo  = capitalAccountId;
            caf.EntrustNumber       = entrustNumber;
            caf.FreezeTypeLogo      = (int)Types.FreezeType.DelegateFreeze;
            caf.FreezeTime          = DateTime.Now;
            caf.FreezeCapitalAmount = 0;
            caf.FreezeCost          = 0;

            XH_CapitalAccountFreezeTableDal dal = new XH_CapitalAccountFreezeTableDal();

            return(dal.Add(caf));
        }
        /// <summary>
        /// 对象实体绑定数据
        /// </summary>
        public XH_CapitalAccountFreezeTableInfo ReaderBind(IDataReader dataReader)
        {
            XH_CapitalAccountFreezeTableInfo model = new XH_CapitalAccountFreezeTableInfo();
            object ojb;

            ojb = dataReader["FreezeTime"];
            if (ojb != null && ojb != DBNull.Value)
            {
                model.FreezeTime = (DateTime)ojb;
            }
            ojb = dataReader["FreezeCapitalAmount"];
            if (ojb != null && ojb != DBNull.Value)
            {
                model.FreezeCapitalAmount = (decimal)ojb;
            }
            ojb = dataReader["CapitalFreezeLogoId"];
            if (ojb != null && ojb != DBNull.Value)
            {
                model.CapitalFreezeLogoId = (int)ojb;
            }
            ojb = dataReader["ThawTime"];
            if (ojb != null && ojb != DBNull.Value)
            {
                model.ThawTime = (DateTime)ojb;
            }
            ojb = dataReader["FreezeTypeLogo"];
            if (ojb != null && ojb != DBNull.Value)
            {
                model.FreezeTypeLogo = (int)ojb;
            }
            model.EntrustNumber = dataReader["EntrustNumber"].ToString();
            ojb = dataReader["CapitalAccountLogo"];
            if (ojb != null && ojb != DBNull.Value)
            {
                model.CapitalAccountLogo = (int)ojb;
            }
            ojb = dataReader["OweCosting"];
            if (ojb != null && ojb != DBNull.Value)
            {
                model.OweCosting = (decimal)ojb;
            }
            ojb = dataReader["FreezeCost"];
            if (ojb != null && ojb != DBNull.Value)
            {
                model.FreezeCost = (decimal)ojb;
            }
            return(model);
        }
        private int PO_BuildCapitalFreezeRecord(decimal predealCapital, decimal predealCost, GTA.VTS.Common.CommonObject.Types.TransactionDirection buySellType, ReckoningTransaction tm)
        {
            var caft = new XH_CapitalAccountFreezeTableInfo();

            ;
            //委托单号
            caft.EntrustNumber = EntrustNumber;

            //卖不产生冻结金额,只有费用
            if (buySellType == GTA.VTS.Common.CommonObject.Types.TransactionDirection.Buying)
            {
                //冻结 预成交金额
                caft.FreezeCapitalAmount = predealCapital;
            }

            //冻结 预成交费用
            caft.FreezeCost = predealCost;
            //冻结时间
            caft.FreezeTime = DateTime.Now;
            //解冻时间
            caft.ThawTime = DateTime.Now;
            //冻结类型
            caft.FreezeTypeLogo = (int)Types.FreezeType.DelegateFreeze;

            caft.OweCosting = 0;

            caft.CapitalAccountLogo = CapitalAccountId;

            string format =
                "现货资金冻结处理XHBuyOrderLogicFlow.PO_BuildCapitalFreezeRecord[委托单号={0},冻结时间={1},解冻时间={2},冻结类型={3},预成交金额={4},预成交费用={5},资金账户ID={6}]";

            string desc = string.Format(format, caft.EntrustNumber, caft.FreezeTime, caft.ThawTime, caft.FreezeTypeLogo,
                                        caft.FreezeCapitalAmount, caft.FreezeCost, CapitalAccountId);

            LogHelper.WriteDebug(desc);

            XH_CapitalAccountFreezeTableDal dal = new XH_CapitalAccountFreezeTableDal();

            return(dal.Add(caft, tm.Database, tm.Transaction));
        }
        /// <summary>
        /// 得到一个对象实体
        /// </summary>
        public XH_CapitalAccountFreezeTableInfo GetModel(int CapitalFreezeLogoId)
        {
            StringBuilder strSql = new StringBuilder();

            strSql.Append(
                "select FreezeTime,FreezeCapitalAmount,CapitalFreezeLogoId,ThawTime,FreezeTypeLogo,EntrustNumber,CapitalAccountLogo,OweCosting,FreezeCost from XH_CapitalAccountFreezeTable ");
            strSql.Append(" where CapitalFreezeLogoId=@CapitalFreezeLogoId ");
            Database  db        = DatabaseFactory.CreateDatabase();
            DbCommand dbCommand = db.GetSqlStringCommand(strSql.ToString());

            db.AddInParameter(dbCommand, "CapitalFreezeLogoId", DbType.Int32, CapitalFreezeLogoId);
            XH_CapitalAccountFreezeTableInfo model = null;

            using (IDataReader dataReader = db.ExecuteReader(dbCommand))
            {
                if (dataReader.Read())
                {
                    model = ReaderBind(dataReader);
                }
            }
            return(model);
        }