C#反射在数据库连接时的应用
反射的应用
1.查找指定ID的数据
//查找指定id的数据,返回指定的对象
private T FindData<T>(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 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<T>(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<T>(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<T>()
{
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;
}
C#反射在数据库连接时的应用的更多相关文章
- 外壳exe通过反射调用dll时
外壳exe通过反射调用dll时,dll是 4.0的框架,外壳exe也需要编译成4.0的框架,如果dll本身有调用32位的dll,那么外壳exe也需要编译成32位. 调试时报的那个错,直接继续运行,不影 ...
- mysql autocommit=OFF导致wordpress 建立数据库连接时出错
今天安装wordpress完成后跳转到login页面时,出现建立数据库连接时出错.网上清一色的拷贝http://mt.sohu.com/20160917/n468547634.shtml的答案. 只能 ...
- 在IDEA中使用JDBC获取数据库连接时的报错及解决办法
在IDEA中使用JDBC获取数据库连接时,有时会报错Sat Dec 19 19:32:18 CST 2020 WARN: Establishing SSL connection without ser ...
- FireDac 与数据库连接时字符集及对应的字段类型问题
近日在一个过程调用时发生一个奇怪现象, 异常返回意思是说, 数据的长度是[6], 而字段定义的长度是[3]. 分析后认为: 调用过程你不涉及到对返回数据集的字段手动定义问题, 出现这个问题应是两边 ...
- 关于数据库连接时URL的问题
最近在写一个简单的增删改查的代码时,遇到保存的中文都会变成问号(?),由于刚开始只是一些数据的保存,所以认为之后只要对数据库的编码进行修改即可,但是后来要对数据进行查找的时候发现根本查找不到, 当时用 ...
- Android中的自定义注解(反射实现-运行时注解)
预备知识: Java注解基础 Java反射原理 Java动态代理 一.布局文件的注解 我们在Android开发的时候,总是会写到setContentView方法,为了避免每次都写重复的代码,我们需要使 ...
- Java——反射:运行时的类信息
RTTI的使用 如果不知道某个对象的确切类型,RTTI会告诉我们,但是有一个限制:这个类型在编译时必须已知,这样才能使用RTTI识别它,并利用这些信息做一些有用的事情. 2.什么情况下需要反射 假设 ...
- JAVA_基础反射创建运行时类的对象
通过反射去创建对应的运行时类的对象 newInstance():调用此方法,创建对应的运行时类的对象.内部调用的是空参的构造器. 要想此方法正常的创建运行时类的对象,要求: 1.运行时类必须提供空参构 ...
- 利用反射调用方法时,处理ref,out参数需要注意的问题(转)
转自:http://www.68idc.cn/help/buildlang/ask/20150318283817.html 项目中如下的泛型方法,因为要在运行时,动态指定类型参数,所以要利用反射来实现 ...
- 通过hibernate session.connection()获得数据库连接时,导致的查询缓慢甚至假死机问题
在使用hibernate的应用中,如果需要直接使用Java.sql.Connection,一般我们是通过hibernate的session.connection()获得的,然后session.clos ...
随机推荐
- 【Playwright+Python】手把手带你写一个自动化测试脚本
如何使用代理方式打开网页 在 playwright.chromium.launch() 中传入 proxy 参数即可,示例代码如下: 1.同步写法: 1 from playwright.sync_ ...
- AGC044C Strange Dance
在2020年A卷省选day2t2有类似操作trie的技巧. 题目链接 显然是建一棵三叉trie树,代表0/1/2 对这棵trie树,我们需要支持子树交换和全局加1 考虑第一个操作怎么做?直接打个懒标记 ...
- 关于c指针的理解
1 #include<stdio.h> 2 { 3 int a= 100,b=10; 4 int *p1=&a,*p2=&b; 5 *p1=b; 6 *p2=a; 7 pr ...
- centos7中的nohup和&的用法和区别
1.&和nohup的区别 &的意思是在后台运行, 意思是说, 当你在执行 ./start.sh & 的时候, 即使你用ctrl C, 那么start.sh照样运行(因为对SIG ...
- mapreduce压缩
这是mr的一种优化策略,通过压缩编码对mapper或者reducer的输出进行压缩,以减少磁盘io,提高mr运行速度(但也相应增加了cpu运算负担) 特性: 1.mr支持将map输出的结果或者redu ...
- python3 requests 请求https报错: urllib3.exceptions.SSLError: [SSL: SSLV3_ALERT_HANDSHAKE_FAILURE] sslv3 alert handshake failure (_ssl.c:992)
正文 代码示例: #-*- coding:utf-8 -*- import requests url = "https://tst.com" res = requests.get( ...
- 如何把自己项目中的jar包部署或pom部署到私服Nexus【实践可行版】
如何把自己项目中的jar包部署到私服 1.在项目的pom.xml文件中加入私服地址: <distributionManagement> <snapshotRepository> ...
- 原创软件 | 系统服务工具箱原创软件(587KB)--基于aardio开发的第一个程序
1 系统服务工具箱简介 该软件是我使用aardio开发的第一个程序,它集成了多个系统常用的快捷键,无需记住各种命令就能快捷使用cmd管理员.计算机管理.控制面板.组策略.注册表.服务.任务管理.卸载程 ...
- C# 使用模式匹配的好处,因为好用所以推荐~
类型检查和转换:当你需要检查对象是否为特定类型,并且希望在同一时间内将其转换为那个类型时,模式匹配提供了一种更简洁的方式来完成这一任务,避免了使用传统的as和is操作符后还需要进行额外的null检查. ...
- 全网最适合入门的面向对象编程教程:20 类和对象的 Python 实现-组合关系的实现与 CSV 文件保存
全网最适合入门的面向对象编程教程:20 类和对象的 Python 实现-组合关系的实现与 CSV 文件保存 摘要: 本文主要介绍了在使用 Python 面向对象编程时,如何实现组合关系,同时对比了组合 ...