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

MS SQL Server Discussion :

TRANSACTION sql serve 2005


Sujet :

MS SQL Server

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    105
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 105
    Points : 59
    Points
    59
    Par défaut TRANSACTION sql serve 2005
    Bonjour,

    Je demande votre aide car je n'y arrive decidement pas.
    Cette transaction dois regrouper 2 requetes (2 insert into).

    Malheuresement j'ai le message d'erreur suivant, que je n'arrive pas a resoudre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Warning: odbc_do(): SQL error: [Microsoft][ODBC SQL Server Driver][SQL Server]Le identificateur qui commence par 'CREATION_COMMANDEbeginSP_CREER_COMMANDE' est trop long. La longueur maximale est 32., SQL state 37000 IN SQLExecDirect IN c:\program files\easyphp1-8\www\pti_jv_admin_clients\jeuxvideo_clients\panier_4.php ON line 184
    Voici un extrait de mon code:

    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
    //TRANSACTION
    		$createcmd = "BEGIN TRANSACTION CREATION_COMMANDE"; //On démarre une transaction et on lui donne un nom
    		$createcmd .= "begin";
    		$createcmd .= "SP_CREER_COMMANDE '$idclient', '$datecmd', '$tot', '$liv' ";
    		//$rs=odbc_do($connection,$createcmd);
     
    		if ($createcmd)
    		{
    			// recupération de l'id de la commande par rapport
    			// au numéro client et à la dernière de ses commandes
    			$riq = "SP_RECUPCMD_COMMANDE '$idclient' ";
    			$rik=odbc_do($connection,$riq);
    			odbc_fetch_into($rik,$fiis);
    			$NumCd=$fiis[0];
     
    			foreach ($panier as $valeur=>$cde)
    			{
    				$sql15 = "SP_INFOJEU_JEUX_VIDEO '$valeur' ";
    				$req15=odbc_do($connection,$sql15);
    				// recupération du stck d'un produit
    				$stck=odbc_result($req15,'jv_qte');
    				$nbVente=odbc_result($req15,'jv_nbvente');
    				$newNbVente= $nbVente + $cde;
    				$newstock = $stck - $cde;
     
    				//mise à jour du stock
    				$udstock= "SP_MAJSTOCK_JEUX_VIDEO '$newstock', '$newNbVente', '$valeur' ";
    				$rudstock=odbc_do($connection,$udstock);
     
    				if($rudstock)
    				{
    						$createcmd.="SP_CREERARTICLECMD_LIGNECOMMANDE '$NumCd', '$valeur', '$cde' ";
    						$rsILS=odbc_do($connection,$createcmd);
     
    						if ($rsILS)
    						{
    							$createcmd .= " COMMIT TRANSACTION CREATION_COMMANDE "; //On commit la transaction
    							echo "<SCRIPT LANGUAGE='JavaScript'>alert('Votre commande à bien été prise en compte.');</SCRIPT>  ";
    							echo "	<h3 align=center>Votre commande à bien été prise en compte.<br/> <a href=ResumerCommande.php  class=type1> Voir le résumer de la commande</a></h3>";
    							echo '<script language="javascript">document.location.href = "ResumerCommande.php"</script>';
    							$_SESSION['RefCmd']= $NumCd;
    							unset($_SESSION['panier']);
    						}// si il y a eu des erreurs
    						else 
    						{
    							echo 'Une erreure est survenue';
    							$createcmd .= " ROLLBACK TRANSACTION CREATION_COMMANDE "; //On annule tous les changements de cette transaction
    						}
    //FIN TRANSACTION						
    				}
    				else
    				{
    					echo 'Une erreure est survenue';
    				}
    			}
    		}
    Merci pour votre aide

  2. #2
    Membre actif
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Juillet 2007
    Messages
    193
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2007
    Messages : 193
    Points : 213
    Points
    213
    Par défaut
    il manque des espaces dans les chaines concaténées. Espace ou retour a la ligne au choix
    Fabian M. - DBA Sql server 2008R2.
    Apprenti Admin Système 2008 R2
    Développeur SSRS, SQL
    Développement C# en hobby

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    105
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 105
    Points : 59
    Points
    59
    Par défaut
    Bonjour,

    Cela ne marche pas j'ai toujour le même message d'erreur

  4. #4
    Rédacteur
    Avatar de WOLO Laurent
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Mars 2003
    Messages
    2 741
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : Congo-Brazzaville

    Informations professionnelles :
    Activité : Architecte de base de données
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2003
    Messages : 2 741
    Points : 4 414
    Points
    4 414
    Par défaut
    Citation Envoyé par meddy Voir le message
    Bonjour,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    //TRANSACTION
    		$createcmd = "BEGIN TRANSACTION CREATION_COMMANDE"; //On démarre une transaction et on lui donne un nom
    		$createcmd .= "begin";
    		$createcmd .= "SP_CREER_COMMANDE '$idclient', '$datecmd', '$tot', '$liv' ";
    		//$rs=odbc_do($connection,$createcmd);
    Je ne connais pas php mais le resultat de ce code donne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $createcmd = "BEGIN TRANSACTION CREATION_COMMANDEbeginSP_CREER_COMMANDE .......
    Ce qui en fait un identificateur trop long.

    Découvrez la FAQ de MS SQL Server.
    La chance accorde ses faveurs aux esprits avertis !

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    105
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 105
    Points : 59
    Points
    59
    Par défaut
    je viens pourtant de tester avec des espaces.

    Merci

Discussions similaires

  1. [SQL Serve 2005 / Appli web] Problème d'apostrophe
    Par ndsaerith dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 15/06/2010, 17h11
  2. journal de transaction sql server 2005
    Par alicia26 dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 03/09/2008, 17h19
  3. [SQL Serv 2005 Express]Access-->Sql Serveur
    Par wishmasteer dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 27/11/2007, 09h24
  4. Réponses: 3
    Dernier message: 30/06/2007, 13h08
  5. connexion projet Access à SQl serv 2005 exp
    Par a29595 dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 25/01/2007, 19h44

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