using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace 封装泛型CRUD
{
    public class TeacherInfoDAL<T> : BaseDAL<T> where T : new()
    {
        public override T Add(T obj)
        {
            Console.WriteLine("TeacherInfoDAL添加了一个对象");
           return base.Add(obj);

}

public override int Del(T obj)
        {
            Console.WriteLine("TeacherInfoDAL删除了一个对象");
            return base.Del(obj);

}

public override T Update(T obj)
        {
            Console.WriteLine("TeacherInfoDAL更新了一个对象");
            return base.Update(obj);
        }

public override IList<T> QueryList(Func<T, bool> whereLambada)
        {
            Console.WriteLine("TeacherInfoDAL查询了系列个对象");
            return base.QueryList(whereLambada);
        }
    }
    public class UserInfoDAL<T> : BaseDAL<T> where T : new()
    {
        public override  T Add(T obj)
        {
            Console.WriteLine("UserInfoDAL添加了一个对象");
            base.Add(obj);
            return obj;

}

public override int Del(T obj)
        {
            Console.WriteLine("UserInfoDAL删除了一个对象");
           return  base.Del(obj);
          
        }

public override T Update(T obj)
        {
            Console.WriteLine("UserInfoDAL更新了一个对象");
            return base.Update(obj);
        }

public override IList<T> QueryList(Func<T, bool> whereLambada)
        {
            Console.WriteLine("UserInfoDAL查询了系列个对象");
          return  base.QueryList(whereLambada);
        }
    }

public class BaseDAL<T> where T : new()
    {
        public virtual T Add(T obj)
        {
           
            return obj;
        }

public virtual int Del(T obj)
        {
          
            return 0;
        }

public virtual T Update(T obj)
        {
           
            return new T();
        }

public virtual IList<T> QueryList(Func<T,bool> whereLambada )
        {

IList<T> list = new List<T>();
            foreach (var r in list)
            {
                if (whereLambada(r))
                {
                    list.Add(r);
                }
            }
            return list;
        }

}

public abstract class BaseBLL<T> where T : new()
    {
        public BaseDAL<T> basedal;

public virtual T Add(T obj)
        {
            Console.WriteLine("基本业务处理add");
            return new T();
        }

public virtual int Del(T obj)
        {
            Console.WriteLine("基本业务处理del");
            return 0;
        }

public virtual T Update(T obj)
        {
            Console.WriteLine("基本业务处理update");
           return new T();
        }

public virtual IList<T> QueryList(Func<T, bool> whereLambada)
        {
            Console.WriteLine("基本业务处理QueryList");
           return new List<T>();
        }

public abstract void setDAL( );

}

public class UserInfoBLL<T>:BaseBLL<T> where T : new()
    {
        public UserInfoBLL()
        {
            setDAL();
        }

public override T Add(T obj)
        {
            base.Add(obj);
            Console.WriteLine("UserInfoBLL务处理add");
            return basedal.Add(obj);
        }

public override int Del(T obj)
        {
            base.Del(obj);
            Console.WriteLine("UserInfoBLL务处理del");
          
            return basedal.Del(obj);
        }

public override T Update(T obj)
        {
            base.Update(obj);
            Console.WriteLine("UserInfoBLL务处理update");
            return basedal.Update(obj);
        }

public override IList<T> QueryList(Func<T, bool> whereLambada)
        {
            base.QueryList(whereLambada);
            Console.WriteLine("UserInfoBLL务处理querylist");
            return basedal.QueryList(whereLambada);
        }

public override void setDAL()
        {
            basedal=new UserInfoDAL<T>();
        }
    }

public class TeacheInfoBLL<T> : BaseBLL<T> where T : new()
    {
        public TeacheInfoBLL()
        {
            setDAL();
        }

public override void setDAL()
        {
            basedal=new TeacherInfoDAL<T>();
           
        }
        public override T Add(T obj)
        {
            base.Add(obj);
            Console.WriteLine("TeacheInfoBLL务处理add");
            return basedal.Add(obj);
        }

public override int Del(T obj)
        {
            base.Del(obj);
            Console.WriteLine("TeacheInfoBLL务处理del");

return basedal.Del(obj);
        }

public override T Update(T obj)
        {
            base.Update(obj);
            Console.WriteLine("TeacheInfoBLL务处理update");
            return basedal.Update(obj);
        }

public override IList<T> QueryList(Func<T, bool> whereLambada)
        {
            base.QueryList(whereLambada);
            Console.WriteLine("TeacheInfoBLL务处理querylist");
            return basedal.QueryList(whereLambada);
        }

}

class Program
    {
        static void Main(string[] args)
        {
            BaseBLL<Student> bll=new TeacheInfoBLL<Student>();
            Student student=new Student();
            student.StudentNo = 1;
            bll.Add(new Student());
            bll.Del(new Student());
            bll.Update(new Student());
            bll.QueryList(a => a.StudentNo != 0);
            Console.WriteLine("------------------------");
            BaseBLL<Teacher> bll2 = new UserInfoBLL<Teacher>();
            Teacher t = new Teacher();
            t.TeacherNO = 1;
            bll2.Add(t);
            bll2.Del(t);
            bll2.Update(t);
            bll2.QueryList(a => a.TeacherNO != 0);
            Console.ReadKey();
        }
    }

public class Student
    {
        public int StudentNo { get; set; }
        public string Name { get; set; }
        public string Sex { get; set; }
        public int Age { get; set; }
        public string Address { get; set; }
        public string Class { get; set; }
        public string DeptNO { get; set; }
    }

public class Teacher
    {
        public int TeacherNO { get; set; }
        public string Name { get; set; }
        public string Sex { get; set; }
        public int Age { get; set; }
        public string DeptNo { get; set; }
    }
}

