Пример #1
0
        /// <summary>
        /// 得到一个对象实体
        /// </summary>
        public Model.finance_chk GetModel(int id)
        {
            StringBuilder strSql = new StringBuilder();
            StringBuilder str1   = new StringBuilder();

            Model.finance_chk model = new Model.finance_chk();
            //利用反射获得属性的所有公共属性
            PropertyInfo[] pros = model.GetType().GetProperties();
            foreach (PropertyInfo p in pros)
            {
                str1.Append(p.Name + ",");//拼接字段
            }
            strSql.Append("select top 1 " + str1.ToString().Trim(','));
            strSql.Append(" from MS_finance_chk");
            strSql.Append(" where fc_id=@id");
            SqlParameter[] parameters =
            {
                new SqlParameter("@id", SqlDbType.Int, 4)
            };
            parameters[0].Value = id;
            DataTable dt = DbHelperSQL.Query(strSql.ToString(), parameters).Tables[0];

            if (dt.Rows.Count > 0)
            {
                return(DataRowToModel(dt.Rows[0]));
            }
            else
            {
                return(null);
            }
        }
Пример #2
0
        /// <summary>
        /// 更新一条数据
        /// </summary>
        public bool Update(Model.finance_chk model)
        {
            StringBuilder strSql = new StringBuilder();
            StringBuilder str1   = new StringBuilder();

            //利用反射获得属性的所有公共属性
            PropertyInfo[]      pros  = model.GetType().GetProperties();
            List <SqlParameter> paras = new List <SqlParameter>();

            strSql.Append("update MS_finance_chk set ");
            foreach (PropertyInfo pi in pros)
            {
                //如果不是主键则追加sql字符串
                if (!pi.Name.Equals("fc_id"))
                {
                    //判断属性值是否为空
                    if (pi.GetValue(model, null) != null)
                    {
                        str1.Append(pi.Name + "=@" + pi.Name + ",");                          //声明参数
                        paras.Add(new SqlParameter("@" + pi.Name, pi.GetValue(model, null))); //对参数赋值
                    }
                }
            }
            strSql.Append(str1.ToString().Trim(','));
            strSql.Append(" where fc_id=@id ");
            paras.Add(new SqlParameter("@id", model.fc_id));
            return(DbHelperSQL.ExecuteSql(strSql.ToString(), paras.ToArray()) > 0);
        }
Пример #3
0
        /// <summary>
        /// 对账
        /// </summary>
        /// <param name="fin_id"></param>
        /// <param name="oid">订单号</param>
        /// <param name="num">对账标识</param>
        /// <param name="money">对账金额</param>
        /// <param name="manager"></param>
        /// <returns></returns>
        public string addFinancechk(int?fin_id, string oid, string num, decimal?money, Model.manager manager, int fcid = 0, bool flag = false)
        {
            if (!new BLL.permission().checkHasPermission(manager, "0406"))
            {
                return("无权限操作");
            }
            Model.finance_chk model   = new Model.finance_chk();
            StringBuilder     content = new StringBuilder();

            if (fcid > 0)
            {
                model = GetModel(fcid);
                if (model.fc_num != num)
                {
                    content.Append("对账标识:" + model.fc_num + "→<font color='red'>" + num + "</font><br/>");
                }
                model.fc_num = num;
                if (model.fc_money != money)
                {
                    content.Append("对账金额:" + model.fc_money + "→<font color='red'>" + money + "</font><br/>");
                }
                model.fc_money = money;
            }
            else
            {
                model.fc_finid   = fin_id;
                model.fc_oid     = oid;
                model.fc_num     = num;
                model.fc_money   = money;
                model.fc_number  = manager.user_name;
                model.fc_name    = manager.real_name;
                model.fc_addDate = DateTime.Now;
                content.Append("对账标识:" + num + "<br/>");
                content.Append("对账金额:" + money + "<br/>");
            }
            if (flag)
            {
                dal.DeleteByFinid(fin_id.Value);
            }
            bool result = fcid > 0 ? Update(model) : dal.Add(model) > 0;

            if (result)
            {
                Model.business_log logmodel = new Model.business_log();
                logmodel.ol_relateID    = fin_id.Value;
                logmodel.ol_oid         = oid;
                logmodel.ol_title       = "添加对账";
                logmodel.ol_content     = content.ToString();
                logmodel.ol_operateDate = DateTime.Now;
                new business_log().Add(DTEnums.ActionEnum.Add.ToString(), logmodel, manager.user_name, manager.real_name); //记录日志
                return("");
            }
            return("对账失败");
        }
