BookmarkSubscribeRSS Feed
🔒 This topic is solved and locked. Need further help from the community? Please sign in and ask a new question.
SASame
Fluorite | Level 6

Software Versions:     SAS EG 6.1,     MS Office 2010 Pro Plus 2010 ,     SQL Server 2014,     Linux 2.6.32-754.6.3.el6.x86_64

 

Data is received from various countries in Excel. Some text fields contain special foreign characters. Import via the wizard is not used because numeric fields can have bogus text such as 'N/A', which throws off the data types. Worksheets from each country are saved as tab delimited files and copied to Linux folders from where they're concatenated in SAS Enterprise Guide via a FILENAME statement and then input by a data step. In the data step, the INFILE statement has    dsd dlm='09'x ENCODING='LATIN9'.

 

Everything works fine until the data is uploaded to SQL Server.

 

To upload, first a libname mylib  statement signs on to the right datasrc and schema. Then proc sql is used to execute the following:
create table mylib.mytable as select * from mySASdataset;

 

The problem is that all text fields in SQL Server are uploaded as varchar ... not Nvarchar (i.e. unicode).

 

1. In this case, does varchar instead of Nvarchar mean that various special foreign characters might not be supported.
2. If so, how can the Nvarchar data type be forced for the fields that may contain special foreign characters?

 

1 ACCEPTED SOLUTION

Accepted Solutions
SASame
Fluorite | Level 6

Hi Suryakiran,

FANTASTIC !!!    Thank you so much !!!

-Peter

View solution in original post

2 REPLIES 2
SuryaKiran
Meteorite | Level 14

Hi,

 

When loading into SQL Server only default Data Types are used by SQL Server interface. Check this document for Default SQL Server data types.

 

You may have to explicitly specify the format.

1) Create a LIBNAME with connection=global and dbmstemp=yes

2) Using pass-through create an empty table in SQL Server with required formats.

3) Now, load the data into the empty table.

 

You need to setup a single connection to SQL Server that shared by multiple proc steps and data steps (step 1 does that).

 

This paper might help you some: https://www.lexjansen.com/sesug/2018/SESUG2018_Paper-154_Final_PDF.pdf

 

 

Thanks,
Suryakiran
SASame
Fluorite | Level 6

Hi Suryakiran,

FANTASTIC !!!    Thank you so much !!!

-Peter

SAS Innovate 2025: Register Now

Registration is now open for SAS Innovate 2025 , our biggest and most exciting global event of the year! Join us in Orlando, FL, May 6-9.
Sign up by Dec. 31 to get the 2024 rate of just $495.
Register now!

How to connect to databases in SAS Viya

Need to connect to databases in SAS Viya? SAS’ David Ghan shows you two methods – via SAS/ACCESS LIBNAME and SAS Data Connector SASLIBS – in this video.

Find more tutorials on the SAS Users YouTube channel.

Discussion stats
  • 2 replies
  • 867 views
  • 0 likes
  • 2 in conversation