C # 프로그램에서 저장 프로 시저를 실행하는 방법


254

이 저장 프로 시저를 C # 프로그램에서 실행하고 싶습니다.

SqlServer 쿼리 창에 다음 저장 프로 시저를 작성하고 stored1으로 저장했습니다.

use master 
go
create procedure dbo.test as

DECLARE @command as varchar(1000), @i int
SET @i = 0
WHILE @i < 5
BEGIN
Print 'I VALUE ' +CONVERT(varchar(20),@i)
EXEC(@command)
SET @i = @i + 1
END

편집 :

using System;
using System.Collections.Generic;
using System.Text;
using System.Data;
using System.Data.SqlClient;
namespace AutomationApp
{
    class Program
    {
        public void RunStoredProc()
        {
            SqlConnection conn = null;
            SqlDataReader rdr  = null;

            Console.WriteLine("\nTop 10 Most Expensive Products:\n");

            try
            {
                conn = new SqlConnection("Server=(local);DataBase=master;Integrated Security=SSPI");
                conn.Open();
                SqlCommand cmd = new SqlCommand("dbo.test", conn);
                cmd.CommandType = CommandType.StoredProcedure;
                rdr = cmd.ExecuteReader();
                /*while (rdr.Read())
                {
                    Console.WriteLine(
                        "Product: {0,-25} Price: ${1,6:####.00}",
                        rdr["TenMostExpensiveProducts"],
                        rdr["UnitPrice"]);
                }*/
            }
            finally
            {
                if (conn != null)
                {
                    conn.Close();
                }
                if (rdr != null)
                {
                    rdr.Close();
                }
            }
        }
        static void Main(string[] args)
        {
            Console.WriteLine("Hello World");
            Program p= new Program();
            p.RunStoredProc();      
            Console.Read();
        }
    }
}

예외가 표시됩니다 Cannot find the stored procedure dbo.test. 경로를 제공해야합니까? 그렇다면 저장 프로 시저를 어느 위치에 저장해야합니까?


3
테스트에도 master 이외의 데이터베이스를 사용하는 것이 좋습니다. 이것은 시스템 데이터베이스이므로 결국 문제가 발생합니다. SQL 2012에서는 테이블을 만들 수 없습니다. 반대로 sproc을 만들 수 있습니다. : /
Joe Johnston

그럼에도 불구하고 답변 : 당신이 당신이 준 이름 (dbo.test)으로 sp가 실제로 생성되었는지 확인 했습니까? dbo가 아닌 사용자가 dbo.test를 만들려고하면 어떻게 될지 모르겠습니다 ... dbo.test가 아닌 것으로 생성됩니까?
DigCamara

5
@obayhan이 질문은 복제 가능성이 있다고 주장하는 질문 2 년 전에 요청되었습니다. 앞으로 가장 최근의 질문을 중복으로 표시하십시오.
RyanfaeScotland

답변:


333
using (var conn = new SqlConnection(connectionString))
using (var command = new SqlCommand("ProcedureName", conn) { 
                           CommandType = CommandType.StoredProcedure }) {
   conn.Open();
   command.ExecuteNonQuery();
}

51
당신은 심지어 제거 할 수 conn.Close에 의해 암시,Dispose
레무스 Rusanu

16
이 경우에도 마찬가지입니다. 나는 일치 Open하고 Close전화를 하고 싶습니다 . 나중에 연결 개체를 필드로 리팩터링하고 using 문을 제거하면 실수로 Close열린 연결 을 추가 하고 끝내는 것을 잊을 수 있습니다 .
Mehrdad Afshari

11
저장된 proc에 매개 변수가 필요한 경우 어떻게해야합니까? 이름과 유형이 같은 명령 개체에 매개 변수를 추가하기 만하면됩니까?
Dani

5
@ 다니 예. 개체 Parameters컬렉션에 매개 변수를 추가하기 만하면 SqlCommand됩니다.
Mehrdad Afshari

SP에서 DROPDOWN 값 옵션을 보낼 수 있습니까?
SearchForKnowledge

