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

相关推荐

  • 为何网络检测揭示画报CDN资源访问频现故障,背后原因是什么?

    网络检测显示画报CDN资源访问出现问题网络检测系统发现画报CDN资源访问出现异常,影响了用户的使用体验,本文将针对这一问题进行详细分析,并提出相应的解决方案,问题表现部分用户在访问画报CDN资源时,页面加载缓慢或无法加载,部分用户在访问画报CDN资源时,出现404错误或500错误,部分用户在访问画报CDN资源时……

    2025年11月10日
    01430
  • CDN设置回默认值频率问题,多久自动重置一次合适?

    CDN如何设置回原默认多久一次CDN简介CDN(Content Delivery Network,内容分发网络)是一种通过在多个地理位置部署缓存服务器,将网站内容分发到用户最近的节点,从而提高网站访问速度和用户体验的技术,CDN通过智能调度,将用户请求引导到最近的节点,减少延迟,提高访问速度,CDN回原默认设置……

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

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

      2026年1月10日
      020
  • 揭秘创世纪cdn宣发事业,骗局真相究竟有哪些?

    在互联网时代,创世纪CDN宣发事业凭借其强大的网络分发能力,一度成为许多企业宣发推广的首选,在光鲜亮丽的背后,也存在着诸多骗局,以下列举了创世纪CDN宣发事业中常见的几种骗局,以供广大企业主和消费者警惕,虚假宣传无中生有部分不法商家在宣传中夸大其词,声称其CDN服务能够保证100%的访问速度,实际上这是不可能的……

    2025年11月27日
    01300
  • 长虹CDN一R丫2000室内加热器制热效果到底怎么样?

    在寒冷的季节里,一台性能可靠、安全舒适的室内加热器是提升生活品质的关键,长虹作为中国知名的家电品牌,其推出的CDN-YR2000室内加热器(此处根据常见型号逻辑优化了“一R丫”的表述,旨在更准确地描述产品类别)凭借其高效的对流加热技术和人性化的功能设计,成为了许多家庭冬季取暖的理想选择,本文将深入解析这款产品的……

    2025年10月25日
    01600

发表回复

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