SSMS
 sql >> Base de données >  >> Database Tools >> SSMS

Affichage du nombre de lignes du serveur SQL au programme

Si vous avez plusieurs requêtes dans votre fichier de script, vous devez améliorer votre script avec @rowsAffected variable comme indiqué dans T-SQL ci-dessous. Ensuite, dans votre code C #, vous devrez appeler ExecuteScalar pour obtenir les lignes détaillées affectées par votre 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;

Vous devrez lire le texte de votre fichier de script, comme vous le faites dans votre code, puis créer un objet de commande en utilisant le texte lu à partir du fichier avant d'exécuter le code dans l'extrait ci-dessous.

Code C# pour exécuter le script ci-dessus

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

Code C# détaillé utilisant votre code d'origine

    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);
        }
    }