这个仅是为了培训做的一个小例子

public class DB     {

public static string GetClassName(Type type)

{

if (type == null)

throw new ArgumentException("参数type不能为空");

else{

if (type.HasAttribute<DBTableNameAttribute>())

return type.GetAttribute<DBTableNameAttribute>().Name;

else

return type.Name;

  }

}

public static T AddObject<T>(T o) where T :class

{

string tablename = GetClassName(typeof(T));

string fieldName;

object fieldValue;

string[] fieldNames;

object[] fieldValues;

System.Reflection.PropertyInfo[] Props = typeof(T).GetProperties();

fieldNames=new string[Props.Length ];

fieldValues =new object [Props.Length ];

string checkstr = "";

for (int i = 0; i < Props.Length; i++)

{

fieldName = Props[i].Name;

fieldValue = Props[i].GetValue(o, null);

if (fieldValue == null)                     continue;

fieldValue = CommonFunction.SafeSQL(fieldValue.ToString());

fieldNames[i] = fieldName;

fieldValues[i] = fieldValue;

object[] attributes = Props[i].GetCustomAttributes(false);

foreach (Attribute a in attributes)

{

//判断Attribute 中是否 为 UniqueColumnAttribute

if (a is UniqueColumnAttribute)

{

checkstr = "not exists(select * from " +tablename + " where " + fieldName  + "='" + fieldValue + "')";

}

}

}

if (checkstr != "")

{

checkstr = "if("+checkstr +")";

}

string insert = "" ,tail="";

insert = "insert into " + tablename + " (";

tail = "values(";

for (int i = 0; i < Props.Length; i++)

{

fieldName = fieldNames[i] ;

if (fieldName.ToUpper() == "ID") continue;

object  _fieldValue = fieldValues[i];

if (_fieldValue == null)

{ }

else

      {

insert += fieldName + ",";

tail += "'" + _fieldValue + "',";

}

}

insert = insert.Remove(insert.Length - 1);

tail = tail.Remove(tail.Length - 1);

string insertstr = insert + ")" + " " + tail + ")";

if (checkstr != "")

insertstr = checkstr +"begin "+ insertstr+" end";

insertstr+=" select @@identity"

SqlHelper link = new SqlHelper();

int r=  link.UpdateDataBase(insertstr);

if(r>0)     {

o.Id=r;

return o;

}

return null;

}

public static bool  DelObject<T>( int id) where T : class

{

if (id == 0) return false;

string tablename = GetClassName(typeof(T));

string insert = "";

insert =string.Format( "delete from {0} where id={1}",tablename,id)

SqlHelper link = new SqlHelper();

int r = link.UpdateDataBase(insert);

return true;

}

public static bool  DelObject<T>(T o) where T : class

{

string tablename = GetClassName(typeof(T));

string fieldName;

object fieldValue;

string[] fieldNames;

object[] fieldValues;

System.Reflection.PropertyInfo[] Props = typeof(T).GetProperties();

fieldNames = new string[Props.Length];

fieldValues = new object[Props.Length];

for (int i = 0; i < Props.Length; i++)

{

fieldName = Props[i].Name;

fieldValue = Props[i].GetValue(o, null);

fieldNames[i] = fieldName;

fieldValues[i] = fieldValue;

}

string str="";

for (int i = 0; i < Props.Length; i++)

{

fieldName = fieldNames[i];

string _fieldValue = fieldValues[i].ToString();

if (fieldName.ToUpper() == "ID")

{

str = "delete from " + tablename + " where id=" + _fieldValue ;

break;

}

}

if(!string.IsNullOrEmpty(str))

{

SqlHelper link = new SqlHelper();

int r = link.UpdateDataBase(str);

return true;

}

return false;

}

public static bool UpdateObject<T>(T o) where T : class

{

string tablename = GetClassName(typeof(T));

string fieldName;

object fieldValue;

string[] fieldNames;

object[] fieldValues;

System.Reflection.PropertyInfo[] Props = typeof(T).GetProperties();

fieldNames = new string[Props.Length];

fieldValues = new object[Props.Length];

for (int i = 0; i < Props.Length; i++)

{

if (Props[i].DeclaringType.IsValueType)

{

fieldName = Props[i].Name;

fieldValue = Props[i].GetValue(o, null);

fieldNames[i] = fieldName;

fieldValues[i] = fieldValue;

}

else

{

fieldNames[i] = null;

fieldValues[i] = null;

}

}

string str = "update "+tablename +" set ",where=" where id=";

int id = 0;

for (int i = 0; i < Props.Length; i++)

{

fieldName = fieldNames[i];

object  _fieldValue = fieldValues[i] ;

if (fieldName == null) continue;

if (fieldName.ToUpper() == "ID")

{

if (_fieldValue == null)

{

}

else

{

int.TryParse(_fieldValue.ToString(), out id);

//str = "delete from " + tablename + " where id=" + _fieldValue;

where += id.ToString();

}

//break;

}

else

{

if (_fieldValue == null)

{

}

else

str += fieldName +  "='" + _fieldValue.ToString() + "',";

}

}

if (id <= 0) return false;

str = str.Remove(str.Length - 1);

str += where;

SqlHelper link = new SqlHelper();

int r = link.UpdateDataBase(str);

return true;

}

public static T SelObject<T>(int id) where T : class

{

if (id <= 0) return null ;

string tablename = GetClassName(typeof(T));

string insert = "";

insert = "select * from " + tablename + " where id=" + id.ToString();

SqlHelper link = new SqlHelper();

DataTable dt = link.SelectDataBase(insert);

if (dt == null || dt.Rows.Count == 0) return null;

Type type = typeof(T);

Object obj = type.Assembly.CreateInstance(type.FullName);

System.Reflection.PropertyInfo[] Props = typeof(T).GetProperties();

for (int i = 0; i < Props.Length; i++)

{

Props[i].SetValue(obj, dt.Rows[0][Props[i].Name], null);

}

return (T)obj;

}

public static T SelObject<T>(BaseQuery query  ) where T : class

{

if (query==null )

return null;

string tablename = GetClassName(typeof(T));

if (tablename.EndsWith("Query"))

tablename = tablename.Replace("Query","");

string fieldName;

object fieldValue;

string[] fieldNames;

object[] fieldValues;

System.Reflection.PropertyInfo[] Props = query.GetType().GetProperties();

fieldNames = new string[Props.Length];

fieldValues = new object[Props.Length];

for (int i = 0; i < Props.Length; i++)

{

fieldName = Props[i].Name;

fieldValue = Props[i].GetValue(query, null);

fieldNames[i] = fieldName;

fieldValues[i] = fieldValue;

}

string insert = "",where="1=1";

insert = "select * from " + tablename + " where "  ;

int id = 0;

for (int i = 0; i < Props.Length; i++)

{

fieldName = fieldNames[i];

object _fieldValue = fieldValues[i];

if (fieldName.ToUpper() == "ID")

{

if (_fieldValue == null)

{ }

else

{

int.TryParse(_fieldValue.ToString(), out id);

//str = "delete from " + tablename + " where id=" + _fieldValue;

where +="Id="+ id.ToString();

}

//break;

}

else

{

if (_fieldValue == null)

{ }

else

{

if (string.IsNullOrEmpty(_fieldValue.ToString()))

{ }

else

where += " and " + fieldName + "='" + _fieldValue.ToString() + "'";

}

}

}

insert = insert + where;

SqlHelper link = new SqlHelper();

DataTable dt = link.SelectDataBase(insert);

if (dt == null || dt.Rows.Count == 0) return null;

Type type = typeof(T);

Object obj = type.Assembly.CreateInstance(type.FullName );

System.Reflection.PropertyInfo[] Props2 = typeof(T).GetProperties();

for (int i = 0; i < Props2.Length; i++)

{

Props2[i].SetValue(obj, dt.Rows[0][Props2[i].Name], null);

}

return (T)obj;

}

public static T SelObject<T>(string where) where T : class

{

if (string.IsNullOrEmpty(where)) )                 return null;

string tablename = GetClassName(typeof(T));

string insert = "";

insert = "select * from " + tablename + " where " + where;

SqlHelper link = new SqlHelper();

DataTable dt = link.SelectDataBase(insert);

if (dt == null || dt.Rows.Count == 0) return null;

Type type = typeof(T);

Object obj = type.Assembly.CreateInstance(type.FullName);

System.Reflection.PropertyInfo[] Props = typeof(T).GetProperties();

for (int i = 0; i < Props.Length; i++)

{

Props[i].SetValue(obj, dt.Rows[0][Props[i].Name], null);

}

return (T)obj;

}

