sql >> Base de Datos >  >> Database Tools >> SSMS

Mostrar el recuento de filas del servidor SQL al programa

Si tiene varias consultas en su archivo de secuencia de comandos, debe mejorar su secuencia de comandos con @rowsAffected variable como se muestra en T-SQL a continuación. Luego, en su código C# deberá llamar a ExecuteScalar para obtener las filas detalladas afectadas por su secuencia de comandos.

**Script file with @rowsAffected variable logic**

--add following variable at start of your script
DECLARE @rowsAffected VARCHAR(2000);

INSERT INTO [dbo].[Products] ([ProductName]) VALUES ('sun1'),('sun2'),('sun3');

--after each query that you want to track, include the following line
SET @rowsAffected = 'Products : ' + CAST(@@rowcount AS varchar(20));

UPDATE [dbo].[newTable]   SET [ColB] = 'b' ,[ColC] = 'd',[ColD] = 'e'  ,[ColE] = 'f'  WHERE ColA='a';

 --after each query that you want to track, include the following line
SET @rowsAffected = @rowsAffected + ', newTable : ' + CAST(@@rowcount AS varchar(20));

-- add the query below at end of your script 
SELECT @rowsAffected;

Tendrá que leer el texto de su archivo de script, como lo está haciendo en su código, y luego crear un objeto de comando usando el texto leído del archivo antes de ejecutar el código en el fragmento a continuación.

Código C# para ejecutar el script anterior

string rowsAffected =(string) command.ExecuteScalar();
//you can now use rowsAffected variable in any way you like
//it will contain something like Table1 : 4, Table2 : 6

Código C# detallado usando su código original

    using (SqlConnection con = new SqlConnection(constr))
    {

        FileInfo file = new FileInfo(DIRECTORY OF THE SCRIPT);
        string script = file.OpenText().ReadToEnd();

        SqlCommand command = new SqlCommand(script, con);
        command.CommandType = CommandType.Text;
        try
        {
            con.Open();
            string rowsAffected =(string) command.ExecuteScalar();
            Display( rowsAffected);
            con.Close();
        }
        catch (Exception ex)
        {
            con.Close();
            Display(ex.Message);
        }
    }