C# SQL封装(四)
admin
2023-05-22 04:42:30
0

本篇接C# SQL封装(三)

在其功能上继续扩展 改操作 , 让我们开始吧。。。。。

一 : 构建T-SQL语句(在SQL_Structure.cs中添加一个方法 UPDATE_T_SQL , 用于构建update的T-SQL)

        /// 
        /// 更新一条数据的T-SQL构成(以id号来删除)
        /// 
        /// 
        /// 原始model
        /// 更改后的model
        /// 
        public static string UPDATE_T_SQL(T model , T model_change) where T : BaseModel
        {
            Type model_type = model.GetType();
            Type model_change_type = model_change.GetType();
            if (model_type.Name == model_change_type.Name)
            {
                string base_update = @"update [{0}] set {1} where {2} = @{3}";
                string[] arr = model_type.Name.Split(new char[] { '.' });
                string table_name = arr[arr.Length - 1];//获得表的名称
                PropertyInfo[] p_intos = model_type.GetProperties();
                PropertyInfo item = null;
                PropertyInfo item_change = null;
                string item_value = string.Empty;
                string item_change_value = string.Empty;
                StringBuilder update_set = null;
                for (int i = 0; i < p_intos.Length; i++)
                {
                    item = p_intos[i];
                    item_change = model_change_type.GetProperty(item.Name);
                    item_value = item.GetValue(model, null).ToString();
                    item_change_value = item_change.GetValue(model_change, null).ToString();
                    if (item.Name == "id")
                    {
                        //比较id值是否一致
                        if (item_value != item_change_value)
                        {
                            throw new Exception(
                                string.Format("model类 id : {0} 与model_change类id:{1} 不一致,请确保是同一条数据",
                                    item_value,
                                    item_change_value
                                )
                                );
                        }
                    }
                    else
                    {
                        if (item_value != item_change_value)
                        {
                            if (update_set == null) update_set = new StringBuilder();
                            update_set.Append(
                                string.Format( @" {0} = @{1}," , item.Name , item.Name )
                                );
                        }
                    }
                }
                if (update_set != null)
                {
                    return string.Format( base_update,
                        table_name,
                        update_set.ToString().Substring(0, update_set.ToString().Length - 1),
                        "id",
                        "id"
                        );
                }
                else
                {
                    return string.Empty;//不存在更新
                }
            }
            else
            {
                throw new Exception(
                    string.Format("model类 : {0} 与model_change类 :{1} 不匹配",
                        model_type.Name ,
                        model_change_type.Name
                        )
                    );
            }
        }

