asp.net如何调用存储过程?SQL教程详解步骤方法

在 ASP.NET 中调用 SQL Server 存储过程可以通过 ADO.NET 实现,以下是详细步骤和示例代码:

asp.net调用存储过程gogle

步骤 1:创建存储过程(SQL Server 示例)

CREATE PROCEDURE GetEmployeeByID
    @EmployeeID INT
AS
BEGIN
    SELECT * FROM Employees WHERE EmployeeID = @EmployeeID
END

步骤 2:ASP.NET C# 调用代码(使用 ADO.NET)

示例 1:基础版(带参数)

using System.Data;
using System.Data.SqlClient;
public Employee GetEmployee(int employeeId)
{
    Employee emp = null;
    // 从配置获取连接字符串(推荐在 Web.config 中配置)
    string connString = ConfigurationManager.ConnectionStrings["YourDbConnection"].ConnectionString;
    using (SqlConnection conn = new SqlConnection(connString))
    {
        using (SqlCommand cmd = new SqlCommand("GetEmployeeByID", conn))
        {
            cmd.CommandType = CommandType.StoredProcedure;
            cmd.Parameters.AddWithValue("@EmployeeID", employeeId);
            conn.Open();
            using (SqlDataReader reader = cmd.ExecuteReader())
            {
                if (reader.Read())
                {
                    emp = new Employee
                    {
                        ID = (int)reader["EmployeeID"],
                        Name = reader["Name"].ToString(),
                        Department = reader["Department"].ToString()
                    };
                }
            }
        }
    }
    return emp;
}

示例 2:带输出参数

public int CreateEmployee(Employee emp)
{
    int newID = -1;
    string connString = ConfigurationManager.ConnectionStrings["YourDbConnection"].ConnectionString;
    using (SqlConnection conn = new SqlConnection(connString))
    {
        using (SqlCommand cmd = new SqlCommand("sp_CreateEmployee", conn))
        {
            cmd.CommandType = CommandType.StoredProcedure;
            // 输入参数
            cmd.Parameters.AddWithValue("@Name", emp.Name);
            cmd.Parameters.AddWithValue("@Department", emp.Department);
            // 输出参数
            SqlParameter outParam = new SqlParameter("@NewID", SqlDbType.Int);
            outParam.Direction = ParameterDirection.Output;
            cmd.Parameters.Add(outParam);
            conn.Open();
            cmd.ExecuteNonQuery();
            // 获取输出参数值
            newID = (int)cmd.Parameters["@NewID"].Value;
        }
    }
    return newID;
}

配置 Web.config

<connectionStrings>
  <add name="YourDbConnection" 
       connectionString="Server=your_server;Database=your_db;User Id=user;Password=pass;"
       providerName="System.Data.SqlClient"/>
</connectionStrings>

关键点说明:

  1. 参数化查询:始终使用 Parameters.AddWithValue() 防止 SQL 注入
  2. 资源释放:使用 using 语句确保连接和命令对象自动释放
  3. 参数类型
    • 输入参数:AddWithValue("@Param", value)
    • 输出参数:设置 Direction = ParameterDirection.Output
    • 返回值:使用 ParameterDirection.ReturnValue
  4. 执行方法
    • ExecuteReader():返回结果集(SELECT)
    • ExecuteNonQuery():执行操作不返回数据(INSERT/UPDATE/DELETE)
    • ExecuteScalar():返回单个值

处理事务

using (SqlTransaction transaction = conn.BeginTransaction())
{
    try
    {
        cmd.Transaction = transaction;
        // 执行多个操作...
        transaction.Commit();
    }
    catch
    {
        transaction.Rollback();
        throw;
    }
}

异步版本(ASP.NET 4.5+)

public async Task<Employee> GetEmployeeAsync(int id)
{
    using (SqlConnection conn = new SqlConnection(connString))
    {
        SqlCommand cmd = new SqlCommand("GetEmployeeByID", conn);
        cmd.CommandType = CommandType.StoredProcedure;
        cmd.Parameters.AddWithValue("@EmployeeID", id);
        await conn.OpenAsync();
        using (SqlDataReader reader = await cmd.ExecuteReaderAsync())
        {
            // 处理数据...
        }
    }
}

最佳实践:

  1. 将连接字符串存储在配置文件中
  2. 使用参数化查询防止 SQL 注入
  3. 通过 using 确保资源释放
  4. 重要操作添加事务支持
  5. 对高并发场景使用异步方法
  6. 验证存储过程返回值和错误代码

注意:实际项目中建议使用 Entity Framework 或 Dapper 等 ORM 工具简化存储过程调用,但原生 ADO.NET 在性能关键场景仍有优势。

asp.net调用存储过程gogle

图片来源于AI模型,如侵权请联系管理员。作者:酷小编,如若转载,请注明出处:https://www.kufanyun.com/ask/286020.html

(0)
上一篇 2026年2月7日 19:14
下一篇 2026年2月7日 19:15

相关推荐

  • 公交大数据分析背景是什么?公交大数据应用趋势

    公交大数据分析背景公交大数据分析的核心结论在于:它已不再仅仅是简单的客流统计工具,而是城市交通从“经验驱动”向“数据智能驱动”转型的基石,能够直接实现运力资源的精准匹配、运营成本的显著降低以及乘客出行体验的质的飞跃, 在数字化转型的浪潮下,通过对海量多源异构数据的深度挖掘,公交系统能够构建起“感知 – 决策……

    2026年4月29日
    0341
  • 光传送网络怎么玩,光传送网络是什么

    光传送网络(OTN)并非传统意义上的“游戏”,而是通过WDM波分复用与数字包封装技术,实现大容量、低时延、高可靠数据传输的基础设施,其核心价值在于解决5G回传、云计算互联及算力网络中的带宽瓶颈问题, 光传送网络的核心逻辑与架构解析在2026年的通信行业语境中,理解OTN需要跳出传统电信思维,将其视为“光域的数据……

    2026年5月13日
    083
  • 宇明阀门A48Y_16cdn40价格是多少?性价比如何?市场行情分析?

    宇明阀门A48Y-16CDN40价格解析宇明阀门A48Y-16CDN40是一款广泛应用于工业管道系统中的阀门产品,具有结构紧凑、密封性能好、操作方便等特点,该阀门适用于DN40管道,公称压力为16bar,广泛应用于石油、化工、制药、食品等行业,产品参数参数名称参数值阀门类型闸阀公称直径DN40公称压力16bar……

    2025年11月19日
    01550
    • 服务器间歇性无响应是什么原因?如何排查解决?

      根源分析、排查逻辑与解决方案服务器间歇性无响应是IT运维中常见的复杂问题,指服务器在特定场景下(如高并发时段、特定操作触发时)出现短暂无响应、延迟或服务中断,而非持续性的宕机,这类问题对业务连续性、用户体验和系统稳定性构成直接威胁,需结合多维度因素深入排查与解决,常见原因分析:从硬件到软件的多维溯源服务器间歇性……

      2026年1月10日
      020
  • 光盘镜像死机怎么办?光盘镜像死机原因和应对方法

    2026 年光盘镜像死机通常由文件系统校验失败、光驱机械老化或驱动兼容性冲突引发,核心应对策略是立即停止写入操作并优先使用“只读模式”挂载或替换为 ISO 校验工具修复,在数字化存储向云原生与固态介质全面迁移的 2026 年,光盘镜像(ISO/IMG)作为系统部署与数据归档的“最后一道防线”,其稳定性仍受物理介……

    2026年5月7日
    0333

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注