Robin's Blog

记录 积累 学习 成长

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::

这个三层不像MVC框架,因为只是业界的规范,所以理论上分开3层就可以了。

首先建立新的解决方案,建立类库Models,BLL,DAL,还有新建个网站WebForm,

如图

这个层次结构比较清晰的。Models层的edmx是如何建立的呢,接着看下面:

这里新建个项目,在安装的模版选择

ADO.NET Entity Data Model,然后是导航式向导,最后就可以建立了如图一的ORM框架映射了。如果说Java有hibernate,那么.net这个也可以算类似的框架了。

然后看看service层我们是如何操作数据库的:


using System;
using System.Collections.Generic;
using System.Linq;
using System.ComponentModel;
using System.Text;
using System.Web;
using System.Data;
using Models;
using System.Data.Linq;
using System.Data.EntityModel;
using System.Data.EntityClient;
using System.Data.Entity;

namespace DAL
{
    
public static partial class TypesService
    {
        
private static CnaWineEntities db = new CnaWineEntities();

        
private static bool SaveChangesWithDB()
        {
            
if (db.SaveChanges() > 0)
            {
                
return true;
            }
            
else
            {
                
return false;
            }
        }

        
public static bool InsertEntity(Types type)
        {
            db.AddToTypes(type);
            
return SaveChangesWithDB();
        }

        
public static bool DeleteEntity(Types type)
        {
            db.DeleteObject(type);
            
return SaveChangesWithDB();
        }

        
public static bool DeleteEntityByKey(int id)
        {
            Types type 
= db.Types.Where(c => c.Id == id).SingleOrDefault();
            db.DeleteObject(type);
            
return SaveChangesWithDB();
        }

        
public static bool ModifyEntity(Types type)
        {
            
return SaveChangesWithDB();
        }

        
public static IList<Types> GetAllEntities()
        {
            
return db.Types.ToList();
        }

        
public static Types FetchEntityByKey(int id)
        {
            
return db.Types.Where(c => c.Id == id).SingleOrDefault();
        }
    }
}

这里部分代码没测试过的,例如有人说single方法支持不太好,可能会报错。这里先写原理吧。具体再调整。方法调整好后,可以利用codesmith等工具,生成自己的DAL,BLL模版,实现了EDM+三层结构方式。那DAL层如何写呢,这里也列举一下:


using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Text;
using System.Web;
using System.Data;
using Models;
using DAL;
using System.Data.Linq;
using System.Data.EntityModel;
using System.Data.EntityClient;
using System.Data.Entity;

namespace BLL
{
    [DataObject]
    
public static partial class TypesManager
    {
        [DataObjectMethod(DataObjectMethodType.Insert)]
        
public static bool InsertEntity(Types type)
        {
            
return TypesService.InsertEntity(type);
        }

        [DataObjectMethod(DataObjectMethodType.Delete)]
        
public static bool DeleteEntity(Types type)
        {
            
return TypesService.DeleteEntity(type);
        }

        [DataObjectMethod(DataObjectMethodType.Delete)]
        
public static bool DeleteEntityByKey(int id)
        {
            
return TypesService.DeleteEntityByKey(id);
        }

        [DataObjectMethod(DataObjectMethodType.Update)]
        
public static bool ModifyEntity(Types type)
        {
            
return TypesService.ModifyEntity(type);
        }

        [DataObjectMethod(DataObjectMethodType.Select)]
        
public static IList<Types> GetAllEntities()
        {
            
return TypesService.GetAllEntities();
        }

        [DataObjectMethod(DataObjectMethodType.Select)]
        
public static Types FetchEntityByKey(int id)
        {
            
return TypesService.FetchEntityByKey(id);
        }
    }
}

 


//这里是页面的后台代码,只是普通的绑定而已
public partial class _Default : System.Web.UI.Page 
{
    
protected void Page_Load(object sender, EventArgs e)
    {
        
if (!IsPostBack) {
            GridView1.DataSource 
= TypesManager.GetAllEntities();
            GridView1.DataBind();
        }
    }
}

最后,记得在web.config配置连接字符串,把app.config里面的般过去就可以了。Linq to sql好像不用配置那个,web层不直接引用不用配也可以。反正是报错了有可能是这个配置问题。

然后一切正常,按ASP.net的写法开始写项目吧

posted on 2009-11-30 16:37  Robin99  阅读(2448)  评论(0编辑  收藏  举报