C#数据访问层主类.(SqlHelper)SQLDataAccess.cs


C#数据访问层主类.(SqlHelper)SQLDataAccess.cs

顾名思义数据访问层是直接与数据库打交通了.下面这个类封装了一些常用的方法,简单实用.

using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Data.SqlClient;

namespace dal
{
   /// <summary>
   /// 数据访问层 by www.csframework.com 
   /// </summary>
   public class SQLDataAccess
   {
      //Sql Server连接字符串
      private string _ConnectionString = string.Empty;
      
      private static SQLDataAccess _Instance = null;
      
      //数据访问层实例<单件模式>
      public static SQLDataAccess Instance //实例
      {
         get
         {
            if (_Instance == null) _Instance = new SQLDataAccess();
            return _Instance;
         }
      }
      
      private SQLDataAccess()//私有构造器
      {
         _ConnectionString = "server=192.168.0.3;database=mydata;uid=sa;pwd=123;";
      }
      
      public SqlConnection createConnection()//创建一个连接对象
      {
         SqlConnection conn = new SqlConnection(_ConnectionString);
         conn.Open();
         return conn;
      }
      
      //获取一条记录
      public DataRow getDataRow(string sql)
      {
         DataTable dt = getSQLTable(sql, "MyTable");
         if (dt != null && dt.Rows.Count > 0)
         return dt.Rows[0];
         else
         return null;
      }
      
      //获取一条记录
      public DataRow getDataRow(SqlCommand command)
      {
         DataTable dt = getSQLTable(command, "MyTable");
         if (dt != null && dt.Rows.Count > 0)
         return dt.Rows[0];
         else
         return null;
      }
      
      //获取一个数据表
      public DataTable getSQLTable(string selectSQL, string tableName)
      {
         SqlConnection connection = this.createConnection();
         try
         {
            DataTable table = new DataTable(tableName);
            SqlDataAdapter adapter = new SqlDataAdapter(selectSQL, connection);
            adapter.Fill(table);
            this.CloseConnection(connection);
            return table;
         }
         catch (System.Exception ex)
         {
            this.CloseConnection(connection);
            throw ex;
         }
      }
      
      //获取一个数据表
      public DataTable getSQLTable(SqlCommand command, string tableName)
      {
         SqlConnection connection = command.Connection;
         try
         {
            if (command.Connection == null) command.Connection = this.createConnection();
            DataTable table = new DataTable(tableName);
            SqlDataAdapter adapter = new SqlDataAdapter(command);
            adapter.Fill(table);
            this.CloseConnection(connection);
            return table;
         }
         catch (System.Exception ex)
         {
            if (connection.State != ConnectionState.Closed) connection.Close();
            throw ex;
         }
      }
      
      //获取一个数据集
      public DataSet getDataset(string selectSQL)
      {
         SqlConnection connection = this.createConnection();
         try
         {
            DataSet ds = new DataSet();
            SqlDataAdapter adapter = new SqlDataAdapter(selectSQL, connection);
            adapter.Fill(ds);
            this.CloseConnection(connection);
            return ds;
         }
         catch (System.Exception ex)
         {
            this.CloseConnection(connection);
            throw ex;
         }
      }
      
      //获取一个数据集
      public DataSet getDataset(SqlCommand command)
      {
         SqlConnection connection = command.Connection;
         try
         {
            if (command.Connection == null) command.Connection = this.createConnection();
            DataSet ds = new DataSet();
            SqlDataAdapter adapter = new SqlDataAdapter(command);
            adapter.Fill(ds);
            this.CloseConnection(connection);
            return ds;
         }
         catch (System.Exception ex)
         {
            this.CloseConnection(connection);
            throw ex;
         }
      }
      
      //执行SQL语句.参数:sql语句,返回整数值为判断所影响的行数
      public int executeSQL(string cmdText)
      {
         int iValue = -1;
         SqlConnection connection = this.createConnection();
         try
         {
            SqlCommand command = new SqlCommand(cmdText, connection);
            iValue = command.ExecuteNonQuery();
            this.CloseConnection(connection);
            return iValue;
         }
         catch (System.Exception ex)
         {
            this.CloseConnection(connection);
            throw ex;
         }
      }
      
      //执行SQL语句.参数:sql带有参数的sql语句。如:where userid=@userid
      //返回整数值为判断所影响的行数
      public int executeSQL(string sql, params SqlParameter[] values)
      {
         SqlCommand cmd = new SqlCommand(sql);
         cmd.Parameters.AddRange(values);
         return executeSQL(cmd);
      }
      
      //执行SQL命令
      public int executeSQL(SqlCommand command)
      {
         SqlConnection connection = command.Connection;
         try
         {
            if (command.Connection == null) command.Connection = this.createConnection();
            int iValue = command.ExecuteNonQuery();
            this.CloseConnection(connection);
            return iValue;
         }
         catch (System.Exception ex)
         {
            this.CloseConnection(connection);
            throw ex;
         }
      }
      
