目前在需求确定了以后进行开发的步骤一般是这样的:建立数据表,建立model,构建数据操作层,最后在页面中进行调用。关于数据操作层,因为大量的操作都集中在增加、更新、删除等简易操作,而我之前的写法是每次建立model的时候就写一遍这样的方法,并且为Model中的字段赋值,而这花费了我大量的精力,于是我想找个方法,有没有能够在建立model以后自动识别数据库字段而进行增加、更新、删除等这些常用的基本方法呢?于是我找到了DBHelper.dll。目前这个组件在百度都可以进行下载。

首先先看一下我先前进行的数据库操作方法:

 public int Add(wymodel.WY_WapChannel model)
{
StringBuilder strSql = new StringBuilder();
strSql.Append("insert into wy_wapchannel (");
strSql.Append("title,wapid,state,orderid)");
strSql.Append(" values(");
strSql.Append("@title,@wapid,@state,@orderid)");
strSql.Append(";select scope_identity();");
SqlParameter[] parameters ={
new SqlParameter("@title",SqlDbType.VarChar,200),
new SqlParameter("@wapid",SqlDbType.Int),
new SqlParameter("@state",SqlDbType.Int),
new SqlParameter("@orderid",SqlDbType.Int)
};
parameters[0].Value = model.Title;
parameters[1].Value = model.WapId;
parameters[2].Value = model.State;
parameters[3].Value = model.OrderId; object obj = SQLHelper.GetSingle(strSql.ToString(), parameters);
if (obj == null)
return 0;
else
return Convert.ToInt32(obj);
}

  以上是我的插入语句,在这里我需要将model进行数据操作,进行赋值。而一旦我数据库中新增一个字段或者删除一个字段,这些语句和参数都需要进行修改,并且不仅插入语句需要修改,更新等其他语句都可能需要修改,灵活性不高。

现在,我引入了DBHelper.dll组件,并使用其自带方法进行数据库连接:

public static class DBF
{
public static readonly DBHelper.DBFactory dbWeiyun; static DBF()
{
dbWeiyun = new DBHelper.DBFactory(System.Configuration.ConfigurationManager.ConnectionStrings["WyConn"].ConnectionString);
}
}

  这里"WyConn"是在我的webconfig配置页面里面进行数据库连接的一个参数,通过此组件自带的DBFactory方法可以便利的进行不同数据库的连接操作。

完成了这一步以后,我就要将建好的model跟数据库进行映射了:

public class TableMappings
{
static TableMappings()
{
InitWeiyun();
}
public static DBHelper.TableMapping WY_BusinessActivity { get; private set; }
public static DBHelper.TableMapping WY_ShopGoods { get; private set; }
public static DBHelper.TableMapping WY_GoodsComment { get; private set; }
private static void InitWeiyun()
{
WY_BusinessActivity = new DBHelper.TableMapping(DBF.dbWeiyun, "[WY_BusinessActivity]");
WY_ShopGoods = new DBHelper.TableMapping(DBF.dbWeiyun, "[WY_ShopGoods]");
WY_GoodsComment = new DBHelper.TableMapping(DBF.dbWeiyun, "[WY_GoodsComment]");
}
}

  这里“[WY_BusinessActivity]”等均是数据库中的数据表。

映射完成以后,我需要进行插入操作只需要将参数传入即可,直接调用组件中的insert方法。

 public bool insertComment(wymodel.WY_GoodsComment model)
{
return wydal.TableMappings.WY_GoodsComment.Insert(model);
}

  这里需要注意一点的就是,如果在Model里出现了数据库中没有的字段,要在字段前加上[ModelProperty(true)]来避免映射:

public int goodsId { set; get; }
public int star { set; get; }
public string Comment { set; get; }
public string openID { set; get; }
public DateTime intime { set; get; }
/// <summary>
/// 0商品评论,1活动评论,2跳蚤市场,3兼职
/// </summary>
public int Ctype { set; get; }
/// <summary>
/// 非数据库数据 头像
/// </summary>
[ModelProperty(true)]
public string headimgurl { get; set; }
/// <summary>
/// 非数据库数据 昵称
/// </summary>
[ModelProperty(true)]
public string nickname { get; set; }

  总之,这个组件能够帮助我们对数据库的操作进行简化,而不必浪费大量的精力进行重复的操作。

