こんにちは、ストアドプロシージャを呼び出すDALを作成しましたが、一部のプロシージャにExecuteScalar、NonQuery、またはReaderを使用する必要があるかどうかはまだわかりません。
たとえば、私が呼び出したいこの関数を書いた
CREATE FUNCTION `retornarIdArea`(cod longtext) RETURNS int(11)
BEGIN
DECLARE id int;
select AreaId into id FROM area where Codigo = cod;
return id;
END
データセットを返すはずのこのプロシージャ
CREATE PROCEDURE `consultar_n_asunto`(in asun longtext, in est int)
BEGIN
select * from notas where Asunto LIKE CONCAT('%',CONCAT(asun,'%')) AND Estado = est;
END$$
そして最後に、いくつかのデータを挿入する手順、そしてそれをselect using using出力パラメーターで検証します。
CREATE PROCEDURE `registrar_dest`(in nomb longtext,
in dir longtext, in inst int, in mail longtext, in tel longtext,
in act int, out res tinyint(1))
BEGIN
-- verificar que no exista el destinatario
select count(*) into res from destinatario WHERE Nombre = nomb AND
Direccion = dir AND Email = mail AND Telefono = tel AND Activo = act;
IF res = 0 THEN
INSERT INTO destinatario (Nombre, Direccion, InstitucionId, Email, Telefono, Activo)
VALUES (nomb, dir, inst, mail, tel, act);
select count(*) into res from destinatario WHERE Nombre = nomb AND
Direccion = dir AND Email = mail AND Telefono = tel AND Activo = act;
ELSE
set res = -1;
END IF;
END$$
今私はC#でこれを書いて、関数から値を返します
public object ejecutarFuncion() { using (MySqlConnection conn = new MySqlConnection(stringDeConexion)) { using (MySqlCommand cmd = new MySqlCommand(procedimiento, conn)) { cmd.CommandType = System.Data.CommandType.StoredProcedure; //Se abre la conexión conn.Open(); //existen parámetros los recorremos y agregamos. foreach (KeyValuePair<string, object> pars in parametros) { cmd.Parameters.Add(new MySqlParameter(pars.Key, pars.Value)); } //Se crea la variable de retorno cmd.Parameters.Add(new MySqlParameter(nombreOut, tipoParOut)); cmd.Parameters[nombreOut].Direction = System.Data.ParameterDirection.ReturnValue; cmd.ExecuteNonQuery(); // Cerramos conexión conn.Close(); return cmd.Parameters[nombreOut].Value; } } }
ここでExecuteNonQuery()を実行していることがわかりましたが、実行スカラーを使用する必要がありますか?または単にparmsからの戻り値を使用しますか?
次に、このメソッドを記述して、出力値(一部は更新、挿入を行う)操作でプロシージャを実行し、出力値を使用して、操作が正しく行われたかどうかを確認します。
public object ejecutarProcedimientoConOutput()
{
using (MySqlConnection conn = new MySqlConnection(stringDeConexion))
{
using (MySqlCommand cmd = new MySqlCommand(procedimiento, conn))
{
cmd.CommandType = System.Data.CommandType.StoredProcedure;
//Se abre la conexión
conn.Open();
//verificamos si se mando la lista de parámetros
if (parametros.Count > 0)
{
//existen parámetros los recorremos y agregamos.
foreach (KeyValuePair<string, object> pars in parametros)
{
cmd.Parameters.Add(new MySqlParameter(pars.Key, pars.Value));
cmd.Parameters[pars.Key].Direction = System.Data.ParameterDirection.Input;
}
}
cmd.Parameters.Add(new MySqlParameter(nombreOut, tipoParOut));
cmd.Parameters[nombreOut].Direction = System.Data.ParameterDirection.Output;
cmd.ExecuteNonQuery();
conn.Close();
return cmd.Parameters[nombreOut].Value;
}
}
}
繰り返しますが、更新または挿入操作を行っていますが、出力パラメーターを使用してそれが行われたかどうかを確認する場合、ExecuteNonQueryまたはExecuteScalarを使用する必要がある場合、挿入ストアドプロシージャを確認できますか?
データセットを返すプロシージャの場合、上記で記述したメソッドと同じですが、出力パラメーターなしで、selectのみを実行し、出力パラメーターを使用しないため、executeReaderを使用しています。
これらのプロシージャに正しい実行コマンドを使用しているかどうかを知りたいだけです。
クエリの影響を受ける行数を返す場合は、ExecuteNonReader()
を使用します。
最初の行の最初の列を返す場合は、ExecuteScalar
を使用します。
SqlDataReader
を作成して結果を反復できるようにする必要がある場合は、ExecuteReader
を使用します。
したがって、関数ExecuteScalar
にはretornarIdArea
を使用できます。これは、1つの列と1つの行(id)しか返さないため、この関数がコンテキストに適合するためです。
あなたの手順のためにconsultar_n_asunto
複数の行を選択しており、結果セットが返されることを期待しているため、ExecuteReader
を使用できます。