246
using (SqlConnection conn = new SqlConnection("Server=(local);DataBase=Northwind;Integrated Security=SSPI")) {
    conn.Open();

    // 1.  create a command object identifying the stored procedure
    SqlCommand cmd  = new SqlCommand("CustOrderHist", conn);

    // 2. set the command object so it knows to execute a stored procedure
    cmd.CommandType = CommandType.StoredProcedure;

    // 3. add parameter to command, which will be passed to the stored procedure
    cmd.Parameters.Add(new SqlParameter("@CustomerID", custId));

    // execute the command
    using (SqlDataReader rdr = cmd.ExecuteReader()) {
        // iterate through results, printing each to console
        while (rdr.Read())
        {
            Console.WriteLine("Product: {0,-35} Total: {1,2}",rdr["ProductName"],rdr["Total"]);
        }
    }
}

읽을 수있는 흥미로운 링크는 다음과 같습니다.


32
실제로 "using"키워드를 사용해야합니다. 프레임 워크에 개방 / 폐쇄 책임을 부여하십시오.
TruMan1

1
SqlCommand의 정의 : public sealed class SqlCommand : System.Data.Common.DbCommand, ICloneable, IDisposable. 에 넣어 using정리 도움이 될 것입니다 문.
themefield

24

C #에서 호출 저장 프로 시저

    SqlCommand cmd = new SqlCommand("StoreProcedureName",con);
    cmd.CommandType=CommandType.StoredProcedure;
    cmd.Parameters.AddWithValue("@value",txtValue.Text);
    con.Open();
    int rowAffected=cmd.ExecuteNonQuery();
    con.Close();

21
using (SqlConnection sqlConnection1 = new SqlConnection("Your Connection String")) {
using (SqlCommand cmd = new SqlCommand()) {
  Int32 rowsAffected;

  cmd.CommandText = "StoredProcedureName";
  cmd.CommandType = CommandType.StoredProcedure;
  cmd.Connection = sqlConnection1;

  sqlConnection1.Open();

  rowsAffected = cmd.ExecuteNonQuery();

}}

cmd.CommandText = "Stored1"이 내 저장 프로 시저를 해석하는 방법에 대해 걱정하고 있습니다.
Cute

2
"CommandText"는 저장 프로 시저의 NAME으로 설정되어야합니다. 그러면 SSMS에서 "exec StoredProcedureName"을 실행 한 것처럼 C #에서 실행됩니다.
marc_s

위의 저장 프로 시저에 대해 저장 프로 시저 이름을 어떻게 줄 수 있습니까?
Cute

따라서 먼저 저장 프로 시저를 작성해야합니다. 코드가있는 경우 처음에 "프로 시저 dbo.NameOfYourStoredProcedureHere as"작성
BlackTigerX

1
@Cute : 이것을 저장 프로 시저로 가지고 있다면 반드시 이름을 가져야합니다! "CREATE PROCEDURE (프로 시저 이름)"호출에 사용 된 이름입니다. 이를 가지고 있지 않으면 저장 프로 시저 (T-SQL 문의 일괄 처리)가없고 "CommandType = StoredProcedure"를 사용할 수 없습니다.
marc_s

15
SqlConnection conn = null;
SqlDataReader rdr  = null;
conn = new SqlConnection("Server=(local);DataBase=Northwind;Integrated Security=SSPI");
conn.Open();

// 1.  create a command object identifying
//     the stored procedure
SqlCommand cmd  = new SqlCommand("CustOrderHist", conn);

// 2. set the command object so it knows
//    to execute a stored procedure
cmd.CommandType = CommandType.StoredProcedure;

// 3. add parameter to command, which
//    will be passed to the stored procedure
cmd.Parameters.Add(new SqlParameter("@CustomerID", custId));

// execute the command
rdr = cmd.ExecuteReader();

// iterate through results, printing each to console
while (rdr.Read())
{
    Console.WriteLine("Product: {0,-35} Total: {1,2}", rdr["ProductName"], rdr["Total"]);
}

14

리플렉션을 통해 매개 변수를 사용하거나 사용하지 않고 저장 프로 시저를 실행하기위한 코드입니다. 오브젝트 특성 이름은 스토어드 프로 시저의 매개 변수와 일치해야합니다.