数据层使用DBHelper.dll来减少工作量的更多相关文章

  1. CYQ.Data 开源数据层框架 官方下载

    CYQData 数据框架 介绍: CYQ.Data 是一款操作数据库用的数据框架:安全稳定.简洁易用.功能强大.性能优越.内置支持多数据库.多语言.RSS.AOP.事务等功能. 使用本框架进行开发,入 ...

  2. 【类库】私房干货.Net数据层方法的封装

    [类库]私房干货.Net数据层方法的封装 作者:白宁超 时间:2016年3月5日22:51:47 摘要:继上篇<Oracle手边常用70则脚本知识汇总>文章的发表,引起很多朋友关注.便促使 ...

  3. CYQ.Data 轻量数据层之路 优雅V1.4 现世 附API帮助文档(九)

    继上一版本V1.3版本发布到现在,时隔N天了:[V1.3版本开源见:CYQ.Data 轻量数据层之路 华丽V1.3版本 框架开源] N天的时间,根据各路网友的反映及自身的想法,继续修改优化着本框架,力 ...

  4. 【开源】OSharp框架解说系列(5.2):EntityFramework数据层实现

    OSharp是什么? OSharp是个快速开发框架,但不是一个大而全的包罗万象的框架,严格的说,OSharp中什么都没有实现.与其他大而全的框架最大的不同点,就是OSharp只做抽象封装,不做实现.依 ...

  5. 【开源】OSharp框架解说系列(5.1):EntityFramework数据层设计

    OSharp是什么? OSharp是个快速开发框架,但不是一个大而全的包罗万象的框架,严格的说,OSharp中什么都没有实现.与其他大而全的框架最大的不同点,就是OSharp只做抽象封装,不做实现.依 ...

  6. 23、ASP.NET MVC入门到精通——业务层和数据层父类及接口-T4模板

    本系列目录:ASP.NET MVC4入门到精通系列目录汇总 在上一篇中,我们已经把项目的基本框架搭起来了,这一篇我们就来实现业务层和数据层的父接口及父类. 1.我们先来定义一个业务层父接口IBaseB ...

  7. Spring+SpringMVC+MyBatis+easyUI整合优化篇(九)数据层优化-jdbc连接池简述、druid简介

    日常啰嗦 终于回到既定轨道上了,这一篇讲讲数据库连接池的相关知识,线程池以后有机会再结合项目单独写篇文章(自己给自己挖坑,不知道什么时候能填上),从这一篇文章开始到本阶段结束的文章都会围绕数据库和da ...

  8. Spring+SpringMVC+MyBatis+easyUI整合优化篇(十三)数据层优化-表规范、索引优化

    本文提要 最近写的几篇文章都是关于数据层优化方面的,这几天也在想还有哪些地方可以优化改进,结合日志和项目代码发现,关于数据层的优化,还是有几个方面可以继续修改的,代码方面,整合了druid数据源也开启 ...

  9. EF通用数据层封装类(支持读写分离,一主多从)

    浅谈orm 记得四年前在学校第一次接触到 Ling to Sql,那时候瞬间发现不用手写sql语句是多么的方便,后面慢慢的接触了许多orm框架,像 EF,Dapper,Hibernate,Servic ...

随机推荐

  1. DGIM

    http://blog.liulixiang.info/2011/04/05/dgim%E7%AE%97%E6%B3%95%EF%BC%9A%E4%BC%B0%E8%AE%A1%E6%BB%91%E5 ...

  2. 射频识别技术漫谈(29)——射频接口芯片TRF7960

    TRF7960系列是TI推出的载波为13.56MHz.支持ISO15693.ISO14443A/B和FeliCa协议的射频接口芯片.许多人更关心它能不能读写MF1卡片,就我的理解及实际验证,由于MF1 ...

  3. 实现将VirtualBox 虚拟机转换为KVM虚拟机的步骤

    原来在桌面上一直使用virtualbox虚拟机管理程序(VMM)构建虚拟机安装不同的操作系统,现在 研究linux下的KVM,能否将已经建立的virtualBox虚拟客户机(guest)转换为KVM虚 ...

  4. C功底挑战Java菜鸟入门概念干货(一)

    一.认识Java 1.Java 程序比较特殊,它必须先经过编译,然后再利用解释的方式来运行.  2.Byte-codes 最大的好处是——可越平台运行,可让“一次编写,处处运行”成为可能.  3.使用 ...

  5. Javascript 思维导图

    学习的道路就是要不断的总结归纳,好记性不如烂笔头,so,下面将po出8张javascript相关的思维导图. 思维导图小tips:思维导图又叫心智图,是表达发射性思维的有效的图形思维工具 ,它简单却又 ...

  6. tomcat的JK和JK2

    如今又開始配置JK2,想将Tomcat和apache,但Tomcat上已经不支持对于JK2的开发了,详情请看: Apache-Tomcat mod_jk2 aka JK2 15 November - ...

  7. Windows系统中使用WMI获取远程服务器的信息

    使用WMI获取远程服务器的状态 我做的项目里边主要包含两个内容: (1)对发布在服务器上的服务(IIS服务.WCF服务)是否可以正常访问: (2)获取服务器上的部分指标:如CPU.内存.磁盘空间信息等 ...

  8. ExtJs004define定义类

    Ext.onReady(function () { //在Ext中如何去定义一个类: Ext.define(className , properties , callback) Ext.define( ...

  9. BZOJ 1192 鬼谷子的钱袋

    题目如下 Description 鬼谷子非常聪明,正因为这样,他非常繁忙,经常有各诸侯车的特派员前来向他咨询时政.有一天,他在咸阳游历的时候,朋友告诉他在咸阳最大的拍卖行(聚宝商行)将要举行一场拍卖会 ...

  10. 【C++】基于socket的多线程聊天室(控制台版)

    以前学习socket网络编程和多线程编程的时候写的一个练手程序 聊天室基本功能: 1.用户管理:登录,注册,登出,修改用户名,修改密码 2.聊天室功能:群聊,私聊,获取在线用户列表,获取所有用户列表 ...