Réconciliation des modifications effectuées par plusieurs utilisateurs
Dans certains environnements, plusieurs utilisateurs peuvent modifier le même objet simultanément. Des utilisateurs peuvent par exemple mettre à jour la structure d'un objet dans Concepteur de tables ou le Concepteur de schémas de base de données ou modifier les valeurs du volet Résultats des Concepteurs de requêtes et de vues. Cette situation peut provoquer des conflits que vous devez résoudre.
Conflits dans le Concepteur de tables ou le Concepteur de schémas de base de données
Par exemple, un autre utilisateur peut supprimer ou renommer une table pendant que vous l'utilisez ou que vous travaillez avec une table connexe dans le Concepteur de tables. Si vous tentez d'enregistrer votre table, la boîte de dialogue Modifications détectées dans la base de données (Concepteur de base de données) vous avertit que la base de données a été modifiée depuis que vous avez ouvert la table.
Elle affiche également la liste des objets de base de données qui seront affectés si vous enregistrez la table. À ce stade, vous pouvez prendre une des mesures suivantes :
Choisissez Oui pour enregistrer votre table et mettre à jour la base de données avec toutes les modifications dans la liste.
Cette action peut affecter des tables qui partagent les mêmes objets de base de données. Par exemple, supposons que vous modifiiez la colonne au_id de la table titleauthors alors qu'un autre utilisateur travaille sur la table authors, reliée à la table titleauthors par la colonne au_id. L'enregistrement de votre table affecte la table de l'autre utilisateur. De la même façon, un autre utilisateur peut définir une contrainte de validation de la colonne qty de la table sales. Si vous supprimez la colonne qty, puis enregistrez la table sales, la contrainte de validation de l'autre utilisateur est affectée.
Choisissez Non pour annuler l'opération d'enregistrement.
Vous pouvez alors fermer la table sans l'enregistrer. Lorsque vous la rouvrirez, son contenu correspondra à celui de la base de données.
Choisissez Enregistrer comme fichier texte pour enregistrer une liste des modifications.
Cette liste des modifications apportées à la base de données s'affiche dans la boîte de dialogue Modifications détectées dans la base de données ; vous pouvez l'enregistrer dans un fichier texte, dans lequel vous pourrez examiner ce qui a motivé les changements apportés par les autres utilisateurs. Par exemple, si un autre utilisateur a modifié une table sur laquelle vous avez placé un marqueur de suppression, vous voudrez peut-être savoir s'il faut vraiment supprimer la table avant de mettre la base de données à jour.
Conflits dans le Concepteur de requêtes et de vues
Si vous exécutez une requête ou retournez les résultats d'une vue, les données s'affichent dans le volet Résultats. Plusieurs utilisateurs peuvent travailler simultanément sur le même jeu de données, ce qui risque de provoquer des conflits.
Par exemple, supposons qu'une collègue et vous-même exécutiez chacun une requête d'affichage de toutes les données contenues dans la table titleauthors. Votre collègue remplace le prénom du premier enregistrement retourné, Barb, par Barbara. À ce stade, la base de données contient Barbara dans ce champ, alors que votre jeu de résultats affiche toujours Barb. À présent, vous tapez Barbara et cliquez en dehors de la ligne. Un message s'affiche pour vous demander de quelle manière vous souhaitez résoudre le conflit.
Cliquez sur Oui pour mettre à jour la base de données avec vos modifications.
Cette option substitue les modifications de votre collègue.
Cliquez sur Non pour mettre à jour votre jeu de résultats en fonction de la base de données.
Cette option remplace vos modifications par celles de votre collègue.
Cliquez sur Annuler pour poursuivre la modification sans résoudre le conflit.
Dans ce cas, vous ne pouvez pas valider les modifications apportées à la base de données.
Voir aussi
Tâches
Comment : générer des scripts de modification
Référence
Modifications détectées dans la base de données, boîte de dialogue (Concepteur de bases de données)