二 : 构建SqlParameter参数 (在SqlParameter_Structure.as中添加方法UPDATE_T_SQL

        /// 
        /// 构建T-SQL参数 UPDATE
        /// 
        /// 
        /// 原model
        /// 更改后model
        /// 
        public static SqlParameter[] UPDATE_T_SQL(T model, T model_change) where T : BaseModel
        {
            Type model_type = model.GetType();
            Type model_change_type = model_change.GetType();
            if (model_type.Name == model_change_type.Name)
            {
                PropertyInfo[] p_intos = model_type.GetProperties();
                PropertyInfo item = null;
                PropertyInfo item_change = null;
                string item_value = string.Empty;
                string item_change_value = string.Empty;
                List sql_param = null;
                SqlParameter cell = null;
                bool is_change_model = false;//是否有字段进行了更改
                for (int i = 0; i < p_intos.Length; i++)
                {
                    item = p_intos[i];
                    item_change = model_change_type.GetProperty(item.Name);
                    item_value = item.GetValue(model, null).ToString();
                    item_change_value = item_change.GetValue(model_change, null).ToString();
                    if (item.Name == "id")
                    {
                        if (item_value != item_change_value)
                        {
                            throw new Exception(
                                string.Format("model类 id : {0} 与model_change类id:{1} 不一致,请确保是同一条数据",
                                    item_value,
                                    item_change_value
                                )
                                );
                        }
                        else
                        {
                            if (sql_param == null) sql_param = new List();
                            cell = new SqlParameter(item.Name, SqlParameter_Structure.Get_SqlDbType_SqlType(item.PropertyType));
                            cell.Value = item.GetValue(model, null);
                            sql_param.Add(cell);
                        }
                    }
                    else
                    {
                        if (item_value != item_change_value)
                        {
                            if (!is_change_model) is_change_model = true;
                            if (sql_param == null) sql_param = new List();
                            cell = new SqlParameter(item_change.Name, SqlParameter_Structure.Get_SqlDbType_SqlType(item_change.PropertyType));
                            cell.Value = item_change.GetValue(model_change, null);//加入改变的值
                            sql_param.Add(cell);
                        }
                    }
                }
                if (is_change_model)
                {
                    return sql_param.ToArray();
                }
                else
                {
                    return null;//没有任何字段更改
                }
            }
            else
            {
                throw new Exception(
                    string.Format("model类 : {0} 与model_change类 :{1} 不匹配",
                        model_type.Name,
                        model_change_type.Name
                        )
                    );
            }
        }

测试:

C# SQL封装(四)

测试代码


            //------------------------模拟一条重数据库得到的数据 begin ---------------------------------------
            User kayer_ori = new User();
            kayer_ori.id = 3;
            kayer_ori.name = "kayer";
            kayer_ori.sex = 1;
            kayer_ori.lv = 1;
            kayer_ori.username = "Kayer";
            kayer_ori.userpwd = "123";
            //------------------------模拟一条重数据库得到的数据 end -----------------------------------------
            //拷贝一条kayer_ori数据 ( 可以用原型模式 , 这里我直接使用笨办法 )
            User kayer_change_copy = new User();
            kayer_change_copy.id = kayer_ori.id;
            kayer_change_copy.name = kayer_ori.name;
            kayer_change_copy.sex = kayer_ori.sex;
            kayer_change_copy.lv = kayer_ori.lv;
            kayer_change_copy.username = kayer_ori.username;
            kayer_change_copy.userpwd = kayer_ori.userpwd;
            // --- 改变数据 ---
            kayer_change_copy.name = "Aonaufly";
            kayer_change_copy.lv = 4;
            string sql_update = SQL_Structure.UPDATE_T_SQL(kayer_ori, kayer_change_copy);
            SqlParameter[] update_p = SqlParameter_Structure.UPDATE_T_SQL(kayer_ori, kayer_change_copy);
            int i = SqlHelper.ExecteNonQuery(CommandType.Text, sql_update, update_p);
            if (i > 0)
            {
                Console.WriteLine("执行操作成功");
            }
            else
            {
                Console.WriteLine("执行操作失败");
            }


结果 :

C# SQL封装(四)

在数据库中:

C# SQL封装(四)


未完待续 ..........................


相关内容

热门资讯

被困近11小时,广西柳州地震9... 5月18日,广西柳州市抗震救灾新闻发布会在太阳村镇上等村举行。柳州市消防救援局相关负责人介绍了91岁...
酒钢成功研发食品级瓶盖专用铝材 近日,酒钢突破传统热轧工艺限制,成功研发短流程铸轧薄坯高深冲铝板带——食品级瓶盖专用料,让国产高品质...
和铂医药公布首款AI候选药物L... 来源:上海证券报·中国证券网 和铂医药(股票代码:02142.HK),一家专注于免疫性疾病、肿瘤及其...
从深海孤岛到田间工厂,织就一张... 100%与97.9%,是山东省行政村移动网络覆盖与5G覆盖的双重刻度;全国首张5G全海岸线连续覆盖网...
AI浪潮下的职场转型:技能升级... 人工智能(AI)的出现在科技高管和求职者心中同时激起了恐惧与兴奋,这股最新的技术浪潮正在从根本上改变...
伊朗称有权对霍尔木兹海峡海底光... 伊朗伊斯兰革命卫队18日在社交媒体发布消息称,在伊方对霍尔木兹海峡“实施管理”后,“可宣布所有经过该...
广西柳州市启动洪水防御四级应急... 5月17日以来,广西柳州市柳南区已发生多次地震。据柳州市气象部门预报,5月14日以来,柳州市部分地区...
沙特消息称伊朗提出有条件地将浓... 据沙特方面当地时间18日消息,伊朗旨在结束中东冲突的最新修订方案包括有条件地将浓缩铀转移到俄罗斯,而...
广西再发生5.2级地震,凤凰记... 5月18日晚,广西柳州再度发生5.2级地震。凤凰卫视记者朱家杰深入震中上步村,摄像机全程记录下采访当...
黑龙江省高校科研成果“三进三促... 中新网黑龙江新闻5月17日电(张媛媛)近日,黑龙江省高校科研成果“三进三促”专项行动——哈尔滨理工大...