/// <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); } }
/// <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); }
/// <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("对账失败"); }
/// <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); }
/// <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)); } }
/// <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("删除失败"); }
public bool Update(Model.finance_chk model) { return(dal.Update(model)); }