13

こんにちは、ストアド プロシージャを呼び出す 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$$

最後に、いくつかのデータを挿入する手順を行い、出力パラメーターを使用して選択して検証します。

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$$

FUNCTIONS から値を返すように 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() を実行している場合、Execute Scalar を使用する必要がありますか? または単に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 を使用する必要がある挿入ストアド プロシージャを確認できますか?

また、データセットを返す手順については、上で書いた方法と同じですが、出力パラメーターを使用せずに、選択のみを行い、出力パラメーターを使用しないため、executeReader を使用しています。

これらの手順に正しい実行コマンドを使用しているかどうかを知りたいだけです。

4

1 に答える 1

10
  • クエリの影響を受けた行数を返す場合は、 を使用しますExecuteNonReader()

  • 最初の行の最初の列を返したい場合は、 を使用します ExecuteScalar

  • SqlDataReader結果を反復できるように を作成する必要がある場合は、を使用しますExecuteReader

ExecuteScalarしたがって、1 つの列と 1 つの行 (id) のみを返すため、関数に使用できるためretornarIdArea、この関数はコンテキストに適合します。

あなたの手順では、複数の行を選択していて、結果セットが返されることを期待して consultar_n_asunto使用できます。ExecuteReader

于 2013-09-15T18:06:36.107 に答える