• Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 274
  • Last Modified:

ODBC/CRecordset & Null characters

MS Access has no trouble allowing the null character in a text field, and MS C++ has no trouble allowing the null character in a CString.  However, when I construct a CString with the null character in the middle, CString("Hi\0Joe",7) and then use AddNew to write that field into an Access database text field, the string gets truncated at the \0.

Anyone know a fix for this?
0
gnewman
Asked:
gnewman
  • 2
1 Solution
 
mbhaktaCommented:
There are several reasons why this is happening. One of the major reasons is your CString is nothing but an internal typecast of LPCSTR. A '\0' indicates a null termination and end of string. Hence, the problem.

May I ask you what you are trying to achieve with this technique ?
0
 
gnewmanAuthor Commented:
In your DoDataExchange function use RFX_Binary() rather than RFX_Text().  RFX_Binary requires a parameter of type CByteArray&, so either convert your CString to a CByteArray or use CByteArray to manipulate your strings rather than CString.
0
 
rhgaracciCommented:
Will RFX_Binary() work if the field type in the database table is text?  I'm under the impression that it only works if the field type is VARBINARY which I can't create in MS-Acess 2.0
0
 
gnewmanAuthor Commented:
It should work as ODBC supports conversions between all character types and SQL_VARBINARY.  Try it.  If it doesn't work the way you want, you may need to make your own RFX_ function.
0

Featured Post

[Webinar] Improve your customer journey

A positive customer journey is important in attracting and retaining business. To improve this experience, you can use Google Maps APIs to increase checkout conversions, boost user engagement, and optimize order fulfillment. Learn how in this webinar presented by Dito.

  • 2
Tackle projects and never again get stuck behind a technical roadblock.
Join Now