关于简单的三层的简化(bll,dal,model)的封装这里全部都在一个文件主要在于明白意思的更多相关文章

  1. Web三层-UI/BLL/DAL/MODEL

    2013传智播客视频\视频\2013-05-28-EF\视频 创建4个程序集,添加引用,model添加映射, P01UI表现层--BLL+MODELP02BLL业务层--DAL+MODELP03DAL ...

  2. NHibernate框架与BLL+DAL+Model+Controller+UI 多层架构十分相似--『Spring.NET+NHibernate+泛型』概述、知识准备及介绍(一)

    原文://http://blog.csdn.net/wb09100310/article/details/47271555 1. 概述 搭建了Spring.NET+NHibernate的一个数据查询系 ...

  3. 【转】asp.net mvc(模式)和三层架构(BLL、DAL、Model)的联系与区别

    原文地址:http://blog.csdn.net/luoyeyu1989/article/details/8275866 首先,MVC和三层架构,是不一样的. 三层架构中,DAL(数据访问层).BL ...

  4. asp.net mvc(模式)和三层架构(BLL、DAL、Model)的联系与区别 转载自:http://blog.csdn.net/luoyeyu1989/article/details/8275866

    首先,MVC和三层架构,是不一样的. 三层架构中,DAL(数据访问层).BLL(业务逻辑层).WEB层各司其职,意在职责分离. MVC是 Model-View-Controller,严格说这三个加起来 ...

  5. 简单的三层asp.net webForm使用Ninject实现Ioc

    简单的三层asp.net webForm使用Ninject实现Ioc 在asp.net webform下使用Ninject的简单过程. 首先建立个项目,如下图,简单三层(PS:UI层要同时引用BLL. ...

  6. MVC中Model BLL层Model模型互转

    MVC中Model BLL层Model模型互转 一. 模型通常可以做2种:充血模型和失血模型,一般做法是模型就是模型,不具备方法来操作,只具有属性,这种叫做失血模型(可能不准确):具备对模型一定的简单 ...

  7. 简单解读linux的/proc下的statm、maps、memmap 内存信息文件分析【转】

    转自:https://blog.csdn.net/sctq8888/article/details/7398776 转载自:http://hi.baidu.com/deep_pro/blog/item ...

  8. 三层架构中bll层把datatable转换为实体model的理解

    看了很多人的项目,很多都是用到三层架构,其中BLL层中有一种将DataTable转换为实体的方法.一直没有明白为啥要这样做,今天特意去搜索了一下,如果没有答案我是准备提问,寻求解答了.还好找到一个相关 ...

  9. C#里面BLL、Model、DAL、UI层

    C# 三层架构分为:表现层(UI).业务逻辑层(BLL).数据访问层(DAL)再加上实体类库(Model) 1.实体类库(Model),主要存放数据库中的表字段. 操作: (1)先建立实体类库Mode ...

随机推荐

  1. 利用OCR文字识别+百度算法搜索,玩转冲顶大会、百万英雄、芝士超人等答题赢奖金游戏

    [先上一张效果图]: 一.原理: 其实原理很简单: 1.手机投屏到电脑: 2.截取投屏画面的题目部分,进行识别,得到题目和三个答案: 3.将答案按照一定的算法,进行搜索,得出推荐答案: 4.添加了一些 ...

  2. form表单序列化serialize-object.js

    <form class="form-horizontal" role="form" id="myform" action=" ...

  3. Bootstrap-Plugin:提示工具(Tooltip)插件

    ylbtech-Bootstrap-Plugin:提示工具(Tooltip)插件 1.返回顶部 1. Bootstrap 提示工具(Tooltip)插件 当您想要描述一个链接的时候,提示工具(Tool ...

  4. Ubantu 网卡绑定固定IP

    # The primary network interface auto eth0 #iface eth0 inet dhcp iface eth0 inet static address 192.1 ...

  5. 2018 Multi-University Training Contest 4-Problem B. Harvest of Apples

    由公式$S(n, m)=S(n - 1, m) + S(n - 1, m - 1) = 2 * S(n - 1, m) - C_{n-1}^{m}$ 莫队思想

  6. Mongodb第一步资料

    学习的时候收集了部分好文章,这个文章主要收集的是下载,安装的基本资料 官方http://docs.mongodb.org/manual/tutorial/install-mongodb-on-wind ...

  7. ES6系列_1之开发环境搭建

    前言: 1.es6的简单介绍: ECMAScript 6.0(以下简称 ES6)是 JavaScript 语言的下一代标准,已经在2015年6月正式发布了.它的目标,是使得 JavaScript 语言 ...

  8. 529. Minesweeper

    ▶ 扫雷的扩展判定.已知棋盘上所有点的情况(雷区 'M',已翻开空白区 'B',未翻开空白区 'E',数字区 '1' ~ '8'),现在给定一个点击位置(一定在空白区域),若命中雷区则将被命中的 M ...

  9. asp.net 不用控件,自动登录(用于和其他系统对接的时候,自动登录系统,用户体验好)

    if (System.Web.Security.Membership.ValidateUser("admin", "123456")) { //这句话很重要,他 ...

  10. oracle执行sql文件

    oracle执行sql文件 在PL/SQL中直接用command window执行就可以了: PL/SQL developer----->File------>New---->com ...