MSDASQL-Anbieter Handles nicht korrekt Negatively skaliert SQL_NUMERIC_STRUCT Werte

SPRACHE AUSWÄHLEN SPRACHE AUSWÄHLEN
Artikel-ID: 274604 - Produkte anzeigen, auf die sich dieser Artikel bezieht
Dieser Artikel wurde archiviert. Er wird im vorliegenden Zustand bereitgestellt und nicht mehr aktualisiert.
Alles erweitern | Alles schließen

Problembeschreibung

Beim Lesen negativ skalierte numerische Werte aus einem ODBC-Treiber mithilfe der OLE DB-Provider für ODBC (MSDASQL) mit der Enumeration (ActiveX Data Objects) AdUseClient Cursor werden die Werte, die zurückgegeben werden abgeschnitten.

Lösung

Installieren Sie das neueste Servicepack für Microsoft MDAC 2.5, um dieses Problem zu beheben. Weitere Informationen finden Sie die folgende KB-Artikelnummer:
293312INFO: Wie erhalten Sie die neueste MDAC 2.5 Servicepack
Die englische Version dieses Updates weist die in der nachstehenden Tabelle aufgelisteten Dateiattribute (oder höher) auf. Die Datums- und Uhrzeitangaben für diese Dateien werden in Coordinated Universal Time () angegeben. Wenn Sie sich die Dateiinformationen ansehen, werden diese Angaben in die lokale Zeit konvertiert. Um die Differenz zwischen UTC und der Ortszeit zu ermitteln verwenden Sie die Registerkarte Zeitzone des Tools ? Datum und Uhrzeit in der Systemsteuerung.
   Date         Time   Version      Size     File Name
   --------------------------------------------------------------------
   31-Jan-2001  18:20  2.53.6131.0  303,376  Msdasql.dll
   31-Jan-2001  18:18  2.53.6131.0   16,384  Msdasqlr.dll
   31-Jan-2001  18:20  2.53.6131.0   78,096  Msdatl2.dll
   31-Jan-2001  18:20  2.53.6131.0   53,520  Msdatt.dll
   28-Feb-2001  18:00  1.10.101.0   484,408  Q277033_w2k_sp3_x86_en.exe
				

Abhilfe

Verwenden Sie die AdUseServer Enumeration für die ADO- CursorLocation -Eigenschaft anstelle der AdUseClient , um dieses Problem zu umgehen.

Status

Microsoft hat bestätigt, dass es sich hierbei um ein Problem bei den in diesem Artikel genannten Microsoft-Produkten handelt. Dieses Problem wurde erstmals im Microsoft MDAC 2.5 Service Pack 3.

Weitere Informationen

Wenn Sie ein ADO- Recordset -Objekt gegen alle ODBC-Treiber öffnen, wird der OLE DB-Provider für ODBC (MSDASQL) verwendet, um ODBC OLEDB-Übersetzungsdienste zur Verfügung stellen. Wenn das Resultset, das angefordert wird ein numerisches Feld enthält und Sie die AdUseClient -Enumeration der CursorLocation -Eigenschaft verwenden, versucht ADO den Wert des numerischen Feldes in einer OLE DB DB_NUMERIC-Struktur abrufen.

Wenn der zugrunde liegende ODBC-Treiber meldet, dass es ODBC 3.0 kompatibel ist, versucht MSDASQL zum Binden an SQL_NUMERIC_STRUCT Werte direkt anstelle der Bindung zu einer Zeichenfolge. Verfügt SQL_NUMERIC_STRUCT, die der Treiber gibt eine negative Skalierung, wenn der Client den MSDASQL-Anbieter einen DB_NUMERIC-Wert anfordert MSDASQL konvertiert zuerst die SQL_NUMERIC_STRUCT in einen DB_VARNUMERIC Wert und konvertiert in eine DB_NUMERIC-Wert. Die letzte Konvertierung ein DB_NUMERIC-Wert ist falsch verarbeitet, wenn die Skalierung ist negativ, wodurch ein Wert abgeschnitten.

Eigenschaften

Artikel-ID: 274604 - Geändert am: Montag, 24. Februar 2014 - Version: 3.1
Die Informationen in diesem Artikel beziehen sich auf:
  • Microsoft Data Access Components 1.5
  • Microsoft Data Access Components 2.0
  • Microsoft Data Access Components 2.1
  • Microsoft Data Access Components 2.1 Service Pack 2
  • Microsoft Data Access Components 2.5
Keywords: 
kbnosurvey kbarchive kbmt kbhotfixserver kbqfe kbmdac250sp3fix kbbug kbfix KB274604 KbMtde
Maschinell übersetzter Artikel
Wichtig: Dieser Artikel wurde maschinell und nicht von einem Menschen übersetzt. Die Microsoft Knowledge Base ist sehr umfangreich und ihre Inhalte werden ständig ergänzt beziehungsweise überarbeitet. Um Ihnen dennoch alle Inhalte auf Deutsch anbieten zu können, werden viele Artikel nicht von Menschen, sondern von Übersetzungsprogrammen übersetzt, die kontinuierlich optimiert werden. Doch noch sind maschinell übersetzte Texte in der Regel nicht perfekt, insbesondere hinsichtlich Grammatik und des Einsatzes von Fremdwörtern sowie Fachbegriffen. Microsoft übernimmt keine Gewähr für die sprachliche Qualität oder die technische Richtigkeit der Übersetzungen und ist nicht für Probleme haftbar, die direkt oder indirekt durch Übersetzungsfehler oder die Verwendung der übersetzten Inhalte durch Kunden entstehen könnten.
Den englischen Originalartikel können Sie über folgenden Link abrufen: 274604
Microsoft stellt Ihnen die in der Knowledge Base angebotenen Artikel und Informationen als Service-Leistung zur Verfügung. Microsoft übernimmt keinerlei Gewährleistung dafür, dass die angebotenen Artikel und Informationen auch in Ihrer Einsatzumgebung die erwünschten Ergebnisse erzielen. Die Entscheidung darüber, ob und in welcher Form Sie die angebotenen Artikel und Informationen nutzen, liegt daher allein bei Ihnen. Mit Ausnahme der gesetzlichen Haftung für Vorsatz ist jede Haftung von Microsoft im Zusammenhang mit Ihrer Nutzung dieser Artikel oder Informationen ausgeschlossen.

Ihr Feedback an uns

 

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