写一个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组件 ...
随机推荐
- KEIL C51中的_at_关键字
绝对位置变量 变量可以在你的C程序中的绝对内存地址位于源模块使用_at_关键字.此功能的用法是: 类型 _ memory_space _ 变量名 _at _ 常数 ; 其中:memory_space ...
- KEIL C编译器常见警告与错误信息的解决办法
对于函数的自变量.局部变量和全局变量声明如果没有指定内存类型,则内存模式将成为内定的内存类型.如果指定了内存类型的变量,则不理会内存模式,完全有所指定的内存类型为主. SMALL模式:小模式 ...
- 【转】JAVA字符串格式化-String.format()的使用
原文网址:http://blog.csdn.net/lonely_fireworks/article/details/7962171 常规类型的格式化 String类的format()方法用于创建格式 ...
- (转载)python多行注释
(转载)http://www.cnblogs.com/pylemon/archive/2011/05/23/2054090.html python本身不带多行注释,编辑时每行敲一个“#”相当的不方便, ...
- Palindrome Partitioning——LeetCode
Given a string s, partition s such that every substring of the partition is a palindrome. Return all ...
- HDOJ 1285 确定比赛名次(拓扑排序)
Problem Description 有N个比赛队(1<=N<=500),编号依次为1,2,3,....,N进行比赛,比赛结束后,裁判委员会要将所有参赛队伍从前往后依次排名,但现在裁判委 ...
- cannot be resolved to a type in same package 问题解决
在 STS 上,一个类引用在相同 package 中另一个类,但是报 cannot be resolved to a type 错误. 解决方法 : Alternatively, you can hi ...
- UVA127- "Accordian" Patience(模拟链表)
"Accordian" Patience You are to simulate the playing of games of ``Accordian'' patience, t ...
- HDU2048(标准错排问题)
错排问题. 将错排方法数记为D(n). 1. 把第n个元素放在一个位置,比如k,有n-1种方法. 2. 编号为k的元素有两种放法. <1> 把它放到位置n.那么对于剩下的n-2个元素,就有 ...
- Controlling How NSThread and NSRunLoop Exit
http://shaheengandhi.com/controlling-thread-exit/ While most concurrency can be dealt with by using ...