Solved

How do I limit the number of characters returned in a variable.

Posted on 2008-06-09
7
1,032 Views
Last Modified: 2012-08-13
I am receiving the following error with this formula in Crystal XI.

A string can be at most 65534 characters long.

How do I limit the number of characters returned?

Here is the formula that the report is bombing out on.
 

whileprintingrecords;

stringvar x:=x+{Database.NOTES}
 

Type = String and Length is 1000

Open in new window

0
Comment
Question by:angeleam
  • 4
  • 3
7 Comments
 
LVL 100

Expert Comment

by:mlmcc
ID: 21747550
Do you need to display the full string even if it is over 64K?

You can do this

If Len(x) < 64533 then
   x := x + {Database.NOTES}

If you need to display the full string there are ways using arrays of strings.

mlmcc
0
 

Author Comment

by:angeleam
ID: 21752259
I don't need to print if it is over 64. when I use this formula I receive an error: The ) is missing. and it highlights (x)
0
 
LVL 100

Expert Comment

by:mlmcc
ID: 21752322
Did you add that to your formula as shown below.

whileprintingrecords;
stringvar x;
If Len(x) < 64533 then
   x := x + {Database.NOTES}

mlmcc
0
What Is Threat Intelligence?

Threat intelligence is often discussed, but rarely understood. Starting with a precise definition, along with clear business goals, is essential.

 

Author Comment

by:angeleam
ID: 21754406
I left out the ;. I think this formula will work for me. Thank you for your reply.
0
 

Author Comment

by:angeleam
ID: 21756464
After validating my data how would display the text if it is over 65534?
0
 
LVL 100

Accepted Solution

by:
mlmcc earned 500 total points
ID: 21762847
If it is over 64K then you need to use an array of strings.

whileprintingrecords;
stringvar array x := [""];
numbervar currentindex := 1;

If Len(x[currentindex]) < 64533 then
   x[currentindex] := x[currentindex] + {Database.NOTES}
else
(
    currentindex := currentindex + 1;
    ReDim Preserve x[currentindex];
   x[currentindex] := x[currentindex] + {Database.NOTES};    
);

To display you will need several display formulas
First String
whileprintingrecords;
stringvar array x;
x[1]

second string
whileprintingrecords;
stringvar array x;
numbervar currentindex;
If currentindex > 1 then
    x[2]

thrid string
whileprintingrecords;
stringvar array x;
numbervar currentindex;
If currentindex > 2 then
    x[3]

mlmcc

0
 

Author Comment

by:angeleam
ID: 21763247
Thank You
0

Featured Post

How to improve team productivity

Quip adds documents, spreadsheets, and tasklists to your Slack experience
- Elevate ideas to Quip docs
- Share Quip docs in Slack
- Get notified of changes to your docs
- Available on iOS/Android/Desktop/Web
- Online/Offline

Join & Write a Comment

I hate sub reports and always consider them the last resort in any reporting solution.  The negative effect on performance and maintainability is just not worth the easy ride they give the report writer.  Nine times out of ten reporting requirements…
There have always been a lot of questions related to when Crystal Reports evaluates report components (such as formulas, summaries, cross-tabs, charts, to name a few examples). Crystal Reports uses a two-pass reporting process to provide greater …
This demo shows you how to set up the containerized NetScaler CPX with NetScaler Management and Analytics System in a non-routable Mesos/Marathon environment for use with Micro-Services applications.
This video demonstrates how to create an example email signature rule for a department in a company using CodeTwo Exchange Rules. The signature will be inserted beneath users' latest emails in conversations and will be displayed in users' Sent Items…

760 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

21 Experts available now in Live!

Get 1:1 Help Now