复习了在学校的时候做的WinForm端的一个学生信息管理系统,用的三层架构,看了一下里面的数据优化类

这个类是用来把对数据库的操作封装成静态方法,增删改查的时候直接调用这个类,减少项目里代码的冗余和方便以后修改。

Dbhelper类代码如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Data.SqlClient;
using System.Data;
using Model;
namespace DAL
{
    class DBHelper
    {

        #region 获得连接对象 Connsql
        public static SqlConnection Connsql()
        {
            string sql = "server=.;database=vs;integrated security=sspi";
            SqlConnection conn = new SqlConnection(sql);
            return conn;
        }
        //执行 增加,删除,修改的sql语句
        #endregion

        #region 增加删除修改的sql语句执行方法  ExecuteNonQuery
        public static int ExecuteNonQuery(string sql,CommandType type,params SqlParameter[] sp)
        {
            SqlConnection conn = DBHelper.Connsql();
            conn.Open();

            SqlCommand sc = new SqlCommand(sql, conn);
            sc.CommandType = type;

            if(sp!=null)
            {
                foreach (SqlParameter p in sp)
                {
                    sc.Parameters.Add(p);
                }
            }
            int i = sc.ExecuteNonQuery();
            conn.Close();
            return i;
        }
        #endregion

        #region 数据库返回一个值时的sql语句执行方法
        public static Object ExecuteScalar(string sql,CommandType type, params SqlParameter[] paras)
        {
            SqlConnection conn = DBHelper.Connsql();
            conn.Open();
            SqlCommand  sc = new SqlCommand(sql,conn);
            sc.CommandType=type;

            if(paras!=null)
            {
            foreach(SqlParameter s in paras )
            {
            sc.Parameters.Add(s);
            }
            }
            object result = sc.ExecuteScalar();
            conn.Close();
            return result;
        }
        #endregion

        #region 数据库返回多行记录的执行方法
        public static SqlDataReader ExecuteDataReader(string sql,CommandType type,params SqlParameter[] paras)
        {
            SqlConnection conn = DBHelper.Connsql();
            conn.Open();
            SqlCommand sc = new SqlCommand(sql,conn);
            sc.CommandType = type;

            if (paras != null)
            {
                foreach (SqlParameter s in paras)
                {
                    sc.Parameters.Add(s);
                }
            }
            SqlDataReader dr = sc.ExecuteReader(CommandBehavior.CloseConnection);
            return dr;
        }
        #endregion

        #region 返回一个数据集时执行方法
        public static DataSet ExecuteDataSet(string sql,CommandType type,params SqlParameter [] paras)
        {
            SqlConnection conn = DBHelper.Connsql();
            conn.Open();
            SqlCommand sc = new SqlCommand(sql,conn);
            sc.CommandType = type;

            if (paras != null)
            {
                foreach(SqlParameter s in paras)
                {
                    sc.Parameters.Add(s);
                }
            }
            SqlDataAdapter sda = new SqlDataAdapter(sc);
            DataSet ds = new DataSet();
            sda.Fill(ds);
            return ds;
        }
        #endregion

    }
}

调用DbHelper类:

1.返回一个值:

 int result =(int)this.ExecuteScalar("select count(*) from UserAccount", CommandType.Text);

2.返回一个数据集(存放到Dataset):

   DataSet ds = ExecuteDataSet("select * from UserAccount", CommandType.Text);
   ];

3.返回一个数据集(存放到List),性能上比DataSet要好

  #region 将数据填充到List集合中
       public List<tbSpecialty> GettbSpecialty()
       {
           List<tbSpecialty> sp = new List<tbSpecialty>();
           SqlDataReader dr = DBHelper.ExecuteDataReader("select * from tbSpecialtyInfo", CommandType.Text);
               while(dr.Read())
               {
                   tbSpecialty tsp = new tbSpecialty();
                   tsp.SpecialtyName = dr["SpecialtyName"].ToString();
                   sp.Add(tsp);
               }
               dr.Close();
               return sp;
       }
       #endregion

4.增删改:

#region
       public int AddtbSpecialty(tbSpecialty sp)
       {
           string sql = "insert into tbSpecialtyInfo values(@name,@remark)";
           SqlParameter p1 = new SqlParameter("@name", sp.SpecialtyName);
           SqlParameter p2 = new SqlParameter("@remark",sp.Remark);
           int result = DBHelper.ExecuteNonQuery(sql, CommandType.Text, p1, p2);
           return result;
       }
       #endregion