public static List<T> ListObjects<T>(string where) where T : class

{

try

{

if (string.IsNullOrEmpty(where))

where = "1=1";

string tablename = GetClassName(typeof(T));

string insert = "";

insert = "select * from " + tablename + " where " + where;

SqlHelper link = new SqlHelper();

DataTable dt = link.SelectDataBase(insert);

if (dt == null || dt.Rows.Count == 0) return null;

Type type = typeof(T);

List<T> list = new List<T>();

for (int row = 0; row < dt.Rows.Count; row++)

{

Object obj = type.Assembly.CreateInstance(type.FullName );

System.Reflection.PropertyInfo[] Props = typeof(T).GetProperties();

for (int i = 0; i < Props.Length; i++)

{

Props[i].SetValue(obj, dt.Rows[row][Props[i].Name], null);

}

list.Add((T)obj);

}

return list;

}

catch

{

return null;

}

}

}

原创最简单的ORM例子的更多相关文章

  1. D2010 RTTI + Attribute 简单实现ORM

    还记得David I 今年四月来盛大时,被问及“反射机制能再做得好一点吗?我们想放弃RTTI”,David I 回答“这的确是需要考虑的地方,当然RTTI我们不会放弃的”.(这个白胡子的老哥哥还真很可 ...

  2. 使用Multiplayer Networking做一个简单的多人游戏例子-2/3(Unity3D开发之二十六)

    猴子原创,欢迎转载.转载请注明: 转载自Cocos2Der-CSDN,谢谢! 原文地址: http://blog.csdn.net/cocos2der/article/details/51007512 ...

  3. 使用Multiplayer Networking做一个简单的多人游戏例子-1/3(Unity3D开发之二十五)

    猴子原创,欢迎转载.转载请注明: 转载自Cocos2Der-CSDN,谢谢! 原文地址: http://blog.csdn.net/cocos2der/article/details/51006463 ...

  4. 一个简单的CORBA例子

    因为对CORBA分析的需要,这里写一个简单的CORBA例子.从JDK1.2开始,JDK中集成了ORB的实现,本例子使用了JDK1.7,对于JDK1.2+应该都没有问题.这个例子实现一个简单的加减乘除的 ...

  5. 菜鸟学习Hibernate——简单的一个例子

    一.Hibernate开发. 上篇博客已经为大家介绍了持久层框架的发展流程,持久层框架的种类. 为了能够使用Hibernate快速上手,我们先讲解一个简单的Hibernate应用实例hibernate ...

  6. 一个简单的ORM制作(SQL帮助类)

    一个简单的ORM制作大概需要以下几个类: SQL执行类 CURD操作类 其他酱油类 先从SQL执行类说起,可能会涉及数据库的迁移等问题,所以需要定义一个接口以方便迁移到其他数据库, 事务没提供命名,若 ...

  7. 轻松创建nodejs服务器(1):一个简单nodejs服务器例子

    这篇文章主要介绍了一个简单nodejs服务器例子,本文实现了一个简单的hello world例子,并展示如何运行这个服务器,需要的朋友可以参考下   我们先来实现一个简单的例子,hello world ...

  8. C#基础笔记---浅谈XML读取以及简单的ORM实现

    背景: 在开发ASP.NETMVC4 项目中,虽然web.config配置满足了大部分需求,不过对于某些特定业务,我们有时候需要添加新的配置文件来记录配置信息,那么XML文件配置无疑是我们选择的一个方 ...

  9. 使用Multiplayer Networking做一个简单的多人游戏例子-3/3(Unity3D开发之二十七)

    使用Multiplayer Networking做一个简单的多人游戏例子-1/3 使用Multiplayer Networking做一个简单的多人游戏例子-2/3 使用Multiplayer Netw ...

随机推荐

  1. java中的枚举类型

    枚举类型是那些字段由一组固定常量组成的类型.常见的例子有:东南西北四个方向,星期几等. 所有枚举类型都隐式继承java.lang.Enum类型,因为java不支持多重继承,所以枚举不能继承其他任何类. ...

  2. 【Alpha版本】冲刺阶段——Day 4

    我说的都队 031402304 陈燊 031402342 许玲玲 031402337 胡心颖 03140241 王婷婷 031402203 陈齐民 031402209 黄伟炜 031402233 郑扬 ...

  3. Mybatis 操作数据库的主键自增长

    本篇文章将研究mybatis 实现oracle主键自增的机制 首先我们看对于同一张student表,对于mysql,sql server,oracle中它们都是怎样创建主键的 在mysql中 crea ...

  4. Office 2013 Pro Plus Vol激活

    先确认自己是office2013 vol(大客户版),然后cmd(管理员)里面运行如下命令: cd "C:\Program Files\Microsoft Office\Office15&q ...

  5. GridView多表关联

    有些时候,需要多表关联查询,使用SqlDataProvider比较灵活 Controller中 use yii\data\SqlDataProvider; $dataProvider = new Sq ...

  6. Reveal使用步骤

    一.Reveal使用步骤 1.启动Reveal --> Help --> Show Reveal Library in Finder,拖动添加Reveal.framework到工程中. 选 ...

  7. Hadoop 学习笔记3 Develping MapReduce

    小笔记: Mavon是一种项目管理工具,通过xml配置来设置项目信息. Mavon POM(project of model). Steps: 1. set up and configure the ...

  8. 78. Android之 RxJava 详解

    转载:http://gank.io/post/560e15be2dca930e00da1083 前言 我从去年开始使用 RxJava ,到现在一年多了.今年加入了 Flipboard 后,看到 Fli ...

  9. [iOS 利用MapKit和CoreLocation框架打造精简的定位和导航]

    运行效果:            一.利用<CoreLocation/CoreLocation.h>定位 创建变量 CLLocationManager *locationManager , ...

  10. 手机卫士开发记录之json错误