Accueil > > > PROCÉDURE INSERTION OU MISE À JOUR DONNÉES D'UN UTILISATEUR
PROCÉDURE INSERTION OU MISE À JOUR DONNÉES D'UN UTILISATEUR
Information sur la source
Description
cette procédure a pour rôle de mettre à jour la table USER a partir d'un autre table ou vue si l'utilisateur existe déja, on va rafraichir les Informations si l'utilisateur n'existe pas, on va donc le créer
Source
- CREATE PROCEDURE dbo.AddOrUpdateUser
- AS
- DECLARE
- @MatriculeSalarie as nvarchar(50),
- @NumSalarie as nvarchar(50),
- @Nom as nvarchar(50),
- @Prenom as nvarchar(50),
- @Num_adherent as int,
- @Situation_Familiale as nvarchar(50),
- @Nb_Enfant as int,
- @Categorie as nvarchar(50),
- @Service as nvarchar(50),
- @Famille_Categorie as nvarchar(50)
-
-
-
-
- -- Utilisation d'un curseur pour parcourir tout les données
- DECLARE
- Curseur1 CURSOR FOR
- SELECT DISTINCT MatriculeSalarie, SA_CompteurNumero, Nom, Prenom, Num_Adhesion, SituationFamille, NB_Enfant, Catégorie, Service
- FROM VIEW_SAl_Information
- WHERE (DateHist IS NULL) AND (hstDate_Famil IS NULL)
- ORDER BY SA_CompteurNumero
-
-
-
- OPEN Curseur1
-
- FETCH NEXT FROM Curseur1 INTO @MatriculeSalarie , @NumSalarie , @Nom , @Prenom ,@Num_adherent , @Situation_Familiale ,@Nb_Enfant ,@Categorie , @Service
-
- WHILE @@FETCH_STATUS = 0
-
- BEGIN
- IF exists(SELECT Matricule FROM dbo.Dossier_Personnel WHERE (dbo.Dossier_Personnel.Matricule = @MatriculeSalarie))
- -- Dans cette partie, le Compte existe déja, on a donc juste besoin de rafraichir les Informations
- BEGIN
- UPDATE
- dbo.Dossier_Personnel
- SET
- dbo.Dossier_Personnel.Nom = @Nom,
- dbo.Dossier_Personnel.Prenom = @Prenom,
- dbo.Dossier_Personnel.Num_adherent = @Num_adherent,
- dbo.Dossier_Personnel.Situation_Familiale = @Situation_Familiale,
- dbo.Dossier_Personnel.Nb_Enfant = @Nb_Enfant,
- dbo.Dossier_Personnel.Categorie = @Categorie,
- dbo.Dossier_Personnel.Service = @Service
-
- WHERE
- dbo.Dossier_Personnel.Matricule = @MatriculeSalarie
- END
- ELSE
- -- Dans cette partie, le compte n'existe pas, on va donc le créer
- BEGIN
- INSERT INTO dbo.Dossier_Personnel
- (Matricule,
- NumSalarie,
- Nom,
- Prenom,
- Num_adherent,
- Situation_Familiale,
- Nb_Enfant,
- Categorie,
- Service)
- VALUES
- (@MatriculeSalarie,
- @NumSalarie,
- @Nom,
- @Prenom,
- @Num_adherent,
- @Situation_Familiale,
- @Nb_Enfant,
- @Categorie,
- @Service)
-
- END
-
- FETCH NEXT FROM Curseur1 INTO @MatriculeSalarie , @NumSalarie , @Nom , @Prenom ,@Num_adherent , @Situation_Familiale ,@Nb_Enfant ,@Categorie , @Service
-
- END
-
- CLOSE Curseur1
- DEALLOCATE Curseur1
-
CREATE PROCEDURE dbo.AddOrUpdateUser
AS
DECLARE
@MatriculeSalarie as nvarchar(50),
@NumSalarie as nvarchar(50),
@Nom as nvarchar(50),
@Prenom as nvarchar(50),
@Num_adherent as int,
@Situation_Familiale as nvarchar(50),
@Nb_Enfant as int,
@Categorie as nvarchar(50),
@Service as nvarchar(50),
@Famille_Categorie as nvarchar(50)
-- Utilisation d'un curseur pour parcourir tout les données
DECLARE
Curseur1 CURSOR FOR
SELECT DISTINCT MatriculeSalarie, SA_CompteurNumero, Nom, Prenom, Num_Adhesion, SituationFamille, NB_Enfant, Catégorie, Service
FROM VIEW_SAl_Information
WHERE (DateHist IS NULL) AND (hstDate_Famil IS NULL)
ORDER BY SA_CompteurNumero
OPEN Curseur1
FETCH NEXT FROM Curseur1 INTO @MatriculeSalarie , @NumSalarie , @Nom , @Prenom ,@Num_adherent , @Situation_Familiale ,@Nb_Enfant ,@Categorie , @Service
WHILE @@FETCH_STATUS = 0
BEGIN
IF exists(SELECT Matricule FROM dbo.Dossier_Personnel WHERE (dbo.Dossier_Personnel.Matricule = @MatriculeSalarie))
-- Dans cette partie, le Compte existe déja, on a donc juste besoin de rafraichir les Informations
BEGIN
UPDATE
dbo.Dossier_Personnel
SET
dbo.Dossier_Personnel.Nom = @Nom,
dbo.Dossier_Personnel.Prenom = @Prenom,
dbo.Dossier_Personnel.Num_adherent = @Num_adherent,
dbo.Dossier_Personnel.Situation_Familiale = @Situation_Familiale,
dbo.Dossier_Personnel.Nb_Enfant = @Nb_Enfant,
dbo.Dossier_Personnel.Categorie = @Categorie,
dbo.Dossier_Personnel.Service = @Service
WHERE
dbo.Dossier_Personnel.Matricule = @MatriculeSalarie
END
ELSE
-- Dans cette partie, le compte n'existe pas, on va donc le créer
BEGIN
INSERT INTO dbo.Dossier_Personnel
(Matricule,
NumSalarie,
Nom,
Prenom,
Num_adherent,
Situation_Familiale,
Nb_Enfant,
Categorie,
Service)
VALUES
(@MatriculeSalarie,
@NumSalarie,
@Nom,
@Prenom,
@Num_adherent,
@Situation_Familiale,
@Nb_Enfant,
@Categorie,
@Service)
END
FETCH NEXT FROM Curseur1 INTO @MatriculeSalarie , @NumSalarie , @Nom , @Prenom ,@Num_adherent , @Situation_Familiale ,@Nb_Enfant ,@Categorie , @Service
END
CLOSE Curseur1
DEALLOCATE Curseur1
Sources de la même categorie
Commentaires et avis
Discussions en rapport avec ce code source dans le forum
Curseur et procédure stockée erreur [ par humnanamouch ]
Bonjour J'ai un problème quand je veux modifier ma procédure stockée sous sql server. J'ai l'erreur "L'utilisateur n'a pas l'autorisati
Probleme de variable dans une procédure stockée [ par mastercatz ]
Bonjour A chaque fois que j'essaye de créer ma procédure stockée j'obtient la même erreur (parmis d'autres): Msg 1087, Level 15, State 2, Procedure v
Probleme de variable dans une procédure stockée [ par mastercatz ]
Bonjour A chaque fois que j'essaye de créer ma procédure stockée j'obtient la même erreur (parmis d'autres): Msg 1087, Level 15, State 2, Procedure v
fonction qui retourne un curseur [ par fatou69 ]
salut tout le monde, je suis en train de devellopez une fonction sous oracle qui permet de retourner un curseur et précisament une ou plusieurs lignes
SQL Server : concatenation [ par aieeeuuuuu ]
Bonjour, Je suis sous SQL server 2000, j'ai fait une procédure stockée qui prend deux paramétres. dans une autre procédure stockée, je veux appele
Insertion de données Ascenseur dans base de donnée [ par ecolopolo ]
Bonjour j'ai un problème avec ma base de donnée que je tente de créer... les informations de type ascenseur (ou <option....>.....
Statistique [ par biiru ]
Bonjours à tous,Une fois de plus je sollicite votre aide ^^En fait je dois faire une statistique d'un formulaire et je comptait la faire avec l'aide d
CLAUSE LIKE + procédure stockée. [ par KC62 ]
Bonjour a tous, voila j'ai un petit souci qui me pose de nombreux soucis car je n'arrive pas a le résoudre... Je souhaiterais éxécuté une procédure st
créer une procédure stockée qui renvoie des données [ par bossun ]
salut,je ne connais pas vraiment oracle. je voudrais créer une procédure stockée qui me renvoie des données pour des besoins spécifiques...dans sql se
Condition sur insertion [ par Myke ]
Bonjour à tous!J'utilise SqlServer 2000. J'ai une table avec plusieurs champ. Lorsqu'un utilisateur veut inserer un nouvel enregistrements je dois ver
|
Derniers Blogs
CSS CONTENT STATE SELECTORS (PERSONNAL DRAFT)CSS CONTENT STATE SELECTORS (PERSONNAL DRAFT) par FREMYCOMPANY
Bonjour à tous, Je viens de publier une proposition comprenant 5 pseudo-classes pour le CSS Working Group ayant trait à l'état de chargement d'un élément (ex: IMG,VIDEO,AUDIO,OBJECT pour l'HTML.). Si le c½ur vous en dit, vous pouvez retrouver cette p...
Cliquez pour lire la suite de l'article par FREMYCOMPANY MBA : POURQUOI FAIRE ET COMMENT LE CHOISIR ?MBA : POURQUOI FAIRE ET COMMENT LE CHOISIR ? par ROMELARD Fabrice
Formation initiale Durant la formation, le découpage classique est le suivant (je donnerai les équivalences Suisse lorsque je les connaîtrais) : Ecole primaire jusqu'au Collège : Formation générale permettant d'obtenir les méthodes...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice Y'A DES ERREURS QUI PEUVENT RENDRE LE DéVELOPPEUR VIOLENTY'A DES ERREURS QUI PEUVENT RENDRE LE DéVELOPPEUR VIOLENT par Aleks
Quand on a ce genre d'erreur sans log :
Et bas on a juste envie de choper le gas de Microsoft qu'a développé ça et lui foutre des baffes de Coboye ! ...
Cliquez pour lire la suite de l'article par Aleks [HYPER-V 3] PRéSENTATION DES COMMANDLETS POWERSHELL[HYPER-V 3] PRéSENTATION DES COMMANDLETS POWERSHELL par Pierrick CATRO-BROUILLET
Avec la sortie prochaine de la Beta Consumer Preview de Windows 8, j'avais envie de revenir sur une des fonctionnalités que j'attends le plus et que, en bon geek que je suis, j'utilise déjà : Hyper-V 3 ainsi son module PowerShell.
Il y a déjà pléthor...
Cliquez pour lire la suite de l'article par Pierrick CATRO-BROUILLET IIS7 - COMPRESSION GZIPIIS7 - COMPRESSION GZIP par cyril
La compression GZIP permet d'améliorer les performances de navigation en compressant ce qu'envoie le serveur à un client. Pour comprendre comment cela fonctionne, regardons ce qu'il se passe au niveau HTTP lorsqu'un client tente d'accéder à une ress...
Cliquez pour lire la suite de l'article par cyril
Logiciels
Easy-Planning (1.0.0.1)EASY-PLANNING (1.0.0.1)Basé sur les mêmes principes que MyPlanning, Easy-Planning permet de créer des plannings sous la ... Cliquez pour télécharger Easy-Planning Academy System (17.1.3.0)ACADEMY SYSTEM (17.1.3.0)Logiciel de gestion des établissements.
- élèves/étudiants (inscription, dossier, absence...)
-... Cliquez pour télécharger Academy System COLLECTOR PLUS (3.00B)COLLECTOR PLUS (3.00B)COLLECTOR PLUS version 3.00B est un logiciel utilisant une base de données alimentée par :
- L... Cliquez pour télécharger COLLECTOR PLUS PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V7.4)PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V7.4)PONAMEDIA TV DEVIENS HELLLOOO FLASH
LA TV SUR VOTRE ORDINATEUR.
Toute une plateforme Multi... Cliquez pour télécharger PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO LettresFaciles 2011 (8.0.0.1)LETTRESFACILES 2011 (8.0.0.1)LettresFaciles est un logiciel facilitant la création et la rédaction de lettres types.
Son inte... Cliquez pour télécharger LettresFaciles 2011
|