Я создал хранимую процедуру, чтобы возвратить меня таблица.
Что-то вроде этого:
create procedure sp_returnTable
body of procedure
select * from table
end
Когда я называю эту хранимую процедуру на frontend, какой код я должен написать для получения его в объекте dataTable?
Я написал код что-то как следующее. Я в основном хочу знать получение и хранение таблицы в объект таблицы данных. Все мои запросы работают, но я не знаю, как получить таблицу в таблицу данных через хранимую процедуру
DataTable dtable = new DataTable();
cmd.Connection = _CONN;
cmd.CommandText = SPNameOrQuery;
cmd.CommandType = CommandType.StoredProcedure;
SqlDataAdapter adp = new SqlDataAdapter(cmd);
OpenConnection();
adp.Fill(dtTable);
CloseConnection();
Здесь в этом коде команда была связана с названием хранимой процедуры и его параметрами. Это будет возвращать меня таблица данных из хранимой процедуры?
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
Также установите CommandText
и вызовите Fill
] в SqlAdapter
, чтобы получить результаты в 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);
(Пример использует конструкторы без параметров для ясности; можно сократить, используя другие конструкторы.)