Is there any SAS options to control how SAS maps data types from external databases?
I know that I could map each variable individually using the DBSASTYPE dataset option,
but I am wondering if there is a way to set an option to automatically map all variables with a specific type without having to first identify the specific variables that need to be mapped.
In particular I am interested in whether there is a way to control the automatic conversion of very large integer types (longint etc.) into character strings when pulling data from external databases into SAS dataset. I frequently get access to databases where they are using these extremely large integers as unique identifiers (not for actual numeric data) and think it would make it much easier to work with that data in SAS if those long integer values where automatically converted to digit strings instead of floating point numbers (where they might lose their ability to work as unique identifiers due to truncation/rounding).
Hi @Tom
*** You may want to jump to the final slide image and check out the environment variable ***
*** I don't believe there is a way to globally map one data type to another ***
SAS cannot read the BIGINT data types, directly. There are a couple of ways to handle it.
The first is to have your DBA create views that CAST the BIGINT columns to a character data type (Linus' recommendation). You can do this, without creating Teradata views, using explicit pass-thru.
I have pulled some slides covering using SAS with Teradata BIGINT from a workshop that I used to deliver. Hopefully, they will help. If the slides require clarification please let me know.
Be careful with TRUNCATE_BIGINT. Doing calculations using BIGINT columns could very well be problematic because you can get incorrect answers.
It's finally time to hack! Remember to visit the SAS Hacker's Hub regularly for news and updates.
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.
Ready to level-up your skills? Choose your own adventure.
