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# 克隆

    详解 C# 克隆 在 C# 中,克隆指的是创建一个新对象,这个新对象和旧对象具有相同的属性和值。为了实现克隆,我们需要使用ICloneable接口。在本文中,我们将详细讲解如何使用 C# 克隆。 ICloneable 接口 ICloenable 是 C# 中用来定义克隆能力的接口,它只包含一个方法 Clone()。当实现这个接口时,需要实现 Clone 方法…

    C# 2023年6月1日
    00
  • ASP.NET 使用application与session对象写的简单聊天室程序

    ASP.NET是一种广泛使用的Web开发框架,为构建Web应用程序提供了丰富的工具和组件。其中,application对象和session对象是ASP.NET应用程序中重要的服务器端状态管理机制之一,用于在不同的用户之间和同一用户的多个请求之间共享数据。在此基础上,我们可以实现一些有趣的功能,比如简单的聊天室程序。 下面是ASP.NET使用applicati…

    C# 2023年5月31日
    00
  • c#中LINQ的基本用法(三)

    c#中LINQ的基本用法(三) 在C#中,LINQ(Language Integrated Query)是一种强大的查询语言,可以用于查询各种数据源,如数组、集合、数据库等。本文将介绍LINQ的基本用法,包括分组、聚合、排序和连接等。 分组 分组是指将数据按照某个属性进行分组,以便更好地统计和分析数据。在LINQ中,可以使用group关键字进行分组操作。 以…

    C# 2023年5月15日
    00
  • C#串口接收程序的实现

    C#串口接收程序的实现攻略 串口通信是一种常见的设备与计算机之间进行数据传输的方式。在C#中,我们可以使用SerialPort类来实现串口接收程序的实现。下面是实现串口接收程序的完整攻略: 1. 创建串口接收程序的项目 首先,我们需要创建一个新的C#项目。在Visual Studio中,可以通过选择“新建项目”并选择“控制台应用程序”来完成。在新建项目的过程…

    C# 2023年6月7日
    00
  • C#使用stackalloc分配堆栈内存和非托管类型详解

    关于“C#使用stackalloc分配堆栈内存和非托管类型详解”的完整攻略,下面是我提供的细致讲解。 1. stackalloc简介 stackalloc是C#语言的一种内存分配语法,可以用来在栈上分配存储空间。在使用stackalloc时,必须是将堆栈分配内存全部使用完毕之后才会自动释放,也就是说它分配的内存无法被回收。 使用stackalloc分配内存时…

    C# 2023年6月6日
    00
  • 详解ASP.NET Core中间件Middleware

    详解ASP.NET Core中间件Middleware攻略 ASP.NET Core中间件Middleware是一种用于处理HTTP请求和响应的组件。在本攻略中,我们将深入探讨ASP.NET Core中间件Middleware的工作原理,并提供两个示例说明。 中间件Middleware的工作原理 在ASP.NET Core中,中间件Middleware是一种…

    C# 2023年5月17日
    00
  • 详解.NET中string与StringBuilder在字符串拼接功能上的比较

    接下来我将详细讲解”.NET中string与StringBuilder在字符串拼接功能上的比较”。 什么是string和StringBuilder? string是C#中一种常见的字符串类型,它是不可变的,一旦被创建,就不能被修改。 StringBuilder是C#中的另一种字符串类型,它是可变的,可以进行直接修改。 字符串拼接 在实际的应用中,我们经常需要…

    C# 2023年6月8日
    00
  • c#保存窗口位置大小操作类(序列化和文件读写功能)

    下面我来详细讲解“c#保存窗口位置大小操作类(序列化和文件读写功能)”的完整攻略,具体步骤如下: 1. 在窗口类中添加成员变量 首先,在窗口类中添加两个成员变量,用于存储窗口的位置和大小信息,代码如下: private int x; private int y; private int width; private int height; 2. 重写OnCl…

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