热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

C#反射在数据库连接时的应用

 反射的应用1.查找指定ID的数据查找指定id的数据,返回指定的对象             privateTFindData(i

 
反射的应用

1.查找指定ID的数据

//查找指定id的数据,返回指定的对象

               private T FindData(int id)

        {

            Type ty = typeof(T);

 

//在这里创建实例对象的时候不能转成指定的类型,只能是Object对象

//转成指定类型后面就赋值不成功

 

                            // T t=(T)Activator.CreateInstance(ty);

//原来我是这么写的,也能创建实例对象,但后面怎么赋值都不行,全是NULL,

//特别要注意这点,要赋值完后才转成指定的类型

 

            object obj = Activator.CreateInstance(ty);

 

            string sql = $"select * from [{ty.Name}] where ID={id}";

            OleDbConnection cOnn= new OleDbConnection(connString);

            OleDbCommand cmd = new OleDbCommand(sql, conn);

            conn.Open();

            OleDbDataReader dr = cmd.ExecuteReader();

            dr.Read();

            foreach (var v in ty.GetFields())

            {

                if(v.FieldType.FullName=="System.Int32")     //在这判断字段类型,我这只有两种类型int,string,如果类型多就要多写几种判断

                                     {

                    obj.GetType().GetField($"{v.Name}").SetValue(obj, int.Parse(dr[$"{v.Name}"].ToString()));       //第一种方法赋值

                                     }

                else

                                     {

                    ty.GetField(name: $"{v.Name}").SetValue(obj, dr[$"{v.Name}"].ToString());          //第二种方法赋值

                                     }

            }

                            dr.Close();

            conn.Close();

            //var vname = obj.GetType().GetField("mAge");

            //vname.SetValue(obj, 23);

           

                            //赋值完了才转成指定的类型

            return (T)obj;

        }

 


2.添加数据到数据库中

               private bool Insert_Into(T t)

        {

            int nRet = 0;

            string intoSql = null;

            string fileName = null;

            string fileValue = null;

            List<OleDbParameter> parList = new List<OleDbParameter>();

 

            Type ty = t.GetType();

            foreach (System.Reflection.FieldInfo v in ty.GetFields())

            {

                fileName += v.Name + ",";

                fileValue += $"@{v.Name},";

                OleDbParameter par = new OleDbParameter($"@{v.Name}", v.GetValue(t));

                parList.Add(par);

            }

            fileName = fileName.Substring(0, fileName.Length - 1);

            fileValue = fileValue.Substring(0, fileValue.Length - 1);

            intoSql = $"INSERT INTO [{ty.Name}] ({fileName}) VALUES ({fileValue})";

 

 

 

            using (OleDbConnection cOnn= new OleDbConnection(connString))

            {

                using (OleDbCommand cmd = new OleDbCommand(intoSql, conn))

                {

                    cmd.Parameters.Clear();

                    cmd.Parameters.AddRange(parList.ToArray());

                    conn.Open();

                    nRet = cmd.ExecuteNonQuery();

                    conn.Close();

                }

            }

 

            return nRet == 1;

        }

 


3.修改数据

 

private bool UpdateData(int id,T t)

        {

            int nRet = 0;

            string intoSql = null;

            string fileName = null;

          

            List<OleDbParameter> parList = new List<OleDbParameter>();

 

            Type ty = t.GetType();

            foreach (System.Reflection.FieldInfo v in ty.GetFields())

            {

                fileName += v.Name + $"=@{v.Name},";

               

                OleDbParameter par = new OleDbParameter($"@{v.Name}", v.GetValue(t));

                parList.Add(par);

            }

            fileName = fileName.Substring(0, fileName.Length - 1);

          

            intoSql = $"UPDATE [{ty.Name}] SET {fileName} WHERE ID={id}";

 

 

 

            using (OleDbConnection cOnn= new OleDbConnection(connString))

            {

                using (OleDbCommand cmd = new OleDbCommand(intoSql, conn))

                {

                    cmd.Parameters.Clear();

                    cmd.Parameters.AddRange(parList.ToArray());

                    conn.Open();

                    nRet = cmd.ExecuteNonQuery();

                    conn.Close();

                }

            }

 

            return nRet == 1;

        }

 


4.删除数据

 

private bool DeleteData(int id)

        {

            int nRet = 0;

            string intoSql = null;

           

       

 

            Type ty = typeof(T);         

            intoSql = $"DELETE FROM [{ty.Name}] WHERE ID={id}";

            using (OleDbConnection cOnn= new OleDbConnection(connString))

            {

                using (OleDbCommand cmd = new OleDbCommand(intoSql, conn))

                {

                   

                    conn.Open();

                    nRet = cmd.ExecuteNonQuery();

                    conn.Close();

                }

            }

 

            return nRet == 1;

 

        }

 


5.读取所有数据,返回一个所有数据的表

 

private DataTable GetDataTable()

        {

            DataTable dt = new DataTable();

            Type ty = typeof(T);

            string sql = $"SELECT * FROM [{ty.Name}]";

            using (OleDbConnection cOnn= new OleDbConnection(connString))

            {

                using (OleDbCommand cmd = new OleDbCommand(sql, conn))

                {

                    conn.Open();

                    OleDbDataAdapter da = new OleDbDataAdapter(cmd);

                    da.Fill(dt);           

                }

                conn.Close();

            }

 

            return dt;

        }

签名:GreenLeaf1976



推荐阅读
  • 本文介绍了C#中数据集DataSet对象的使用及相关方法详解,包括DataSet对象的概述、与数据关系对象的互联、Rows集合和Columns集合的组成,以及DataSet对象常用的方法之一——Merge方法的使用。通过本文的阅读,读者可以了解到DataSet对象在C#中的重要性和使用方法。 ... [详细]
  • 本文是一位90后程序员分享的职业发展经验,从年薪3w到30w的薪资增长过程。文章回顾了自己的青春时光,包括与朋友一起玩DOTA的回忆,并附上了一段纪念DOTA青春的视频链接。作者还提到了一些与程序员相关的名词和团队,如Pis、蛛丝马迹、B神、LGD、EHOME等。通过分享自己的经验,作者希望能够给其他程序员提供一些职业发展的思路和启示。 ... [详细]
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • 推荐一个ASP的内容管理框架(ASP Nuke)的优势和适用场景
    本文推荐了一个ASP的内容管理框架ASP Nuke,并介绍了其主要功能和特点。ASP Nuke支持文章新闻管理、投票、论坛等主要内容,并可以自定义模块。最新版本为0.8,虽然目前仍处于Alpha状态,但作者表示会继续更新完善。文章还分析了使用ASP的原因,包括ASP相对较小、易于部署和较简单等优势,适用于建立门户、网站的组织和小公司等场景。 ... [详细]
  • EPICS Archiver Appliance存储waveform记录的尝试及资源需求分析
    本文介绍了EPICS Archiver Appliance存储waveform记录的尝试过程,并分析了其所需的资源容量。通过解决错误提示和调整内存大小,成功存储了波形数据。然后,讨论了储存环逐束团信号的意义,以及通过记录多圈的束团信号进行参数分析的可能性。波形数据的存储需求巨大,每天需要近250G,一年需要90T。然而,储存环逐束团信号具有重要意义,可以揭示出每个束团的纵向振荡频率和模式。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 基于layUI的图片上传前预览功能的2种实现方式
    本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ... [详细]
  • 本文介绍了如何使用Power Design(PD)和SQL Server进行数据库反向工程的方法。通过创建数据源、选择要反向工程的数据表,PD可以生成物理模型,进而生成所需的概念模型。该方法适用于SQL Server数据库,对于其他数据库是否适用尚不确定。详细步骤和操作说明可参考本文内容。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • PHP设置MySQL字符集的方法及使用mysqli_set_charset函数
    本文介绍了PHP设置MySQL字符集的方法,详细介绍了使用mysqli_set_charset函数来规定与数据库服务器进行数据传送时要使用的字符集。通过示例代码演示了如何设置默认客户端字符集。 ... [详细]
  • Oracle Database 10g许可授予信息及高级功能详解
    本文介绍了Oracle Database 10g许可授予信息及其中的高级功能,包括数据库优化数据包、SQL访问指导、SQL优化指导、SQL优化集和重组对象。同时提供了详细说明,指导用户在Oracle Database 10g中如何使用这些功能。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • Mac OS 升级到11.2.2 Eclipse打不开了,报错Failed to create the Java Virtual Machine
    本文介绍了在Mac OS升级到11.2.2版本后,使用Eclipse打开时出现报错Failed to create the Java Virtual Machine的问题,并提供了解决方法。 ... [详细]
  • [译]技术公司十年经验的职场生涯回顾
    本文是一位在技术公司工作十年的职场人士对自己职业生涯的总结回顾。她的职业规划与众不同,令人深思又有趣。其中涉及到的内容有机器学习、创新创业以及引用了女性主义者在TED演讲中的部分讲义。文章表达了对职业生涯的愿望和希望,认为人类有能力不断改善自己。 ... [详细]
author-avatar
继续不插电的名单
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有