本文的目的是为了更加深刻的理解反射。

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--利用反射的方法的更多相关文章

  1. 利用反射调用方法时,处理ref,out参数需要注意的问题(转)

    转自:http://www.68idc.cn/help/buildlang/ask/20150318283817.html 项目中如下的泛型方法,因为要在运行时,动态指定类型参数,所以要利用反射来实现 ...

  2. javascript : 写一个类似于 jquery css() 的方法

    我们知道,jquery css() 方法可以很方便的更改DOM的样式. 但从原理上,这个并不复杂,我们完全可以自己写一个. 上代码. updateDOMStyle(DOM, obj){ Object. ...

  3. asp.net一般处理程序利用反射定位方法

    asp.net的一般处理程序我想大家用得都不少,经常会如下如下的代码: using System; using System.Collections.Generic; using System.Lin ...

  4. java工具类-接受请求参数,并利用反射调用方法

    public String a(HttpServletRequest request,HttpServletResponse response) throws JSONException, IOExc ...

  5. java将配置信息写在数据库(利用反射)

    Demo出处: 1. package com.fpx.pcs.prealert.process.xml.service.impl; public class CainiaoPushMessageSer ...

  6. Java_jdbc 基础笔记之八 数据库连接(写一个查询Student对象的方法)

    public Student getStudent(String sql, Object... args) { // 查询Student对象 Student stu = null; Connectio ...

  7. Python基础篇【第3篇】: Python异常处理、反射、动态导入、利用反射的web框架

    异常处理 什么是异常? 异常即是一个事件,该事件会在程序执行过程中发生,影响了程序的正常执行. 一般情况下,在Python无法正常处理程序时就会发生一个异常.异常是Python对象,表示一个错误.当P ...

  8. 反射main方法

    利用Java反射机制去调用其他类的main方法基于这种情形: 当程序中的某个类在运行到某处需要去调用其他类的main方法时,如果此程序并不知道此main方法所属类的名称,而只是在程序中接受某一代表此m ...

  9. C#利用反射调用PB编译的COM组件

    问题: 1.根据COM组件的ProgID,得到COM组件公开的类型 2.创建COM组件提供的类型的对象 3.调用执行方法 正确姿势 C#利用反射调用(后期绑定)PB编译的COM组件 C#调用COM组件 ...

随机推荐

  1. ChatCell

    import UIKit let chatCellHeight: CGFloat = 72 let chatCellInsetLeft =  chatCellHeight + 8 class Chat ...

  2. 【HDOJ】1561 The more, The Better

    树状DP. /* 1561 */ #include <iostream> #include <cstdio> #include <cstring> #include ...

  3. Java学习日记 集合

    一.接口Map<K,V>1.V put(K key, V value)2.int size()3.public class HashMap<K, V> implements M ...

  4. oracle连接进程数设置

    SQL> select count(*) from v$session #连接数SQL> Select count(*) from v$session where status='ACTI ...

  5. java—— 调用系统命令

    调用所在环境的命令 链接:http://blog.csdn.net/yy6060/article/details/6311916 1 import java.io.*; 2 class Exec{ 3 ...

  6. Jetty开发指导:框架

    Spring设置 你能嵌入Jetty到你的项目中,也能够使用差点儿全部的IoC类型框架,包含Spring.假设全部你想做的是在你的Spring中设置Jetty Server,那么以下的xml片段能够作 ...

  7. html 第一阶段 学习使用总结

    基本使用内容: <html> <head> <title>Title of the document</title> <link rel=&quo ...

  8. ListView 水平滑动 水平和竖直滑动

    效果 Activity public class MainActivity extends Activity {     @Override     protected void onCreate(B ...

  9. 使用多线程完成Socket

    public class Service { //服务器 public static void main(String[] args) { ServerSocket serverSocket=null ...

  10. 在公网(internet)上建立website时不能用http访问

    我们在internet的IDC提供的虚拟机上建了新的web site, 域名也从阿里巴巴那里得到二级域名,也经过映射到了虚机的IP, 在本机都可以用域名以Http方式访问,但在internet上的其它 ...