写一个MyORM--利用反射的方法
本文的目的是为了更加深刻的理解反射。
ORM:Object Relational Mapping对象关系映射,是解决了面向对象语言和关系型数据库不匹配的问题。
ORM是一种思想,实现这种思想的技术有很多,如C#中的Entity Framework,NHibernate,Java中的Hibernate。
新建一个控制台应用程序,添加一个类,Person.cs
public class Person
{
public int Id { get; set; }
public string Name { get; set; }
public int Age { get; set; }
}
添加一个类,MyORM.cs
public class MyORM
{
private static readonly string connstr = ConfigurationManager.ConnectionStrings["connstr"].ConnectionString;
//假设:表名和类名一致
/// <summary>
/// 插入一条数据
/// </summary>
/// <param name="obj">插入的对象</param>
/// <returns>受影响函数</returns>
public int Insert(object obj)
{
Type type = obj.GetType();
string className = type.Name;//person
//insert into Person(Name,Age)values("哈哈",10)
PropertyInfo[] props = type.GetProperties();
List<string> propNames = new List<string>();//属性名列表
List<string> paraNames = new List<string>();//参数名列表
List<MySqlParameter> paramters = new List<MySqlParameter>();//参数
foreach (PropertyInfo prop in props)
{
string propName = prop.Name;
if (propName != "Id")
{
propNames.Add(propName);
paraNames.Add("@" + propName);
MySqlParameter para=new MySqlParameter(propName,prop.GetValue(obj));
paramters.Add(para);
}
}
StringBuilder sqlsb = new StringBuilder();
sqlsb.Append("insert into ").Append(className).Append("(").Append(string.Join(",", propNames)).Append(")values(").Append(string.Join(",", paraNames)).Append(")");
return MySqlHelper.ExecuteNonQuery(connstr, sqlsb.ToString(), paramters.ToArray());
}
//根据Id查询
public object SelectById(Type type, int id)
{
object obj= Activator.CreateInstance(type);
//select * from Person where Id=1
string className = type.Name;
string sql = "select * from " + className + " where Id=@Id";
MySqlParameter para = new MySqlParameter("@Id",id);
DataSet ds= MySqlHelper.ExecuteDataset(connstr, sql, para);
DataTable table = ds.Tables[];
if (table.Rows.Count<=)
{
return null;//没有查到数据
}
else if (table.Rows.Count>)
{
throw new Exception("出大问题了");
}
DataRow row = table.Rows[];
foreach (var prop in type.GetProperties())
{
prop.SetValue(obj,row[prop.Name]);
}
return obj;
} }
这里有一个先决条件:类名要和数据库表名一致
Insert方法实现的是只要传一个类Object就可以将这个类对应的数据添加到数据库表中,主要是通过反射的方法获取类名、属性名和属性值,通过这些拼接sql语句,完成insert操作。
SelectById方法是根据类的Type和属性Id的值,从数据库中查询数据并且赋值给Object.先从数据库中查询数据,通过反射的方法为object的每个属性赋值,返回object.
为了事先规定Type的类型,我们还可以把SelectById方法更改为泛型的方法
//根据Id查询
public T SelectById<T>( int id) where T:new()//泛型约束有无参的构造函数
{
Type type = typeof(T);
//object obj= Activator.CreateInstance(type);
T obj = new T();
//select * from Person where Id=1
string className = type.Name;
string sql = "select * from " + className + " where Id=@Id";
MySqlParameter para = new MySqlParameter("@Id",id);
DataSet ds= MySqlHelper.ExecuteDataset(connstr, sql, para);
DataTable table = ds.Tables[];
if (table.Rows.Count<=)
{
return default(T);//没有查到数据
}
else if (table.Rows.Count>)
{
throw new Exception("出大问题了");
}
DataRow row = table.Rows[];
foreach (var prop in type.GetProperties())
{
prop.SetValue(obj,row[prop.Name]);
}
return obj;//T类型的
}
在主程序中调用的代码
//插入数据到数据库
Person p1 = new Person();
MyORM orm = new MyORM();
p1.Name = "哈哈";
p1.Age = ;
orm.Insert(p1);
Console.ReadKey(); //根据查询数据
Person p2 = (Person)orm.SelectById(typeof(Person), );
Console.WriteLine(p2.Name);
Console.ReadKey(); //泛型的方法查询
Person P3=orm.SelectById<Person>();
Console.WriteLine(p3.Name);
Console.ReadKey();
写一个MyORM--利用反射的方法的更多相关文章
- 利用反射调用方法时,处理ref,out参数需要注意的问题(转)
转自:http://www.68idc.cn/help/buildlang/ask/20150318283817.html 项目中如下的泛型方法,因为要在运行时,动态指定类型参数,所以要利用反射来实现 ...
- javascript : 写一个类似于 jquery css() 的方法
我们知道,jquery css() 方法可以很方便的更改DOM的样式. 但从原理上,这个并不复杂,我们完全可以自己写一个. 上代码. updateDOMStyle(DOM, obj){ Object. ...
- asp.net一般处理程序利用反射定位方法
asp.net的一般处理程序我想大家用得都不少,经常会如下如下的代码: using System; using System.Collections.Generic; using System.Lin ...
- java工具类-接受请求参数,并利用反射调用方法
public String a(HttpServletRequest request,HttpServletResponse response) throws JSONException, IOExc ...
- java将配置信息写在数据库(利用反射)
Demo出处: 1. package com.fpx.pcs.prealert.process.xml.service.impl; public class CainiaoPushMessageSer ...
- Java_jdbc 基础笔记之八 数据库连接(写一个查询Student对象的方法)
public Student getStudent(String sql, Object... args) { // 查询Student对象 Student stu = null; Connectio ...
- Python基础篇【第3篇】: Python异常处理、反射、动态导入、利用反射的web框架
异常处理 什么是异常? 异常即是一个事件,该事件会在程序执行过程中发生,影响了程序的正常执行. 一般情况下,在Python无法正常处理程序时就会发生一个异常.异常是Python对象,表示一个错误.当P ...
- 反射main方法
利用Java反射机制去调用其他类的main方法基于这种情形: 当程序中的某个类在运行到某处需要去调用其他类的main方法时,如果此程序并不知道此main方法所属类的名称,而只是在程序中接受某一代表此m ...
- C#利用反射调用PB编译的COM组件
问题: 1.根据COM组件的ProgID,得到COM组件公开的类型 2.创建COM组件提供的类型的对象 3.调用执行方法 正确姿势 C#利用反射调用(后期绑定)PB编译的COM组件 C#调用COM组件 ...
随机推荐
- poj 2983Is the Information Reliable?
http://poj.org/problem?id=2983 #include<cstdio> #include<cstring> #include<algorithm& ...
- 测试Flask+PYTHON的WEB框架
参数URL: http://blog.csdn.net/qwiwuqo/article/details/8970621 安装flask之前,你必须要先安装python和easy_install. 安装 ...
- 复位应答ATR的基本结构和数据元
根据定义,复位应答是一系列字节的值,这些字节是由卡作为对复位命令的响应发送给接口设备的 ,在I/O电路上,每个字节在一个异步字符中传输.每个成功的复位操作,都会导致I/O上的一个初始字符TS,TS后面 ...
- ISO7816协议的块传输协议
1.块传输协议中的前三个字节是强制必须有的 NAD节点地址: 当终端支持多个卡槽,终端和这些卡槽以总线的方式通讯时,该字节有用,其他情况下,默认为0 bit1-3:定义了源地址 bit5-7:定义了目 ...
- Qt自定义事件的实现(军队真正干活,但要增加监军,大平台通知事件,事件内容自定义)
初学Qt,用了Qt自带的事件,然后想怎么才能定义自己的事件呢?又如何使用自定义事件呢?看了篇文章,说先要子类化QEvent,然后定义自己的QEvent::Type,然后重写QWidget::event ...
- oracle事务和锁
数据库事务概括 1. 说明 一组SQL,一个逻辑工作单位,执行时整体修改或者整体回退. 2.事务相关概念 1)事务的提交和回滚:COMMIT/ROLLBACK 2)事务的开始和结束 开始事务:连接到数 ...
- freemarker基本知识总结
1.取出内容 ${} 例如,${document.fileName} 2. <ul> <#list cms.documents("channel=XXXX") a ...
- Symmetric Tree——LeetCode
Given a binary tree, check whether it is a mirror of itself (ie, symmetric around its center). For e ...
- dojox.grid.EnhancedGrid 和 dojox.grid.DataGrid 的继承关系
dojox.grid.EnhancedGrid 的介绍说, EnhancedGrid 是基于 DataGrid 提供增强功能的. EnhancedGrid (dojox.grid.EnhancedG ...
- libvirt 命令行交互工具之virsh
libvirt是当前主流VM最低层库.IBM PowerVM也不例外,libvirt是深入玩虚拟化必须玩转的东西; 简单测试玩玩libvirt 的virsh命令行交互工具, 你我都知libvirt大体 ...