MicroOrm.Net(2) 基础及动态特性

MicroOrm.Net主页:

http://code.google.com/p/micro-orm-net/

MicroOrm.Net系列随便目录总览:

http://www.cnblogs.com/mapserver/archive/2012/04/07/2436129.html

 

在传统的orm中,我们操作Table的时候,必须先有Model的定义,但是在MicroOrm.Net中,我们可以不定义Model,来直接操作Table。

假如我们在db中有OrderDetail这样一张表:

CREATE TABLE [dbo].[OrderDetail](
	[OrderDetailId] [nvarchar](50) NOT NULL,
	[OrderId] [nvarchar](50) NULL,
	[ProductId] [nvarchar](50) NULL,
	[Qty] [int] NULL,
CONSTRAINT [PK_OrderDetail] PRIMARY KEY CLUSTERED 
(
	[OrderDetailId] ASC
)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]
) ON [PRIMARY]

 

在你的项目中引用MicroOrm.Net,修改项目的config文件,配置db的链接字符串:

<connectionStrings>
    <add name="db" connectionString="..."  providerName="System.Data.SqlClient"/>
</connectionStrings>

 

编写下面代码:

var db = Database.Open("db");
var od = db.OrderDetail.Query()
        .First();
string orderId = od.OrderId;
string productId = od.ProductId;

  

我们来分析下上面代码:

var db = Database.Open("db");   我们创建了一个db对象,此对象为DynamicObject。

var od = db.OrderDetail.Query().First();  因为db对象是一个DynamicObject,所以它的OrderDetail属性,在运行的时候,才会被解析并且和数据库里的OrderDetail表自动产生关联,Query方法是我们查询的一个基准方法,最后再返回表里的第一行记录。

string orderId = od.OrderId; 因为od也是DynamicObject,它的OrderId属性,也是在运行时来解析的。

 

当然如果你定义了Model,那么也能轻松的把DynamicObject转换为Model强类型对象:

public class OrderDetail 
{
        public string OrderDetailId { get; set; }
        public string OrderId { get; set; }
        public string ProductId { get; set; }
        public int Qty { get; set; }
}

// 方式1
OrderDetail od = db.OrderDetail.Query()
        .First()
     .To<OrderDetail>();

// 方式2
od = db.OrderDetail.Query()
      .First<OrderDetail>();

 

至此我们一个简单的Demo就完成了,我们没有定义Model,没有Model-Table Mapping,Orm也可以这么简单。

posted @ 2012-04-07 17:21  mapserver  阅读(1700)  评论(2编辑  收藏  举报