private static string ConnString = ConfigurationManager.ConnectionStrings["SqlConnection"].ConnectionString;
    private SqlConnection Conn = new SqlConnection(ConnString);

    public void ExecuteStoredProcedure(string procedureName)
    {
        SqlConnection sqlConnObj = new SqlConnection(ConnString);

        SqlCommand sqlCmd = new SqlCommand(procedureName, sqlConnObj);
        sqlCmd.CommandType = CommandType.StoredProcedure;

        sqlConnObj.Open();
        sqlCmd.ExecuteNonQuery();
        sqlConnObj.Close();
    }

    public void ExecuteStoredProcedure(string procedureName, object model)
    {
        var parameters = GenerateSQLParameters(model);
        SqlConnection sqlConnObj = new SqlConnection(ConnString);

        SqlCommand sqlCmd = new SqlCommand(procedureName, sqlConnObj);
        sqlCmd.CommandType = CommandType.StoredProcedure;

        foreach (var param in parameters)
        {
            sqlCmd.Parameters.Add(param);
        }

        sqlConnObj.Open();
        sqlCmd.ExecuteNonQuery();
        sqlConnObj.Close();
    }

    private List<SqlParameter> GenerateSQLParameters(object model)
    {
        var paramList = new List<SqlParameter>();
        Type modelType = model.GetType();
        var properties = modelType.GetProperties();
        foreach (var property in properties)
        {
            if (property.GetValue(model) == null)
            {
                paramList.Add(new SqlParameter(property.Name, DBNull.Value));
            }
            else
            {
                paramList.Add(new SqlParameter(property.Name, property.GetValue(model)));
            }
        }
        return paramList;

    }

5

Ado.net을 사용하여

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

namespace PBDataAccess
{
    public class AddContact
    {   
        // for preparing connection to sql server database   

        private SqlConnection conn; 

        // for preparing sql statement or stored procedure that 
        // we want to execute on database server

        private SqlCommand cmd; 

        // used for storing the result in datatable, basically 
        // dataset is collection of datatable

        private DataSet ds; 

        // datatable just for storing single table

        private DataTable dt; 

        // data adapter we use it to manage the flow of data
        // from sql server to dataset and after fill the data 
        // inside dataset using fill() method   

        private SqlDataAdapter da; 


        // created a method, which will return the dataset

        public DataSet GetAllContactType() 
        {



    // retrieving the connection string from web.config, which will 
    // tell where our database is located and on which database we want
    // to perform opearation, in this case we are working on stored 
    // procedure so you might have created it somewhere in your database. 
    // connection string will include the name of the datasource, your 
    // database name, user name and password.

        using (conn = new SqlConnection(ConfigurationManager.ConnectionString["conn"]
        .ConnectionString)) 

                {
                    // Addcontact is the name of the stored procedure
                    using (cmd = new SqlCommand("Addcontact", conn)) 

                    {
                        cmd.CommandType = CommandType.StoredProcedure;

                    // here we are passing the parameters that 
                    // Addcontact stored procedure expect.
                     cmd.Parameters.Add("@CommandType",
                     SqlDbType.VarChar, 50).Value = "GetAllContactType"; 

                        // here created the instance of SqlDataAdapter
                        // class and passed cmd object in it
                        da = new SqlDataAdapter(cmd); 

                        // created the dataset object
                        ds = new DataSet(); 

                        // fill the dataset and your result will be
                        stored in dataset
                        da.Fill(ds); 
                    }                    
            }  
            return ds;
        }
}

****** Stored Procedure ******

CREATE PROCEDURE Addcontact
@CommandType VARCHAR(MAX) = NULL
AS
BEGIN
  IF (@CommandType = 'GetAllContactType')
  BEGIN
    SELECT * FROM Contacts
  END
END

귀하의 의견에 저장 절차를 제공 할 수있는 경우에도 귀하의 의견 줄이 끊어졌습니다.
PeerNet

저장 프로 시저를 코드에 추가했다면 확인하십시오.
Johnny

4

이것은 값을 반환하는 저장 프로 시저의 예이며 C #에서 실행됩니다.

CREATE PROCEDURE [dbo].[InsertPerson]   
-- Add the parameters for the stored procedure here  
@FirstName nvarchar(50),@LastName nvarchar(50),  
@PersonID int output  
AS  
BEGIN  
    insert [dbo].[Person](LastName,FirstName) Values(@LastName,@FirstName)  

