C#封装DBHelper类

下面是我对“C#封装DBHelper类”的完整攻略:

第一步:创建封装类

首先,我们需要创建一个名为DBHelper的类,这个类将会是一个对应于一个数据库连接的封装,提供了一系列的方法来操作数据库。这个类可以采用单例模式,确保整个应用程序只会有一个数据库连接对象。以下是一个简单的DBHelper类的示例:

using System;
using System.Data;
using System.Data.SqlClient;

// 单例模式
public sealed class DBHelper
{
    private static string connectionString = "Data Source=yourServer;Initial Catalog=yourDBName;User ID=yourUsername;Password=yourPassword;";
    private static DBHelper instance = null;

    // 私有构造函数
    private DBHelper() {}

    // 获取DBHelper单例
    public static DBHelper GetInstance()
    {
        if (instance == null)
        {
            instance = new DBHelper();
        }
        return instance;
    }

    // 连接对象
    public SqlConnection Connection
    {
        get
        {
            SqlConnection conn = new SqlConnection(connectionString);
            conn.Open();
            return conn;
        }
    }

    // 查询
    public DataTable ExecuteQuery(string sql)
    {
        using (SqlConnection conn = Connection)
        {
            SqlDataAdapter adapter = new SqlDataAdapter(sql, conn);
            DataTable dataTable = new DataTable();
            adapter.Fill(dataTable);
            return dataTable;
        }
    }

    // 修改
    public int ExecuteNonQuery(string sql)
    {
        using (SqlConnection conn = Connection)
        {
            SqlCommand command = new SqlCommand(sql, conn);
            return command.ExecuteNonQuery();
        }
    }
}

第二步:使用封装类

在创建好封装类之后,就可以在代码中使用类中提供的方法来操作数据库了。下面是两个使用封装类的示例:

示例1:查询方法

DBHelper db = DBHelper.GetInstance();
string sql = "SELECT * FROM users WHERE username='admin'";
DataTable dt = db.ExecuteQuery(sql);
foreach (DataRow row in dt.Rows)
{
    Console.WriteLine("{0} {1}", row["id"], row["username"]);
}

示例2:执行SQL语句

DBHelper db = DBHelper.GetInstance();
string sql = "UPDATE users SET username='new_admin' WHERE id=1";
int rows = db.ExecuteNonQuery(sql);
Console.WriteLine("受影响的行数:{0}", rows);

以上就是C#封装DBHelper类的完整攻略了,希望能对你有所帮助。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:C#封装DBHelper类 - Python技术站

(0)
上一篇 2023年5月31日
下一篇 2023年5月31日

相关文章

  • C#语言async await工作原理示例解析

    下面是详细讲解“C#语言async await工作原理示例解析”的完整攻略,包括工作原理和示例说明。 C#语言async await工作原理示例解析 async await原理 async和await是C#5.0提供的一种异步编程方式,在处理对IO操作、CPU密集型操作等任务时都可以提供性能的提升。async关键字会告诉编译器当前的方法是一个异步方法,而aw…

    C# 2023年6月6日
    00
  • asp.NET中实现文件的压缩和解压(3种方式)

    下面就详细讲解一下“asp.NET中实现文件的压缩和解压(3种方式)”的完整攻略。在实现文件的压缩和解压功能的过程中,我们可以通过三种方式来实现,包括使用ICSharpCode.SharpZipLib库、使用System.IO.Compression命名空间以及使用DotNetZip库。 一、使用ICSharpCode.SharpZipLib库 使用这种方式…

    C# 2023年6月3日
    00
  • C#比较二个数组并找出相同或不同元素的方法

    针对“C#比较二个数组并找出相同或不同元素的方法”的完整攻略,以下是具体步骤: 步骤一:创建两个数组 首先,我们需要创建两个数组,来保存要进行比较的数据。可以使用 int[] 或者 string[] 等类型,以下是示例代码: int[] arr1 = new int[] {1, 2, 3, 4, 5}; int[] arr2 = new int[] {3, …

    C# 2023年6月7日
    00
  • C#用委托BeginInvoke做异步线程

    下面是C#用委托BeginInvoke做异步线程的完整攻略: 委托和异步线程 委托(Delegate)是C#中非常重要的概念之一。它是一种类型,允许我们在定义方法的时候,把该方法的引用传递给其他的方法,这样其他的方法就可以“调用”该方法了。委托本身就是一个指针,只不过是用来指向方法的,因此有时候也称之为“方法指针”。 异步线程指的是,我们在执行某些任务时,不…

    C# 2023年6月7日
    00
  • C#常用目录文件操作类实例

    C#常用目录文件操作类实例 在C#的编程过程中,我们需要对文件和目录进行操作。为了方便开发,C#提供了一些常用的目录文件操作类。本文将详细介绍这些类的使用方法,并给出两个实例。 目录操作类 Directory类 Directory类提供了很多操作目录的方法,例如创建、删除、复制和移动目录等。 创建目录 创建目录的方法为: Directory.CreateDi…

    C# 2023年5月15日
    00
  • C#实现简单俄罗斯方块

    C#实现简单俄罗斯方块 简介 俄罗斯方块是经典的休闲益智游戏之一,玩家需要操作方块进行移动、旋转使其落到底部并消除行。而我们可以通过C#语言来实现这个小游戏。 前置知识 在开始之前,需要具备一定的C#编程基础,以及对屏幕绘制和输入处理有一定的了解。 实现步骤 定义类 我们需要定义一个TetrisBlock类来表示方块,同时定义一个TetrisGame类来控制…

    C# 2023年6月6日
    00
  • EF Core项目中不同数据库需要的安装包介绍

    下面是EF Core项目中不同数据库需要的安装包介绍的完整攻略。 1. MySQL数据库 第一步:添加依赖 在创建EF Core项目时,需要添加MySql.Data.EntityFrameworkCore这个NuGet依赖,它是与MySQL数据库连接库一起使用的。可以在NuGet 包管理器中搜索MySql.Data.EntityFrameworkCore并将…

    C# 2023年6月3日
    00
  • c# 如何实现web打印插件

    要实现 Web 打印插件,首先需要了解什么是 Web 打印。Web 打印是指通过 Web 端打印文档或网络中的页面的过程。而 Web 打印插件是指一种浏览器插件,可以安装在用户的本地计算机上,用来打印由 Web 服务器生成的文档或 Web 页面。 在 C# 中实现 Web 打印插件的关键是通过.NET Framework创建一个 ActiveX 控件(操作系…

    C# 2023年6月6日
    00
合作推广
合作推广
分享本页
返回顶部