/// <summary> /// 更新一条数据 /// </summary> public bool Update(Model.Sys_Product model) { StringBuilder strSql = new StringBuilder(); StringBuilder str1 = new StringBuilder(); //利用反射获得属性的所有公共属性 PropertyInfo[] pros = model.GetType().GetProperties(); List <SqlParameter> paras = new List <SqlParameter>(); strSql.Append("update Sys_Product set "); foreach (PropertyInfo pi in pros) { //如果不是主键则追加sql字符串 if (!pi.Name.Equals("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 ID=@ID "); paras.Add(new SqlParameter("@ID", model.ID)); return(DbHelperSQL.ExecuteSql(strSql.ToString(), paras.ToArray()) > 0); }
/// <summary> /// 得到一个对象实体 /// </summary> public Model.Sys_Product GetModel(int ID) { StringBuilder strSql = new StringBuilder(); StringBuilder str1 = new StringBuilder(); Model.Sys_Product model = new Model.Sys_Product(); //利用反射获得属性的所有公共属性 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 Sys_Product"); strSql.Append(" where 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> void BindModel() { BLL.Sys_Product sys_BLL = new BLL.Sys_Product(); Model.Sys_Product sys_Model = sys_BLL.GetModel(PKID); PTypeMain = sys_Model.PTypeMain.ToString(); PTypeSmall = sys_Model.PTypeSmall.ToString(); PProperty = sys_Model.PProperty; PName = sys_Model.PName; PMarket = sys_Model.PMarket; PRetail = sys_Model.PRetail; PFormat = sys_Model.PFormat; PParam = sys_Model.PParam; PMould = sys_Model.PMould; PStock = sys_Model.PStock; PRecommend = sys_Model.PRecommend; PShelf = sys_Model.PShelf; txtPDetails.Value = sys_Model.PDetails; PPic = sys_Model.PSmallPic; DPic = sys_Model.PDetailPic; if (PPic != "") { string[] sArray = PPic.Split(','); foreach (string j in sArray) { PPic_List += "<li>"; PPic_List += "<input type=\"hidden\" name=\"ImgName\" value=\"" + j.ToString() + "\" />"; PPic_List += "<div class=\"img-box\">"; PPic_List += "<img src=\"" + GetImgUrl() + "/upload/product/" + j.ToString() + "\" onclick=\"setOpenImg(this.src);\" bigsrc=\"" + GetImgUrl() + "/upload/product/" + j.ToString() + "\" />"; PPic_List += "</div>"; PPic_List += "<a href=\"javascript:;\" onclick=\"delImg(this);\">删除</a>"; PPic_List += "</li>"; } } if (DPic != "") { string[] sArray = DPic.Split(','); foreach (string j in sArray) { DPic_List += "<li>"; DPic_List += "<input type=\"hidden\" name=\"ImgName\" value=\"" + j.ToString() + "\" />"; DPic_List += "<div class=\"img-box\">"; DPic_List += "<img src=\"" + GetImgUrl() + "/upload/product/" + j.ToString() + "\" onclick=\"setOpenImg(this.src);\" bigsrc=\"" + GetImgUrl() + "/upload/product/" + j.ToString() + "\" />"; DPic_List += "</div> "; DPic_List += "<a href=\"javascript:;\" onclick=\"delImg(this);\">删除</a>"; DPic_List += "</li>"; } } }
/// <summary> /// 将对象转换实体 /// </summary> public Model.Sys_Product DataRowToModel(DataRow row) { Model.Sys_Product model = new Model.Sys_Product(); 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.Sys_Product 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 Sys_Product("); foreach (PropertyInfo pi in pros) { //如果不是主键则追加sql字符串 if (!pi.Name.Equals("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> public bool Update(Model.Sys_Product model) { return(dal.Update(model)); }
/// <summary> /// 增加一条数据 /// </summary> public int Add(Model.Sys_Product model) { return(dal.Add(model)); }
void Sys_Product_Manage(HttpContext context) { #region 处理请求参数 string Id = context.Request["Id"]; int pkid = 0; if (!string.IsNullOrEmpty(Id)) { pkid = Convert.ToInt32(Id); } string PTypeMain = StringHelper.NullToStr(context.Request["PTypeMain"]); string PTypeSmall = StringHelper.NullToStr(context.Request["PTypeSmall"]); string PProperty = StringHelper.NullToStr(context.Request["PProperty"]); string PName = StringHelper.NullToStr(context.Request["PName"]); string PPicUrl = StringHelper.NullToStr(context.Request["PPicUrl"]); string DPicUrl = StringHelper.NullToStr(context.Request["DPicUrl"]); string PMarket = StringHelper.NullToStr(context.Request["PMarket"]); string PRetail = StringHelper.NullToStr(context.Request["PRetail"]); string PFormat = StringHelper.NullToStr(context.Request["PFormat"]); string PParam = StringHelper.NullToStr(context.Request["PParam"]); string PMould = StringHelper.NullToStr(context.Request["PMould"]); string PStock = StringHelper.NullToStr(context.Request["PStock"]); string PRecommend = StringHelper.NullToStr(context.Request["PRecommend"]); string PShelf = StringHelper.NullToStr(context.Request["PShelf"]); string PDetails = StringHelper.NullToStr(context.Request["PDetails"]); #endregion string jsonRet = ""; string retMsg = ""; UserInfo user = new UserInfo(); if (pkid < 1) { #region 添加操作 Model.Sys_Product sys_Model = new Model.Sys_Product(); BLL.Sys_Product sys_BLL = new BLL.Sys_Product(); sys_Model.PTypeMain = PTypeMain; sys_Model.PTypeSmall = PTypeSmall; sys_Model.PProperty = PProperty; sys_Model.PName = PName; sys_Model.PSmallPic = PPicUrl; sys_Model.PDetailPic = DPicUrl; sys_Model.PMarket = decimal.Parse(PMarket); sys_Model.PRetail = decimal.Parse(PRetail); sys_Model.PFormat = PFormat; sys_Model.PParam = PParam; sys_Model.PMould = PMould; sys_Model.PStock = Utils.ToInt(PStock); sys_Model.PRecommend = PRecommend; sys_Model.PShelf = PShelf; sys_Model.PDetails = PDetails; sys_Model.CreateUser = user.GetUserName(); sys_Model.CreateTime = DateTime.Now.ToLocalTime(); sys_Model.ModifyUser = user.GetUserName(); sys_Model.ModifyTime = DateTime.Now.ToLocalTime(); sys_Model.MoreCol1 = ""; sys_Model.MoreCol2 = ""; int ret = sys_BLL.Add(sys_Model); if (ret > 0) { retMsg = "添加成功"; jsonRet = "{retMsg:\"" + retMsg + "\"}"; } else { retMsg = "添加失败"; jsonRet = "{retMsg:\"" + retMsg + "\"}"; } context.Response.Write(retMsg); context.Response.End(); #endregion } else { #region 更新操作 Model.Sys_Product sys_Model = new BLL.Sys_Product().GetModel(pkid); BLL.Sys_Product sys_BLL = new BLL.Sys_Product(); sys_Model.ID = pkid; sys_Model.PTypeMain = PTypeMain; sys_Model.PTypeSmall = PTypeSmall; sys_Model.PProperty = PProperty; sys_Model.PName = PName; sys_Model.PSmallPic = PPicUrl; sys_Model.PDetailPic = DPicUrl; sys_Model.PMarket = decimal.Parse(PMarket); sys_Model.PRetail = decimal.Parse(PRetail); sys_Model.PFormat = PFormat; sys_Model.PParam = PParam; sys_Model.PMould = PMould; sys_Model.PStock = Utils.ToInt(PStock); sys_Model.PRecommend = PRecommend; sys_Model.PShelf = PShelf; sys_Model.PDetails = PDetails; sys_Model.ModifyUser = user.GetUserName(); sys_Model.ModifyTime = DateTime.Now.ToLocalTime(); bool ret = sys_BLL.Update(sys_Model); if (ret == true) { retMsg = "更新成功"; jsonRet = "{retMsg:\"" + retMsg + "\"}"; } else { retMsg = "更新失败"; jsonRet = "{retMsg:\"" + retMsg + "\"}"; } context.Response.Write(retMsg); context.Response.End(); #endregion } }