Erreur de modèle: « INSERT a échoué » lorsque vous Update table de référence dans une vue indexée

Traductions disponibles Traductions disponibles
Numéro d'article: 305333 - Voir les produits auxquels s'applique cet article
Agrandir tout | Réduire tout

Symptômes

Lorsque vous exécutez une procédure stockée ou une instruction INSERT SQL directement, qui essaie d'insérer une ligne dans une table qui est référencé dans une vue indexée, l'erreur suivante peut se produire :
INSERT a échoué car les options SET suivantes ont des paramètres incorrects: « ARITHABORT »
En outre, cette erreur peut se produire même si « SET ARITHABORT ON » est inclus dans le lot ou une procédure stockée qui essaie de L'INSERTION.

Cause

Pour insérer correctement une ligne dans une table qui est référencée dans une vue indexée, le paramètre de configuration SQL ARITHABORT doit indiquer sur. En outre, l'instruction qui s'applique ce paramètre de configuration doit être exécutée dans sa propre lot. Étant donné que les procédures stockées contiennent uniquement un lot, ajoutant l'instruction à la procédure ne fonctionne pas.

Résolution

Pour résoudre ce problème, ajoutez le code ADO suivant à votre application après avoir ouvert la connexion à votre base de données :
MyConnection.Execute "SET ARITHABORT ON"
				
MyConnection est une référence à l'objet de connexion ADO vous utilisez pour exécuter la procédure stockée qui effectue un INSERT ou l'instruction INSERT SQL.

Statut

Ce comportement est voulu par la conception même du produit.

Plus d'informations

SET ARITHABORT ON est un des options n'est pas automatiquement définie pour les connexions qui utilisent le fournisseur OLE DB pour SQL Server ou le pilote ODBC SQL Server. Parce que les connexions OLE DB et ODBC ne spécifient pas un paramètre de ARITHABORT, les connexions par défaut pour le défaut de serveur, ce qui est ARITHABORT DÉSACTIVÉE.

Références

Pour plus d'informations, reportez-vous aux rubriques « Création d'un indexées View » et « création d'un index » dans la en ligne de SQL Server 2000.

Propriétés

Numéro d'article: 305333 - Dernière mise à jour: jeudi 8 mai 2003 - Version: 2.2
Les informations contenues dans cet article s'appliquent au(x) produit(s) suivant(s):
  • Microsoft ActiveX Data Objects 2.6 sur le système suivant
    • Microsoft SQL Server 2000 Standard
  • Microsoft ActiveX Data Objects 2.7 sur le système suivant
    • Microsoft SQL Server 2000 Standard
Mots-clés : 
kbmt kbprb KB305333 KbMtfr
Traduction automatique
IMPORTANT : Cet article est issu du système de traduction automatique mis au point par Microsoft (http://support.microsoft.com/gp/mtdetails). Un certain nombre d?articles obtenus par traduction automatique sont en effet mis à votre disposition en complément des articles traduits en langue française par des traducteurs professionnels. Cela vous permet d?avoir accès, dans votre propre langue, à l?ensemble des articles de la base de connaissances rédigés originellement en langue anglaise. Les articles traduits automatiquement ne sont pas toujours parfaits et peuvent comporter des erreurs de vocabulaire, de syntaxe ou de grammaire (probablement semblables aux erreurs que ferait une personne étrangère s?exprimant dans votre langue !). Néanmoins, mis à part ces imperfections, ces articles devraient suffire à vous orienter et à vous aider à résoudre votre problème. Microsoft s?efforce aussi continuellement de faire évoluer son système de traduction automatique.
La version anglaise de cet article est la suivante: 305333
L'INFORMATION CONTENUE DANS CE DOCUMENT EST FOURNIE PAR MICROSOFT SANS GARANTIE D'AUCUNE SORTE, EXPLICITE OU IMPLICITE. L'UTILISATEUR ASSUME LE RISQUE DE L'UTILISATION DU CONTENU DE CE DOCUMENT. CE DOCUMENT NE PEUT ETRE REVENDU OU CEDE EN ECHANGE D'UN QUELCONQUE PROFIT.

Envoyer des commentaires

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com