SSMS
 sql >> Base de Dados >  >> Database Tools >> SSMS

Exibindo a contagem de linhas do SQL Server para o programa


Se você tiver várias consultas em seu arquivo de script, aprimore seu script com @rowsAffected variável conforme mostrado no T-SQL abaixo. Então, em seu código C#, você precisará chamar ExecuteScalar para obter as linhas detalhadas afetadas pelo seu script.
**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;

Você terá que ler o texto do seu arquivo de script, como está fazendo no seu código, e então criar um objeto de comando usando o texto lido do arquivo antes de executar o código no snippet abaixo.

Código C# para executar o script acima
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# detalhado usando seu 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);
        }
    }