自己写数据库访问ORM

数据库 SQL Server
目前,往上有很多优秀的ORM,但和Csla紧密结合还没找到合适的。出于需要,自己动手写了一个。主要优点在于,实现了直接通过DataReader填充业务类数据。IF使用简单,只要在业务类上标记特性TableClass、FieldDescription即可将业务类和数据库建立映射关系。

 下面看一个例子:

现在有一个用户信息的表:E-R图如下:

要实现该表的数据库新增、修改、查询功能,需要实现下面两个业务类:

  1. using Csla; 
  2. using IF.CslaCore; 
  3. using IF.OrmCore.DataSchema; 
  4. using System; 
  5. using System.Collections.Generic; 
  6. using System.ComponentModel; 
  7. using System.Linq; 
  8. using System.Text; 
  9. using System.Threading.Tasks; 
  10.  
  11. namespace IF.SysUser.Business 
  12.     [Serializable
  13.     [TableClass(FriendlyName="用户信息表",TableName="SYS_USER")] 
  14.     public class SysUser : IfBusiness<SysUser> 
  15.     { 
  16.         private static readonly PropertyInfo<string> SUR_IDProperty = RegisterProperty<string>(c => c.SUR_ID); 
  17.  
  18.         [DisplayName("SUR_ID")] 
  19.         [FieldDescription(IsPrimaryKey=true,ColumnName="SUR_ID",FriendlyName="SUR_ID",NeedUpdate=true)] 
  20.         public string SUR_ID { get; set; } 
  21.  
  22.         private static readonly PropertyInfo<string> UserNameProperty = RegisterProperty<string>(c => c.UserName); 
  23.         [DisplayName("登录名")] 
  24.         [FieldDescription(ColumnName="SUR_USERNAME",FriendlyName="登录名",NeedUpdate=true)] 
  25.         public string UserName { get; set; } 
  26.  
  27.  
  28.         private static readonly PropertyInfo<string> NameProperty = RegisterProperty<string>(c => c.Name); 
  29.         [DisplayName("姓名")] 
  30.         [FieldDescription(ColumnName="SUR_NAME",FriendlyName="姓名",NeedUpdate=true)] 
  31.         public string Name { get; set; } 
  32.  
  33.         private static readonly PropertyInfo<string> PasswordProperty = RegisterProperty<string>(c => c.Password); 
  34.         [DisplayName("密码")] 
  35.         [FieldDescription(ColumnName="SUR_PASSWORD",FriendlyName="密码",NeedUpdate=true)] 
  36.         public string Password { get; set; } 
  37.  
  38.         private static readonly PropertyInfo<string> LoginMacProperty = RegisterProperty<string>(c => c.LoginMac); 
  39.         [DisplayName("登录Mac地址")] 
  40.         [FieldDescription(ColumnName="SUR_LOGIN_MAC",FriendlyName="登录Mac地址",NeedUpdate=true)] 
  41.         public string LoginMac { get; set; } 
  42.  
  43.         private static readonly PropertyInfo<string> LoginIPProperty = RegisterProperty<string>(c => c.LoginIP); 
  44.         [DisplayName("登录IP")] 
  45.         [FieldDescription(ColumnName="SUR_LOGIN_IP",FriendlyName="登录IP",NeedUpdate=true)] 
  46.         public string LoginIP { get; set; } 
  47.  
  48.  
  49.         private static readonly PropertyInfo<DateTime?> LoginTimeProperty = RegisterProperty<DateTime?>(c => c.LoginTime); 
  50.         [DisplayName("登录时间")] 
  51.         [FieldDescription(ColumnName="SUR_LOGIN_TIME",FriendlyName="登录时间",NeedUpdate=true)] 
  52.         public DateTime? LoginTime { get; set; } 
  53.  
  54.         private static readonly PropertyInfo<DateTime?> LogoutTimeProperty = RegisterProperty<DateTime?>(c => c.LogoutTime); 
  55.         [DisplayName("登出时间")] 
  56.         [FieldDescription(ColumnName="SUR_LOGOUT_TIME",FriendlyName="登出时间",NeedUpdate=true)] 
  57.         public DateTime? LogoutTime { get; set; } 
  58.  
  59.         private static readonly PropertyInfo<DateTime?> LoginFailTimeProperty = RegisterProperty<DateTime?>(c => c.LoginFailTime); 
  60.         [DisplayName("登录失败时间")] 
  61.         [FieldDescription(ColumnName="SUR_LOGIN_FAIL_TIME",FriendlyName="登录失败时间",NeedUpdate=true)] 
  62.         public DateTime? LoginFailTime { get; set; } 
  63.  
  64.         private static readonly PropertyInfo<Int32?> LoginFailCountProperty = RegisterProperty<Int32?>(c => c.LoginFailCount); 
  65.         [DisplayName("登录失败次数")] 
  66.         [FieldDescription(ColumnName="SUR_LOGIN_FAIL_COUNT",FriendlyName="登录失败次数",NeedUpdate=true)] 
  67.         public Int32? LoginFailCount { get; set; } 
  68.  
  69.  
  70.         private static readonly PropertyInfo<bool?> LockFGProperty = RegisterProperty<bool?>(c => c.LockFG); 
  71.         [DisplayName("是否锁定")] 
  72.         [FieldDescription(ColumnName="SUR_LOCK_FG",FriendlyName="是否锁定",NeedUpdate=true)] 
  73.         public bool? LockFG { get; set; } 
  74.  
  75.         private static readonly PropertyInfo<bool?> DisableFGProperty = RegisterProperty<bool?>(c => c.DisableFG); 
  76.         [DisplayName("是否有效")] 
  77.         [FieldDescription(ColumnName="SUR_DISABLE_FG",FriendlyName="是否有效",NeedUpdate=true)] 
  78.         public bool? DisableFG { get; set; } 
  79.  
  80.  
  81.         #region 通用字段 
  82.  
  83.         private static readonly PropertyInfo<DateTime?> CreateTimeProperty = RegisterProperty<DateTime?>(c => c.CreateTime); 
  84.         [DisplayName("创建时间")] 
  85.         [FieldDescription(ColumnName="CreateTime",FriendlyName="创建时间",NeedUpdate=true)] 
  86.         public override DateTime? CreateTime { get; set; } 
  87.  
  88.         private static readonly PropertyInfo<DateTime?> LastUpdateTimeProperty = RegisterProperty<DateTime?>(c => c.LastUpdateTime); 
  89.         [DisplayName("***修改时间")] 
  90.         [FieldDescription(ColumnName="LastUpdateTime",FriendlyName="***修改时间",NeedUpdate=true)] 
  91.         public override DateTime? LastUpdateTime { get; set; } 
  92.  
  93.  
  94.  
  95.         public override void SetPrimaryKey(string key
  96.         { 
  97.             SUR_ID = key
  98.         } 
  99.         #endregion 
  100.     } 
  101.  
  102.     [Serializable
  103.     public class SysUserList : IfBusinessList<SysUserList, SysUser> 
  104.     { } 

现在就可以工作了:

全表检索数据方法:

  1. SysUserList selData = SysUserList.Fetch(); 

向数据库新增一条数据:

  1. SysUser.Business.SysUser user = new SysUser.Business.SysUser(); 
  2. user.UserName= "inaction"
  3. user.Name = "流砂"
  4. user.Password"superman"
  5. selData.Add(user); 
  6. selData.Save(); 

向数据库修改数据:

  1. var user = SysUserList.Fetch(c => c.UserName == "inaction"); 
  2. user.Password = "123456"
  3.  SysUserList list = new SysUserList { user }; 
  4.  list.Save(); 

以上代码就实现了对密码的修改。

特别说明:目前IF 只能通过SysUserList对象的Save方法保存数据。以后会实现通过业务类自身Save方法保存数据。

原文链接:http://www.cnblogs.com/nactioncsla/p/3439820.html

责任编辑:彭凡 来源: 51CTO
相关推荐

2011-03-03 11:07:57

Spring数据库访问ORM

2016-09-23 13:34:15

PythonORMsqlalchemy

2011-05-26 15:20:46

Oracle数据库导出

2011-03-16 17:26:22

动态数据库

2009-09-15 10:02:44

Linq to SQL

2021-06-10 13:50:55

代码开发数据库

2010-05-20 14:52:42

MySQL数据库

2009-07-02 09:35:02

hibernate访问

2023-11-02 08:56:59

ORMGORM

2009-12-29 11:15:45

ADO数据库

2018-07-13 09:20:30

SQLite数据库存储

2010-04-29 11:53:42

Oracle数据库

2011-04-13 14:07:17

OracleSybase数据库

2011-03-03 16:31:33

2011-03-07 17:35:09

JavaACCESS数据库

2011-05-19 11:33:38

数据库访问速度

2010-12-27 16:18:59

本地元数据库

2010-04-14 15:45:49

Oracle 数据库

2009-09-28 13:33:48

Hibernate访问

2009-08-12 14:27:36

访问MySQL数据库C# ODBC
点赞
收藏

51CTO技术栈公众号