IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

C# Discussion :

WPF message lors de l'execution d'une procédure stockée


Sujet :

C#

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Chargé d'affaire
    Inscrit en
    Février 2015
    Messages
    26
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Chargé d'affaire

    Informations forums :
    Inscription : Février 2015
    Messages : 26
    Par défaut WPF message lors de l'execution d'une procédure stockée
    Bonjour dans une solution WPF au démarrage de l'appli j'exécute le code suivant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    using Repository;
    using System;
    using System.IO;
    using System.Reflection;
    using System.Threading.Tasks;
    using System.Windows;
    using Utilities.Library;
     
    namespace EmailSender
    {
        /// <summary>
        /// Logique d'interaction pour App.xaml
        /// </summary>
        public partial class App : Application
        {
            private async void Application_Startup(object sender, StartupEventArgs e)
            {
                try
                {
                    await CreateRootFolder();
                    await CreateDocumentsBase();
                    await CheckTasks();
                }
                catch (Exception ex)
                {
                    MessageBox.Show(ex.Message);
                }
            }
            private async Task CreateRootFolder()
            {
                if (!Directory.Exists(Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.MyDocuments),
                        $"{Assembly.GetExecutingAssembly().GetName().Name}_Docs")))
                {
                    _ = Directory.CreateDirectory(Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.MyDocuments),
                                               $"{Assembly.GetExecutingAssembly().GetName().Name}_Docs"));
                }
                await Task.CompletedTask;
            }
            private async Task CreateDocumentsBase()
            {
                using (EMAILEntities dc = new EMAILEntities())
                {
                    _ = dc.ApplicationParamsChecker();
                }
                await Task.CompletedTask;
            }
            private async Task CheckTasks()
            {
                switch (GlobalQueries.TasksAreUnCompleted())
                {
                    case true:
                        StartupUri = new Uri("Views/TasksView.xaml", UriKind.Relative);
                        break;
                    default:
                        StartupUri = new Uri("MainWindow.xaml", UriKind.Relative);
                        break;
                }
                await Task.CompletedTask;
            }
        }
    }
    Ce qui pose problème c'est la procédure stockée "ApplicationParamsChecker()" qui renvoi ce message :

    Nom : Capture d'écran 2023-12-09 074233.png
Affichages : 102
Taille : 4,9 Ko

    Et voici la prcédure stockée en question :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    ALTER PROCEDURE [dbo].[ApplicationParamsChecker] 
    AS
    BEGIN
    	-- SET NOCOUNT ON added to prevent extra result sets from
    	-- interfering with SELECT statements.
    	SET NOCOUNT ON;
    declare 
    @bascisDocsExisits bit,
    @DocsHaveBeenInsertedInDocType bit,
    @tableClientIsNotEmpty bit,
    @tableContactsIsNotEmpty bit;
     
    set @bascisDocsExisits = (select T_VERIFIED from TASKS where T_ID = 1);
    set @DocsHaveBeenInsertedInDocType = (select T_VERIFIED from TASKS where T_ID = 2);
    set @tableClientIsNotEmpty = (select T_VERIFIED from TASKS where T_ID = 4);
    set @tableContactsIsNotEmpty = (select T_VERIFIED from TASKS where T_ID = 6);
     
    begin transaction;
     
    begin try
     
    MERGE GENERIC_DOC_NAME AS t  
    USING (
    	SELECT * FROM GENERIC_DOC_NAME_BASE 
    ) AS s ON t.UNIQUE_IDENTIFIER = s.GUID 
    WHEN MATCHED THEN  
    	UPDATE SET
    		t.GDN_SHORT_NAME = s.GDN_SHORT_NAME, 
    		t.GDN_LIB = s.GDN_LIB,
    		t.L_ID = s.L_ID
    WHEN NOT MATCHED THEN  
    	INSERT (  
    		GDN_SHORT_NAME,  
    		GDN_LIB,
    		L_ID,
    		UNIQUE_IDENTIFIER
    	)  
    	VALUES (
    		s.GDN_SHORT_NAME,  
    		s.GDN_LIB,  
    		s.L_ID,
    		s.GUID
    	);
    update TASKS set T_VERIFIED = 1 where T_ID in (1, 2);
     
    declare @nbClientsRows int;
    set @nbClientsRows = (select count(CLI_CODE) from CLIENTS);
    if @nbClientsRows > 0
    	begin
    	update TASKS set T_VERIFIED = 1 where T_ID = 4;
    	end
     
    declare @nbContactsRows int;
    set @nbContactsRows = (select count(C_ID) from CONTACTS_CLIENT);
    if @nbContactsRows > 0
    	begin
    	update TASKS set T_VERIFIED = 1 where T_ID = 6;
    	end
    end try
     
    begin catch
    if @@TRANCOUNT > 0
    rollback transaction;
    end catch
    if @@TRANCOUNT > 0
    commit transaction;
    END
    j'avoue ne jamais avoir eu ce type de message jusqu'à aujourd'hui...

  2. #2
    Expert confirmé
    Avatar de popo
    Homme Profil pro
    Analyste programmeur Delphi / C#
    Inscrit en
    Mars 2005
    Messages
    2 972
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Analyste programmeur Delphi / C#
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2005
    Messages : 2 972
    Par défaut
    Cela arrive généralement lorsque la base de données que tu interroges n'est pas à jour.
    Tu fais probablement une demande sur une colonnes qui n'existe pas encore dans la base que tu interroges.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 1
    Dernier message: 28/12/2010, 14h49
  2. Réponses: 1
    Dernier message: 24/04/2008, 15h23
  3. Erreur lors de l'appel d'une procédure stockée
    Par aperrin dans le forum JDBC
    Réponses: 1
    Dernier message: 04/01/2008, 13h54
  4. Réponses: 3
    Dernier message: 01/12/2006, 12h58
  5. Problème lors de l'appel d'une procédure stockée
    Par ToxiZz dans le forum SQL Procédural
    Réponses: 2
    Dernier message: 21/05/2006, 23h42

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo