关于简单的三层的简化(bll,dal,model)的封装这里全部都在一个文件主要在于明白意思
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)的封装这里全部都在一个文件主要在于明白意思的更多相关文章
- Web三层-UI/BLL/DAL/MODEL
2013传智播客视频\视频\2013-05-28-EF\视频 创建4个程序集,添加引用,model添加映射, P01UI表现层--BLL+MODELP02BLL业务层--DAL+MODELP03DAL ...
- NHibernate框架与BLL+DAL+Model+Controller+UI 多层架构十分相似--『Spring.NET+NHibernate+泛型』概述、知识准备及介绍(一)
原文://http://blog.csdn.net/wb09100310/article/details/47271555 1. 概述 搭建了Spring.NET+NHibernate的一个数据查询系 ...
- 【转】asp.net mvc(模式)和三层架构(BLL、DAL、Model)的联系与区别
原文地址:http://blog.csdn.net/luoyeyu1989/article/details/8275866 首先,MVC和三层架构,是不一样的. 三层架构中,DAL(数据访问层).BL ...
- asp.net mvc(模式)和三层架构(BLL、DAL、Model)的联系与区别 转载自:http://blog.csdn.net/luoyeyu1989/article/details/8275866
首先,MVC和三层架构,是不一样的. 三层架构中,DAL(数据访问层).BLL(业务逻辑层).WEB层各司其职,意在职责分离. MVC是 Model-View-Controller,严格说这三个加起来 ...
- 简单的三层asp.net webForm使用Ninject实现Ioc
简单的三层asp.net webForm使用Ninject实现Ioc 在asp.net webform下使用Ninject的简单过程. 首先建立个项目,如下图,简单三层(PS:UI层要同时引用BLL. ...
- MVC中Model BLL层Model模型互转
MVC中Model BLL层Model模型互转 一. 模型通常可以做2种:充血模型和失血模型,一般做法是模型就是模型,不具备方法来操作,只具有属性,这种叫做失血模型(可能不准确):具备对模型一定的简单 ...
- 简单解读linux的/proc下的statm、maps、memmap 内存信息文件分析【转】
转自:https://blog.csdn.net/sctq8888/article/details/7398776 转载自:http://hi.baidu.com/deep_pro/blog/item ...
- 三层架构中bll层把datatable转换为实体model的理解
看了很多人的项目,很多都是用到三层架构,其中BLL层中有一种将DataTable转换为实体的方法.一直没有明白为啥要这样做,今天特意去搜索了一下,如果没有答案我是准备提问,寻求解答了.还好找到一个相关 ...
- C#里面BLL、Model、DAL、UI层
C# 三层架构分为:表现层(UI).业务逻辑层(BLL).数据访问层(DAL)再加上实体类库(Model) 1.实体类库(Model),主要存放数据库中的表字段. 操作: (1)先建立实体类库Mode ...
随机推荐
- 利用OCR文字识别+百度算法搜索,玩转冲顶大会、百万英雄、芝士超人等答题赢奖金游戏
[先上一张效果图]: 一.原理: 其实原理很简单: 1.手机投屏到电脑: 2.截取投屏画面的题目部分,进行识别,得到题目和三个答案: 3.将答案按照一定的算法,进行搜索,得出推荐答案: 4.添加了一些 ...
- form表单序列化serialize-object.js
<form class="form-horizontal" role="form" id="myform" action=" ...
- Bootstrap-Plugin:提示工具(Tooltip)插件
ylbtech-Bootstrap-Plugin:提示工具(Tooltip)插件 1.返回顶部 1. Bootstrap 提示工具(Tooltip)插件 当您想要描述一个链接的时候,提示工具(Tool ...
- Ubantu 网卡绑定固定IP
# The primary network interface auto eth0 #iface eth0 inet dhcp iface eth0 inet static address 192.1 ...
- 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}$ 莫队思想
- Mongodb第一步资料
学习的时候收集了部分好文章,这个文章主要收集的是下载,安装的基本资料 官方http://docs.mongodb.org/manual/tutorial/install-mongodb-on-wind ...
- ES6系列_1之开发环境搭建
前言: 1.es6的简单介绍: ECMAScript 6.0(以下简称 ES6)是 JavaScript 语言的下一代标准,已经在2015年6月正式发布了.它的目标,是使得 JavaScript 语言 ...
- 529. Minesweeper
▶ 扫雷的扩展判定.已知棋盘上所有点的情况(雷区 'M',已翻开空白区 'B',未翻开空白区 'E',数字区 '1' ~ '8'),现在给定一个点击位置(一定在空白区域),若命中雷区则将被命中的 M ...
- asp.net 不用控件,自动登录(用于和其他系统对接的时候,自动登录系统,用户体验好)
if (System.Web.Security.Membership.ValidateUser("admin", "123456")) { //这句话很重要,他 ...
- oracle执行sql文件
oracle执行sql文件 在PL/SQL中直接用command window执行就可以了: PL/SQL developer----->File------>New---->com ...