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

WinDev Discussion :

[WD10] Procédure stockée SQLServer avec SQLExec()


Sujet :

WinDev

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Octobre 2005
    Messages
    9
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Octobre 2005
    Messages : 9
    Points : 7
    Points
    7
    Par défaut [WD10] Procédure stockée SQLServer avec SQLExec()
    Bonjour,

    J'utilise WinDev depuis quelques temps déjà et je m'interroge sur la possibilité de créer une procédure stockée depuis WinDev à l'aide de l'instruction SQLExec. Ma procédure stockée est la suivante:
    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
    68
    69
    CREATE PROCEDURE PS_nLog AS 
    DECLARE 
    @sscc			char(18), 
    @counttotalsscc	int, 
    @countexisteoui	int, 
    @countexistenon	int, 
    @countinsert	int, 
    @dtdate			datetime, 
    @dttime			datetime, 
    @strOrder		char(10), 
    @strArtNr		char(20), 
    @nPalNr			int, 
    @strMDH			varchar(8), 
    @nFinish		int 
     
    SET @counttotalsscc = 0 
    SET @countexisteoui = 0 
    SET @countexistenon = 0 
    SET @countinsert = 0 
    SET NOCOUNT ON
    SET ANSI_NULLS ON
    SET ANSI_WARNINGS ON
    /****************************************************************/ 
    /*				Déclaration du curseur C_Export					*/ 
    /****************************************************************/ 
    DECLARE C_Export CURSOR FOR 
    SELECT	strSSCC 
     FROM	tPalProd 
     WHERE	nFinish IN (1,3) AND nLog = 0 
     OPEN C_Export 
    FETCH NEXT FROM C_Export 
    INTO @sscc 
    WHILE @@FETCH_STATUS = 0 
    BEGIN 
    SET @counttotalsscc = @counttotalsscc + 1 
     
    IF (SELECT COUNT(*)	 
    	FROM SEBAS009.Aproz.dbo.tpalprod 
    	WHERE strsscc = @sscc) > 0  
    		BEGIN 
    			SET @countexisteoui = @countexisteoui + 1 
    			PRINT 'SSCC: ' + @sscc + ' existe déjà sur SEBAS009' 
    			UPDATE tPalProd SET nlog = -1 WHERE strSSCC = @sscc 
    		END 
    ELSE 
    	BEGIN 
    		SELECT	@dtdate = dtdate, @dttime = dttime, @strOrder = strOrder, 
    				@strArtNr = strArtNr, @nPalNr = nPalNr, 
    				@strMDH = strMHD, @nFinish = nFinish 
    		FROM	tPalProd 
    		WHERE	strSSCC = @sscc  
    		INSERT INTO SEBAS009.Aproz.dbo.tPalProd 
    		VALUES (@dtDate, @dtTime, @sscc, @strOrder, @strArtNr, @nPalNr, 
    				@strMDH, 0, @nFinish) 
    		IF @@ERROR = 0 
    			BEGIN 
    				SET @countinsert = @countinsert + 1 
    				PRINT 'SSCC: ' + @sscc + ' inséré dans la base.' 
    				UPDATE tPalProd SET nlog = -1 WHERE strSSCC = @sscc 
    			END 
    		ELSE 
    			PRINT 'Problème à l''insertion du SSCC: ' + @sscc + '.' 
    	END 
     
    FETCH NEXT FROM C_Export 
    INTO 	@sscc 
    END 
    CLOSE C_Export 
    DEALLOCATE C_Export
    Malheureusement, lors de l'exécution de la requête j'obtiens une réponse de mon serveur SQL qui me dit que je dois définir les codes ANSI_NULLS et ANSI_WARNINGS pour pouvoir exécuter cette opération. Ces deux codes sont définis dans ma procédure mais cela ne fonctionne pas... Quelqu'un l'a-t-il déjà fait?

    Je peux créer des tables, view mais les procédures ne fonctionnent pas!

    Note: J'utilise l'accès natif SQL Server

    MERCI!

  2. #2
    Membre expert
    Avatar de Emmanuel Lecoester
    Profil pro
    Inscrit en
    Février 2003
    Messages
    1 493
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : France, Nord (Nord Pas de Calais)

    Informations forums :
    Inscription : Février 2003
    Messages : 1 493
    Points : 3 266
    Points
    3 266
    Par défaut
    en générant un fichier texte contenant le source et en compilant ce ficheir ligne de commande ?

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Octobre 2005
    Messages
    9
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Octobre 2005
    Messages : 9
    Points : 7
    Points
    7
    Par défaut
    Mon code est le suivant:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    s_sql is a string = "CREATE PROCEDURE ....."
     
    IF NOT SqlExec(s_sql, "procedure") THEN
    RESULT 0
    ELSE
    RESULT 1
    END
    Voilà le texte de l'erreur:
    Heterogeneous queries require the ANSI_NULLS and ANSI_WARNINGS options to be set for the connextion. This ensures consistent query semantics. Enable thes options and then reissue your query.

  4. #4
    Membre expert
    Avatar de Emmanuel Lecoester
    Profil pro
    Inscrit en
    Février 2003
    Messages
    1 493
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : France, Nord (Nord Pas de Calais)

    Informations forums :
    Inscription : Février 2003
    Messages : 1 493
    Points : 3 266
    Points
    3 266
    Par défaut
    pour moi c'est une erreur SQLServer. A voir sur la partie spécifique de dvp.

  5. #5
    Futur Membre du Club
    Profil pro
    Inscrit en
    Octobre 2005
    Messages
    9
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Octobre 2005
    Messages : 9
    Points : 7
    Points
    7
    Par défaut
    L'exécution de la requête dans SQL Analyzer fonctionne parfaitement... C'est pour cela que je m'interroge sur la provenance de ce problème

  6. #6
    Membre expert
    Avatar de Emmanuel Lecoester
    Profil pro
    Inscrit en
    Février 2003
    Messages
    1 493
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : France, Nord (Nord Pas de Calais)

    Informations forums :
    Inscription : Février 2003
    Messages : 1 493
    Points : 3 266
    Points
    3 266
    Par défaut
    Une recherche option avancée dans le forum sqlserver vous aurez permis de trouver :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    SET ANSI_NULLS ON
    SET ANSI_PADDING ON
    SET ANSI_WARNINGS ON
    SET ARITHABORT ON
    SET CONCAT_NULL_YIELDS_NULL ON
    SET QUOTED_IDENTIFIER ON
    SET NUMERIC_ROUNDABORT OFF
    go
    ... votre procedure

  7. #7
    Futur Membre du Club
    Profil pro
    Inscrit en
    Octobre 2005
    Messages
    9
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Octobre 2005
    Messages : 9
    Points : 7
    Points
    7
    Par défaut
    Je connais relativement bien SQL Server car je travaille avec depuis pas mal de temps déjà. La procédure SQLExec() avec comme code:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SET ANSI_NULLS ON
    SET ANSI_WARNINGS ON
    GO
    CREATE PROCEDURE
    ...
    retourne une erreur "Syntaxe incorrecte au niveau du mot 'GO'"

    Ce n'est donc pas ma solution... Je continue des tests et recherche mais je ne trouve pour l'instant aucun élément de réponse...


  8. #8
    Futur Membre du Club
    Profil pro
    Inscrit en
    Octobre 2005
    Messages
    9
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Octobre 2005
    Messages : 9
    Points : 7
    Points
    7
    Par défaut
    Hello Guardian!

    Je crois que j'ai enfin trouvé ma solution Il me faut simplement activer le ANSI_WARNINGS et le ANSI_NULLS au niveau de mon serveur de base de données! Propriétés du serveur -> Tab Connexions et là il y a les infos dont j'ai besoin

    Le mot 'GO' n'est apparemment pas supporté lors de l'exécution d'une requête SQL avec SQLExec sous WinDev. Le code:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    SET ANSI_NULLS ON
    SET ANSI_WARNINGS ON
    GO
    CREATE PROCEDURE...
    fonctionne très bien sous QA (Query Analyzer) mais ne passe pas le cap sous WinDev

    ABE!
    See ya et merci

    Note: j'en enfin mis les balises CODE :p

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

Discussions similaires

  1. [Débutant] Retour d'une procédure stockée Oracle avec paramètre NULL
    Par Hobbi1 dans le forum VB.NET
    Réponses: 4
    Dernier message: 22/12/2014, 19h07
  2. [WD14] Procédure Stockée déphasée avec Analyse
    Par no_me_entero dans le forum WinDev
    Réponses: 10
    Dernier message: 20/03/2013, 11h01
  3. Réponses: 15
    Dernier message: 18/11/2008, 17h41
  4. [ODBC] Lancer une procédure stockée SQLServer 2k5 en tâche de fond
    Par sdisp+ dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 10/09/2008, 08h04
  5. [Procédure stockée]Insert avec renvoi clé primaire?
    Par busmik dans le forum Décisions SGBD
    Réponses: 3
    Dernier message: 26/08/2004, 16h14

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