Microsoft KB Archive/120888

= FIX: Assertion Fails When Use RFX_Text w/ SQL_VARCHAR Column =

Article ID: 120888

Article Last Modified on 11/21/2006

-

APPLIES TO

 Microsoft Foundation Class Library 4.2, when used with:  Microsoft Visual C++ 1.5 Professional Edition

 Microsoft Visual C++ 1.51

 Microsoft Visual C++ 2.0 Professional Edition

 Microsoft Visual C++ 2.0 Professional Edition</li></ul> </li></ul>

-

<div class="notice_section">

This article was previously published under Q120888

<div class="symptoms_section">

SYMPTOMS
An assertion failure occurs when using RFX_Text with a column of type SQL_VARCHAR that has a column width greater than 255 bytes.

<div class="cause_section">

CAUSE
The column width for a column with SQL type of SQL_VARCHAR is usually less than 256 bytes. The ASSERT on line 1747 is verifying that the column width is less than 256 bytes unless the column type is SQL_LONGVARCHAR or SQL_LONGBINARY. However some drivers implement SQL_VARCHAR type columns that allow more than 255 bytes; in which case, the assertion is not valid.

<div class="status_section">

STATUS
Microsoft has confirmed this to be a bug in the Microsoft products listed at the beginning of this article. This bug was corrected in Visual C++ versions 1.52 and 2.1.

<div class="resolution_section">

RESOLUTION
The problem occurs in the function CFieldExchange::GetColumnType. Because this function is not virtual, there is no easy workaround.

You could replace the GetColumnType function as well as the RFX_Text function but that would entail adding all of the RFX_Text function to your application to take care of a problem occurs only in a _DEBUG build because ASSERTs are removed in release builds.

Instead of re-implementing RFX_Text here are two other approaches:

 Ignore the invalid assertion failure by choosing the Ignore button on the Assertion failed message box. This might not be an option if the assertion failure is raised frequently.</li>  Modify the assertion in the MFC code. This requires that you rebuild the MFC libraries. For details on rebuilding the MFC Libraries, please see the section titled "How To Build Other Library Versions" in the "Class Library User's Guide." Or read the README.TXT file located in the MFC source directory (the default is: \MSVC\MFC\SRC). To modify the assertion, change the code in the CFieldExchange::GetColumnType function in DBRFX.CPP: From: ASSERT(dwT <= 255 || nSqlType == SQL_LONGVARBINARY ||            nSqlType == SQL_LONGVARCHAR);

To:

ASSERT(dwT <= 255 || nSqlType == SQL_VARCHAR ||            nSqlType == SQL_LONGVARBINARY ||             nSqlType == SQL_LONGVARCHAR); </li></ul>

Additional query words: 1.50 2.00 2.50 2.51 3.00 ORACLE

Keywords: kbbug kbfix kbdatabase KB120888

-

[mailto:TECHNET@MICROSOFT.COM Send feedback to Microsoft]

© Microsoft Corporation. All rights reserved.