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

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. MVC认知路【点点滴滴支离破碎】【一】----新建数据库

    1.App_Data文件夹创建[SQL Server Compact Local Database *]数据库 2.添加链接字符串<add name="MovieDBContext&q ...

  2. 使用iframe标签结合springMvc做文件上传

    1.iframe.jsp <body> <h1>测试iframe文件上传</h1> <!-- 1.要求表单的target属性名称与iframe的name名字一 ...

  3. Maven的内置变量

    Maven内置变量说明: ${basedir} 项目根目录(即pom.xml文件所在目录) ${project.build.directory} 构建目录,缺省为target目录 ${project. ...

  4. C#查看各种变量的指针地址

    将项目的“可编译不安全代码”属性设置为true就可以了,方法如下:项目属性对话框->配置属性->生成->允许不安全代码块 namespace Pointer { struct XYZ ...

  5. js-处理千分符

      <html> <head> <title> JS千分位处理 </title> </head> <script> functi ...

  6. java基础2.0:Object、Class、克隆、异常编程

    Java编程中两个重要的类Object 和 Class及java异常编程 (1)是所有Java类(API提供的类.自定义类)的最终父类. (2)作用:在JVM管理对象中的过程中,有一套统一的类型检查和 ...

  7. C#-WinForm-打印控件

    打印控件 绘制如下窗体 一.PrintDocument -打印的基础  首先放置PrintDocument控件,双击事件PrintPage设置要打印的样式(李献策lxc) //第一步 设置打印属性 p ...

  8. 安装python-docx

    安装环境: windows 7 64位 python 3.4.2 64位 说明: 用pip install python-docx不行,当装lxml时出现错误,一直卡在那. 安装非官方的版本,如下图, ...

  9. dede使用方法----如何自定义字段

    我们在用dede做东西的时候,有时候需要添加一些dede里面没有的字段,有dede后台里面可以添加相关的自段,下面我就以如何给产品添加一个价格的字段来讲述一下如何给dede添加字段,并且调用它. 1. ...

  10. [日常训练]常州集训day5

    T1 Description 小$W$和小$M$一起玩拼图游戏啦~ 小$M$给小$M$一张$N$个点的图,有$M$条可选无向边,每条边有一个甜蜜值,小$W$要选$K$条边,使得任意两点间最多有一条路径 ...