web-dev-qa-db-ja.com

ストアドプロシージャからデータテーブルにテーブルを取得するにはどうすればよいですか?

テーブルを返すようにストアドプロシージャを作成しました。

このようなもの:

create procedure sp_returnTable
body of procedure
select * from table
end

フロントエンドでこのストアドプロシージャを呼び出すと、データテーブルオブジェクトで取得するためにどのコードを記述する必要がありますか?

次のようなコードを書きました。基本的に、テーブルを取得してデータテーブルのオブジェクトに格納することを知りたいです。すべてのクエリが実行されていますが、ストアドプロシージャを介してテーブルをデータテーブルに取得する方法がわかりません

DataTable dtable = new DataTable();
cmd.Connection = _CONN;

cmd.CommandText = SPNameOrQuery;
cmd.CommandType = CommandType.StoredProcedure;

SqlDataAdapter adp = new SqlDataAdapter(cmd);
OpenConnection();
adp.Fill(dtTable);
CloseConnection();

このコードでは、コマンドがストアドプロシージャ名とそのパラメーターにバインドされています。ストアドプロシージャからデータテーブルを返しますか?

33
Shantanu Gupta
string connString = "<your connection string>";
string sql = "name of your sp";

using(SqlConnection conn = new SqlConnection(connString)) 
{
    try 
    {
        using(SqlDataAdapter da = new SqlDataAdapter()) 
        {
            da.SelectCommand = new SqlCommand(sql, conn);
            da.SelectCommand.CommandType = CommandType.StoredProcedure;

            DataSet ds = new DataSet();   
            da.Fill(ds, "result_name");

            DataTable dt = ds.Tables["result_name"];

            foreach (DataRow row in dt.Rows) {
                //manipulate your data
            }
        }    
    } 
    catch(SQLException ex) 
    {
        Console.WriteLine("SQL Error: " + ex.Message);
    }
    catch(Exception e) 
    {
        Console.WriteLine("Error: " + e.Message);
    }
}

Java Schools Example から変更

47
GrayWizardx

CommandTextも設定し、FillSqlAdapterを呼び出して、DataSetの結果を取得します。

var con = new SqlConnection();
con.ConnectionString = "connection string";
var com = new SqlCommand();
com.Connection = con;
com.CommandType = CommandType.StoredProcedure;
com.CommandText = "sp_returnTable";
var adapt = new SqlDataAdapter();
adapt.SelectCommand = com;
var dataset = new DataSet();
adapt.Fill(dataset);

(例はわかりやすくするためにパラメーターなしのコンストラクターを使用しています。他のコンストラクターを使用して短縮できます。)

5
Andomar

以下のように、ストアドプロシージャの呼び出し中にパラメータを送信したい人がいる場合は、

using (SqlConnection con = new SqlConnection(connetionString))
            {
                using (var command = new SqlCommand(storedProcName, con))
                {
                    foreach (var item in sqlParams)
                    {
                        item.Direction = ParameterDirection.Input;
                        item.DbType = DbType.String;
                        command.Parameters.Add(item);
                    }
                    command.CommandType = CommandType.StoredProcedure;
                    using (var adapter = new SqlDataAdapter(command))
                    {
                        adapter.Fill(dt);
                    }
                }
            }
0
Rush.2707