BookmarkSubscribeRSS Feed
Piku
Obsidian | Level 7

Dear Folk,

 

I have a requirement to read a text file(.sas code file) and save in to MS SQL server DB table(complete file in xml object column)by converting to xml format.

 

As of now I can create XML file on disk by SAS program and I can connect to MS SQL serve for DB transactions.

 

But here challenges in step wise way(all in SAS code) are ,

1) Read text file via SAS - Done

2) Convert aboveto xml object (not file) - How to do ?

3) Save this object to MS SQL DB - How to do ?

 

Requesting to please have the suggestions.

 

Regards,

Tushar Jain

7 REPLIES 7
LinusH
Tourmaline | Level 20
Just out of curiosity, what is the benefit of storing your SAS programs in XML objects?
Also, SAS programs is in clear text, so I can't see any benefit from having SAS to create the XML object. Go directly to SQL Server tools for this.
Data never sleeps
Piku
Obsidian | Level 7
XML object is required to save in Database table for reporting and archival purpose.
Piku
Obsidian | Level 7

I am assuming SAS will have xml object  like DB or C#.

If not, then by using SAS code how can we insert the complete file (by reading from disk) in to MS sql database(pass-through or lib name) ?

Kurt_Bremser
Super User

SAS has two data types: character and numeric. Since XML is text, you can store it in a character variable, provided that the XML in question does not exceed 32767 characters.

 

Tom
Super User Tom
Super User

You are going to have a problem moving a complete SAS program file (which could be thousands of lines long) into a single XML "object" in the server.  SAS has a 32K limit on the size of character variable.

 

So either move the original file line by line into an SQL server table and have the database transform it into an XML object.

Or move the XML file line by line into the SQL server and have the server combine the lines into a single blob/clob or whatever they use to store XML.

Piku
Obsidian | Level 7
Hell Tom,

If there is no way to move complete xml in one go then line by line is only option left(but i have not chose it because of it's inefficient).
I here want to convert complete file in to some xml object, just like xml output file and then move then object to db column in single update uery.

Or if you can think any other solution then it will be appreciated.

Thanks,

sas-innovate-2024.png

Join us for SAS Innovate April 16-19 at the Aria in Las Vegas. Bring the team and save big with our group pricing for a limited time only.

Pre-conference courses and tutorials are filling up fast and are always a sellout. Register today to reserve your seat.

 

Register now!

How to Concatenate Values

Learn how use the CAT functions in SAS to join values from multiple variables into a single value.

Find more tutorials on the SAS Users YouTube channel.

Click image to register for webinarClick image to register for webinar

Classroom Training Available!

Select SAS Training centers are offering in-person courses. View upcoming courses for:

View all other training opportunities.

Discussion stats
  • 7 replies
  • 1006 views
  • 4 likes
  • 4 in conversation