Пример #4
0
 /// <summary>
 /// 将对象转换实体
 /// </summary>
 public Model.finance_chk DataRowToModel(DataRow row)
 {
     Model.finance_chk model = new Model.finance_chk();
     if (row != null)
     {
         //利用反射获得属性的所有公共属性
         Type modelType = model.GetType();
         for (int i = 0; i < row.Table.Columns.Count; i++)
         {
             //查找实体是否存在列表相同的公共属性
             PropertyInfo proInfo = modelType.GetProperty(row.Table.Columns[i].ColumnName);
             if (proInfo != null && row[i] != DBNull.Value)
             {
                 proInfo.SetValue(model, row[i], null);//用索引值设置属性值
             }
         }
     }
     return(model);
 }
Пример #5
0
        /// <summary>
        /// 增加一条数据
        /// </summary>
        public int Add(Model.finance_chk model)
        {
            StringBuilder strSql = new StringBuilder();
            StringBuilder str1   = new StringBuilder(); //数据字段
            StringBuilder str2   = new StringBuilder(); //数据参数

            //利用反射获得属性的所有公共属性
            PropertyInfo[]      pros  = model.GetType().GetProperties();
            List <SqlParameter> paras = new List <SqlParameter>();

            strSql.Append("insert into MS_finance_chk(");
            foreach (PropertyInfo pi in pros)
            {
                //如果不是主键则追加sql字符串
                if (!pi.Name.Equals("fc_id"))
                {
                    //判断属性值是否为空
                    if (pi.GetValue(model, null) != null)
                    {
                        str1.Append(pi.Name + ",");                                           //拼接字段
                        str2.Append("@" + pi.Name + ",");                                     //声明参数
                        paras.Add(new SqlParameter("@" + pi.Name, pi.GetValue(model, null))); //对参数赋值
                    }
                }
            }
            strSql.Append(str1.ToString().Trim(','));
            strSql.Append(") values (");
            strSql.Append(str2.ToString().Trim(','));
            strSql.Append(") ");
            strSql.Append(";select @@IDENTITY;");
            object obj = DbHelperSQL.GetSingle(strSql.ToString(), paras.ToArray());

            if (obj == null)
            {
                return(0);
            }
            else
            {
                return(Convert.ToInt32(obj));
            }
        }
Пример #6
0
        /// <summary>
        /// 删除对账
        /// </summary>
        /// <param name="fcid"></param>
        /// <param name="manager"></param>
        /// <returns></returns>
        public string delFinancechk(int fcid, Model.manager manager)
        {
            if (!new BLL.permission().checkHasPermission(manager, "0406"))
            {
                return("无权限操作");
            }
            Model.finance_chk model = dal.GetModel(fcid);
            if (dal.Delete(fcid))
            {
                StringBuilder content = new StringBuilder();
                content.Append("对账标识:" + model.fc_num + "<br/>");
                content.Append("对账金额:" + model.fc_money + "<br/>");

                Model.business_log logmodel = new Model.business_log();
                logmodel.ol_relateID    = model.fc_finid.Value;
                logmodel.ol_oid         = model.fc_oid;
                logmodel.ol_title       = "删除对账";
                logmodel.ol_content     = content.ToString();
                logmodel.ol_operateDate = DateTime.Now;
                new business_log().Add(DTEnums.ActionEnum.Delete.ToString(), logmodel, manager.user_name, manager.real_name); //记录日志
                return("");
            }
            return("删除失败");
        }
Пример #7
0
 public bool Update(Model.finance_chk model)
 {
     return(dal.Update(model));
 }