首页 >后端开发 >C++ >如何使用 SqlCommand 在 C# 中执行直接 SQL 查询?

如何使用 SqlCommand 在 C# 中执行直接 SQL 查询?

DDD
DDD原创
2025-01-05 12:50:48418浏览

How to Execute Direct SQL Queries in C# Using SqlCommand?

使用 SqlCommand 在 C# 中直接执行 SQL 查询

SQLCMD.exe 以前用于在批处理文件中执行 SQL 查询。但是,要直接在 C# 中实现此目的,SqlCommand 类是合适的解决方案。此类允许从 C# 代码中无缝执行 SQL 查询。

首先,建立与所需 SQL 数据库的连接。您可以通过创建 SqlConnection 对象并为其提供适当的连接字符串来完成此操作。连接字符串应包含服务器地址、数据库名称、用户名和密码等信息。

接下来,创建一个 SqlCommand 对象,指定要执行的 SQL 查询作为其第一个参数,并将 SqlConnection 对象指定为它的第二个参数。如有必要,您可以使用 SqlCommand 的Parameters 属性向查询添加参数,从而增强其安全性和灵活性。

要执行查询,请使用 SqlCommand 对象的 ExecuteReader() 方法。此方法返回一个 SqlDataReader 对象,您可以通过该对象进行迭代以访问查询结果。结果集中的每一行都可以使用索引器或列名称进行访问。

以下是如何实现的示例:

string connectionString = "Server=.\PDATA_SQLEXPRESS;Database=PDATA_SQLEXPRESS;User Id=sa;Password=2BeChanged!;";
string sqlQuery = "SELECT tPatCulIntPatIDPk, tPatSName, tPatSFirstname, tPatDBirthday  FROM [dbo].[TPatientRaw] WHERE tPatSName = @tPatSName";

using (SqlConnection sqlConnection = new SqlConnection(connectionString))
{
    using (SqlCommand sqlCommand = new SqlCommand(sqlQuery, sqlConnection))
    {
        sqlCommand.Parameters.AddWithValue("@tPatSName", "YourName");
        sqlConnection.Open();
        using (SqlDataReader reader = sqlCommand.ExecuteReader())
        {
            if (reader.HasRows)
            {
                while (reader.Read())
                {
                    Console.WriteLine($"Patient ID: {reader["tPatCulIntPatIDPk"]} | Name: {reader["tPatSFirstname"]} {reader["tPatSName"]} | Date of Birth: {reader["tPatDBirthday"]}");
                }
            }
        }
    }
}

通过利用 SqlCommand 和 SqlDataReader 类,您可以直接在 C# 代码中执行 SQL 查询,提供与数据库交互的多功能且有效的方式。

以上是如何使用 SqlCommand 在 C# 中执行直接 SQL 查询?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn