Solved

Problem tranforming field for adding to database

Posted on 2008-06-13
2
160 Views
Last Modified: 2010-04-21
I have the following piece of code:

      INSERT INTO dbo.crmContactTypes
      (
      ContactRef, Contact_Type, Volunteer, Region, Owner
      )
      SELECT DISTINCT
                                      TOP (100) PERCENT InitialData.right('00000' + cast(Contact_Migration_Ref as varchar(5)),5), Contact_Type.CRM_Contact_Type_ID,
                                      crmContactData.Volunteer_Flag, InitialData.[PSYBT Area], Owner.CRM_User_ID
      FROM         InitialData INNER JOIN
                                      Contact_Type ON InitialData.Code = Contact_Type.Code INNER JOIN
                                      Owner ON InitialData.Owner = Owner.Owner LEFT OUTER JOIN
                                      crmContactData ON InitialData.Contact_Migration_Ref = crmContactData.ContactRef COLLATE Latin1_General_CI_AI
      WHERE     (InitialData.LstNm IS NOT NULL) AND (InitialData.Contact_Migration_Ref IS NOT NULL) AND
                                      (Contact_Type.CRM_Contact_Type_ID <> 99) OR
                                      (InitialData.Contact_Migration_Ref IS NOT NULL) AND (Contact_Type.CRM_Contact_Type_ID <> 99) AND (InitialData.Position IS NOT NULL)

but when I run it I receive the following error:

Msg 156, Level 15, State 1, Procedure BusinessContactsUpdate, Line 114
Incorrect syntax near the keyword 'right'.

Now I know where the error is located: InitialData.right('00000' + cast(Contact_Migration_Ref as varchar(5)),5) but the problem I have is that the data being selected here is being translated as an int even though it's nvarchar. The data in this field is something like 01234 or 00070 but the starting 0s are being removed.

I need to be able to ensure that the starting 0s are not being removed from the code and assumed I'd be able to put something like the above code into my statement. I've used code like this before to perform the transformation but for some reason it's not working this time around.

Any ideas appreciated.
0
Comment
Question by:Steven O'Neill
2 Comments
 
LVL 43

Accepted Solution

by:
TimCottee earned 500 total points
ID: 21777103
Hello u101440,

Why do you have "InitialData." in there, Right is a keyword not a method.

      SELECT DISTINCT
                                      TOP (100) PERCENT Right('00000' + cast(Contact_Migration_Ref as varchar(5)),5), Contact_Type.CRM_Contact_Type_ID,
                                      crmContactData.Volunteer_Flag, InitialData.[PSYBT Area], Owner.CRM_User_ID

Should work.

Regards,

TimCottee
0
 
LVL 2

Author Closing Comment

by:Steven O'Neill
ID: 31466866
You know when you've been coding for a very looooong number of hours and the simpliest solutions always go by you...moved the initialdata table reference in the statement and all works. Thanx
0

Featured Post

Top 6 Sources for Identifying Threat Actor TTPs

Understanding your enemy is essential. These six sources will help you identify the most popular threat actor tactics, techniques, and procedures (TTPs).

Join & Write a Comment

by Mark Wills Attending one of Rob Farley's seminars the other day, I heard the phrase "The Accidental DBA" and fell in love with it. It got me thinking about the plight of the newcomer to SQL Server...  So if you are the accidental DBA, or, simp…
So every once in a while at work I am asked to export data from one table and insert it into another on a different server.  I hate doing this.  There's so many different tables and data types.  Some column data needs quoted and some doesn't.  What …
Excel styles will make formatting consistent and let you apply and change formatting faster. In this tutorial, you'll learn how to use Excel's built-in styles, how to modify styles, and how to create your own. You'll also learn how to use your custo…
Here's a very brief overview of the methods PRTG Network Monitor (https://www.paessler.com/prtg) offers for monitoring bandwidth, to help you decide which methods you´d like to investigate in more detail.  The methods are covered in more detail in o…

744 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

11 Experts available now in Live!

Get 1:1 Help Now