bonjour StringBuilder,
lorsque j'utilse "begin transaction" toutes les lignes de la table devient non modifiable.
bonjour StringBuilder,
lorsque j'utilse "begin transaction" toutes les lignes de la table devient non modifiable.
Bien sur que non.
On ne jouit bien que de ce qu’on partage.
Et il y a une différence entre :
- Je lock les lignes que j'ai modifié jusqu'à ce que je valide/invalide la transaction
- Je lock les lignes que je lis, jusqu'à ce que je valide/invalide la transaction
Le premier cas est implicite avec les transactions.
Le second cas n'est pris en charge que par hint : il faut indiquer au SGBD qu'on lock ou non la table/page/ligne qu'on lit.
On ne jouit bien que de ce qu’on partage.
Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
* * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *
mon problème est que lorsque j'utilise "begin transaction" et que j'ai deux utilisateurs qui ont l'accès en exclusivité à deux lignes différentes d'une même table, l'un après l'autre. par conséquence le deuxième ne peut modifier la ligne dont il a l'accée. .
merci.
Poste ton code, qu'on sache au moins comment tu verrouilles tes lignes.
En tout cas "begin transaction", sans instruction derrière, ne provoque absolument aucun verrou.
On ne jouit bien que de ce qu’on partage.
bonjour,
mon code est :
BEGIN TRAN
SELECT * FROM PCC_COM WITH (HOLDLOCK, ROWLOCK) WHERE CODE = '10'
COMMIT TRAN
durant exécution de "select" et avant "COMMIT TRAN" la table est verrouillé.
merci pour votre aide
Le responsable, c'est ton "with".
Il provoque un verrou exclusif sur la ligne lue.
Plus exactement, sur la page lue, car par défaut, SQL Server ne fait pas des verrous à la ligne, mais à la page.
Cf. blog de SQLPro pour plus d'informations sur le sujet.
On ne jouit bien que de ce qu’on partage.
Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
* * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *
bonjour;
j'ai trouver la solution; il faut que la table a une clé.
bonjour,
et maintenant, je veux savoir comment je peux savoir si une ligne est verrouillé ou non.
merci.
Vous avez un bloqueur de publicités installé.
Le Club Developpez.com n'affiche que des publicités IT, discrètes et non intrusives.
Afin que nous puissions continuer à vous fournir gratuitement du contenu de qualité, merci de nous soutenir en désactivant votre bloqueur de publicités sur Developpez.com.
Partager