      //执行SQL命令返回第一行第一列的值
      public object executeScalar(SqlCommand command)
      {
         SqlConnection connection = command.Connection;
         try
         {
            if (command.Connection == null) command.Connection = this.createConnection();
            object ret = command.ExecuteScalar();
            this.CloseConnection(connection);
            return ret;
         }
         catch (System.Exception ex)
         {
            this.CloseConnection(connection);
            throw ex;
         }
      }
      
      //执行SQL语句返回第一行第一列的值
      public object executeScalar(string cmdText)
      {
         SqlConnection connection = this.createConnection();
         try
         {
            SqlCommand command = new SqlCommand(cmdText, connection);
            object ret = command.ExecuteScalar();
            this.CloseConnection(connection);
            return ret;
         }
         catch (System.Exception ex)
         {
            this.CloseConnection(connection);
            throw ex;
         }
      }
      
      //关闭SQL连接
      private void CloseConnection(SqlConnection connection)
      {
         if (connection == null) return;
         if (connection.State != ConnectionState.Closed) connection.Close();
      }
      
   }
}

如何使用?通过SQLDataAccess.Instance实例访问成员方法.

public class Tester
{
   public void TestDAL()
   {
      //获取DataSet
      DataSet user = SQLDataAccess.Instance.getDataset("select * from users");
      
      //执行SQL statement
      int i = SQLDataAccess.Instance.executeSQL("delete users where userid=’csframework'");
      
      //返回一条记录
      DataRow row = SQLDataAccess.Instance.getDataRow("select * from users where userid=’csframework’");      
   }
}


另外提供一个Microsoft官方的SqlHepler类,不过这个类超巨大,很多功能用不了,只做参考.
版权声明:本文为开发框架文库发布内容,转载请附上原文出处连接
C/S框架网
上一篇:C#转换IList对象数组为byte数组.然后通过WebService传递
下一篇:C#内TextBox的Drog&Drop拖放操作
评论列表

发表评论

评论内容
昵称:
关联文章

C#数据访问.(SqlHelper)SQLDataAccess.cs
DAL - 单表数据字典数据访问C#代码
DAL - 主从表业务单据数据访问C#代码
无DAL数据访问提交单个表的数据
C#.Net C/S结构开发框架中数据访问(DAL)的作用
C/S开发框架的数据访问用LINQ吗?
开发数据访问DAL - MiniFramework蝇量框架 - Winform框架
Winform三架构教程,CS结构图及源码实例讲解
如何使用多数据库IDatabase接口以及数据访问应用
C# 使用设计模式构建通用数据库访问
CS系统三架构扩展支持WCF及策略模式应用(原创)
BLL - 单表数据字典业务逻辑C#代码
C/S开发框架教程:使用基础资料(数据字典)的DAL更新主从表(或多表)数据
C#.NET其他程序集访问Internal
C# 使用NPOI导入数据 NPOIHelper.cs
CS开发框架禁用窗体Toolbar的按钮
MdiTools.cs下载|CSFramework版本V5.0|C/S框架网
C/S开发框架DAL提交数据报错"外键值为空!"解决方案。
使用dalBaseDataDict提交单表数据
CSFramework.WebApiV3.数据(Data Layer)

热门标签
.NET5 .NET6 .NET7 APP Auth-软件授权注册系统 Axios B/S B/S开发框架 Bug Bug记录 C#加密解密 C#源码 C/S CHATGPT CMS系统 CodeGenerator CSFramework.DB CSFramework.EF CSFrameworkV1学习版 CSFrameworkV2标准版 CSFrameworkV3高级版 CSFrameworkV4企业版 CSFrameworkV5旗舰版 CSFrameworkV6.0 DAL数据访问层 Database datalock DbFramework Demo教学 Demo下载 DevExpress教程 DOM EF框架 Element-UI EntityFramework ERP ES6 Excel FastReport GIT HR IDatabase IIS JavaScript LINQ MES MiniFramework MIS NavBarControl Node.JS NPM OMS ORM PaaS POS Promise API Redis SAP SEO SQL SQLConnector TMS系统 Token令牌 VS2022 VSCode VUE WCF WebApi WebApi NETCore WebApi框架 WEB开发框架 Windows服务 Winform 开发框架 Winform 开发平台 WinFramework Workflow工作流 Workflow流程引擎 版本区别 报表 踩坑日记 操作手册 代码生成器 迭代开发记录 基础资料窗体 架构设计 角色权限 开发sce 开发技巧 开发教程 开发框架 开发平台 开发指南 客户案例 快速搭站系统 快速开发平台 秘钥 密钥 权限设计 软件报价 软件测试报告 软件简介 软件开发框架 软件开发平台 软件开发文档 软件体系架构 软件下载 软著证书 三层架构 设计模式 生成代码 实用小技巧 收钱音箱 数据锁 数据同步 微信小程序 未解决问题 文档下载 喜鹊ERP 喜鹊软件 系统对接 详细设计说明书 行政区域数据库 需求分析 疑难杂症 蝇量级框架 蝇量框架 用户管理 用户开发手册 用户控件 在线支付 纸箱ERP 智能语音收款机 自定义窗体 自定义组件 自动升级程序