    set @PersonID=SCOPE_IDENTITY()  
END  
Go  


--------------
 // Using stored procedure in adapter to insert new rows and update the identity value.  
   static void InsertPersonInAdapter(String connectionString, String firstName, String lastName) {  
      String commandText = "dbo.InsertPerson";  
      using (SqlConnection conn = new SqlConnection(connectionString)) {  
         SqlDataAdapter mySchool = new SqlDataAdapter("Select PersonID,FirstName,LastName from [dbo].[Person]", conn);  

         mySchool.InsertCommand = new SqlCommand(commandText, conn);  
         mySchool.InsertCommand.CommandType = CommandType.StoredProcedure;  

         mySchool.InsertCommand.Parameters.Add(  
             new SqlParameter("@FirstName", SqlDbType.NVarChar, 50, "FirstName"));  
         mySchool.InsertCommand.Parameters.Add(  
             new SqlParameter("@LastName", SqlDbType.NVarChar, 50, "LastName"));  

         SqlParameter personId = mySchool.InsertCommand.Parameters.Add(new SqlParameter("@PersonID", SqlDbType.Int, 0, "PersonID"));  
         personId.Direction = ParameterDirection.Output;  

         DataTable persons = new DataTable();  
         mySchool.Fill(persons);  

         DataRow newPerson = persons.NewRow();  
         newPerson["FirstName"] = firstName;  
         newPerson["LastName"] = lastName;  
         persons.Rows.Add(newPerson);  

         mySchool.Update(persons);  
         Console.WriteLine("Show all persons:");  
         ShowDataTable(persons, 14); 

2

Dapper 사용. 그래서 나는 이것을 추가하여 누군가가 도움이되기를 바랍니다.

public void Insert(ProductName obj)
        {
            SqlConnection connection = new SqlConnection(Connection.GetConnectionString());
            connection.Open();
            connection.Execute("ProductName_sp", new
            { @Name = obj.Name, @Code = obj.Code, @CategoryId = obj.CategoryId, @CompanyId = obj.CompanyId, @ReorderLebel = obj.ReorderLebel, @logo = obj.logo,@Status=obj.Status, @ProductPrice = obj.ProductPrice,
                @SellingPrice = obj.SellingPrice, @VatPercent = obj.VatPercent, @Description=obj.Description, @ColourId = obj.ColourId, @SizeId = obj.SizeId,
                @BrandId = obj.BrandId, @DisCountPercent = obj.DisCountPercent, @CreateById =obj.CreateById, @StatementType = "Create" }, commandType: CommandType.StoredProcedure);
            connection.Close();
        }

2

크레인을 확인하십시오 (저는 저자입니다)

https://www.nuget.org/packages/Crane/

SqlServerAccess sqlAccess = new SqlServerAccess("your connection string");
var result = sqlAccess.Command().ExecuteNonQuery("StoredProcedureName");

또한 당신이 좋아할만한 많은 다른 기능들이 있습니다.


이 작동하지 않습니다. 이것이 구식입니까? 방법 절차를 찾을 수 없습니다.
Maddy

알려 주셔서 감사합니다.
Greg R Taylor

Crane을 사용하여 여러 데이터 세트를 어떻게 반환합니까? 내 저장 프로 시저는 3 개의 데이터 세트를 반환하며 두 번째 데이터 세트에만 관심이 있습니다. 그러나 크레인은 나에게 첫 번째 것을 돌려줍니다.
Hoang Minh

1

코드가 DDL이라는 것을 의미합니까? 그렇다면 MSSQL에는 차이가 없습니다. 위의 예제는 이것을 호출하는 방법을 잘 보여줍니다. 그냥 확인

CommandType = CommandType.Text

1

여기에는 Dapper가 없습니다 . 그래서 나는 하나를 추가

using Dapper;
using System.Data.SqlClient;

using (var cn = new SqlConnection(@"Server=(local);DataBase=master;Integrated Security=SSPI"))
    cn.Execute("dbo.test", commandType: CommandType.StoredProcedure);
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.