.net 在数据访问层中写一个DBhelper优化类的更多相关文章

  1. ClownFish:比手写代码还快的通用数据访问层

    http://www.cnblogs.com/fish-li/archive/2012/07/17/ClownFish.html 阅读目录 开始 ClownFish是什么? 比手写代码还快的执行速度 ...

  2. 【2017-04-20】Ado.Net与面向对象结合架构中的数据访问层(实体类,数据访问类)

    开发项目三层架构:界面层.业务逻辑层.数据访问层 今天学习一下数据访问层,分为实体类和数据访问类 所有的类放在App_Code这个文件夹下边.养成一个好的习惯. 一.实体类 数据库中的表映射为一个类, ...

  3. servlet层调用biz业务层出现浏览器 500错误,解决方法 dao数据访问层 数据库Util工具类都可能出错 通过新建一个测试类复制代码逐步测试查找出最终出错原因

    package com.swift.jztk.servlet; import java.io.IOException; import javax.servlet.ServletException; i ...

  4. 随机获得MySQL数据库中100条数据方法 驾照题库项目 MVC架构 biz业务层的实现类 根据考试类型rand或order通过dao数据访问层接口得到数据库中100或全部数据

    package com.swift.jztk.biz; import java.util.Collections; import java.util.Comparator; import java.u ...

  5. 【Filter 不登陆无法访问】web项目中写一个过滤器实现用户不登陆,直接给链接,无法进入页面的功能

    在web项目中写一个过滤器实现用户不登陆,直接给链接,无法进入页面,而重定向到登陆界面的功能. 项目是用springMVC+spring+hibernate实现 (和这个没有多大关系) 第一步: 首先 ...

  6. 使用Ninject+Moq在单元测试中抽象数据访问层

    一.测试方法的业务逻辑时,通常都需要从数据库读取测试数据,但是每次初始化数据库数据都很麻烦,也会影响到其它业务对数据的访问,怎样抽象数据访问层呢?就是用Moq去模拟数据访问的逻辑     二.步骤如下 ...

  7. 【Hades】ades是一个开源库,基于JPA和Spring构建,通过减少开发工作量显著的改进了数据访问层的实现

    几乎每个应用系统都需要通过访问数据来完成工作.要想使用领域设计方法,你就需要为实体类定义和构建资源库来实现领域对象的持久化.目前开发人员经常使用JPA来实现持久化库.JPA让持久化变得非常容易,但是仍 ...

  8. 企业级应用架构(三)三层架构之数据访问层的改进以及测试DOM的发布

    在上一篇我们在宏观概要上对DAL层进行了封装与抽象.我们的目的主要有两个:第一,解除BLL层对DAL层的依赖,这一点我们通过定义接口做到了:第二,使我们的DAL层能够支持一切数据访问技术,如Ado.n ...

  9. 数据访问层的改进以及测试DOM的发布

    数据访问层的改进以及测试DOM的发布 在上一篇我们在宏观概要上对DAL层进行了封装与抽象.我们的目的主要有两个:第一,解除BLL层对DAL层的依赖,这一点我们通过定义接口做到了:第二,使我们的DAL层 ...

随机推荐

  1. 认识WinDbg

    WinDbg学习笔记(一)--认识WinDbg 一.前言    本人学习WinDbg已经有好几天了,虽说技术掌握的还不太熟练,不过也总算是入门了在学习WinDbg的过程中,觉得WinDbg真的比Oll ...

  2. 程序处理数据库中值字段值为null的查询显示

    1.如果你做了一个简单的注册界面,需要用户进行注册,但有些项是不必要填的,当用户完成注册时,数据库表中的相应字段的值会写入null,但如何将查询的字段的值null显示出来? 2.首先我们学习一下如何向 ...

  3. jQuery判断浏览器类型

    if ($.browser.msie) { alert("IE浏览器"); } else if ($.browser.opera) { alert("opera浏览器&q ...

  4. 新手教程:wordpress博客安装图文教导

    每一个建立博客的新朋友,当准备好域名和主机后,不知道怎么安装博客,我刚建立昆明SEO的时候,也费了很多时间,终于搭建成功,下面是我一步一步实战得来的总结. 第一步:域名解析,根据域名注册商不同,解析操 ...

  5. CSS:CSS学习总结

    CSS:CSS学习总结 背景 CSS是一种声明式的语言,学好CSS的难度甚至大于学好一门服务器语言(我个人的感觉),这周在学习CSS,就记录一下学习经验. 1.规则声明顺序 因为CSS的样式具备层叠性 ...

  6. IS动态左侧菜单-01

    <%@ Page Language="C#" CodeFile="Default3.aspx.cs" Inherits="Default3&qu ...

  7. JAVA小知识点-Finally和Return的执行关系

    如果Try和Catch中存在return语句的时候Finally内的语句是否会执行,执行的时候对结果又有什么影响呢?我写了个例子来试验这个问题: public static Map<String ...

  8. 为Exchange 2007 SCC 启用 SCR 副本-供需要的人使用!

    SCC 已经部署完整,接下来我们必须防范本地站点如果出现了完全的损坏怎么办? Exchange 2007 SP1 提供了另外一种高可用的方式,就是基于我们的SCR 模型,SCR 模型是基于SCC 本地 ...

  9. UVa1003-Cutting sticks

    试题描述 将一段木棒按要求切割,每次切割都要付出与木棒长度相同的代价,求最小代价切割. (多组数据) 输入描述 长度L. 切割点数n(n<=50). n个切割点. 输出描述 "The ...

  10. 学习新手给Android新手的一些学习建议

    时间紧张,先记一笔,后续优化与完善. Shamoo做Android开辟已有一年了,对Android开辟也有一点点了解.上面就给Android新手说说我对Android浅面的意识和一点建议吧,知道的大牛 ...