BookmarkSubscribeRSS Feed
arcastro
Calcite | Level 5

how to reference a lib table while inside a teradata connection?

7 REPLIES 7
Reeza
Super User
Are you using Explicit pass through?
In that case you're pushing SQL directly to your server and your server cannot see your SAS data sets but there are workarounds if you explain more what you're trying to do.
arcastro
Calcite | Level 5

Thanks for your reply!

I am using this method to connect Teradata:

"PROC SQL;
CONNECT TO TERADATA(SERVER='xxxx' SCHEMA='VWDW' USER="xxxx" PASSWORD="xxxx" MODE=TERADATA);"

 

I want to see some table in my work/lib in SAS and make filters using my own table inside the SAS.

 

Is it possible?

Tom
Super User Tom
Super User

@arcastro wrote:

Thanks for your reply!

I am using this method to connect Teradata:

"PROC SQL;
CONNECT TO TERADATA(SERVER='xxxx' SCHEMA='VWDW' USER="xxxx" PASSWORD="xxxx" MODE=TERADATA);"

 

I want to see some table in my work/lib in SAS and make filters using my own table inside the SAS.

 

Is it possible?


It is still hard to tell what you want to do.  You can clarify by describing a simple example.  Show what tables you have, clearly indicating which are in Teradata and which are not, and then describe the query you need to execute using those tables.

 

Note that you should be able to create volatile tables inside your Teradata database that will live for the duration of your Teradata session.  Similar to WORK datasets in SAS.

Reeza
Super User

@arcastro wrote:

Thanks for your reply!

I am using this method to connect Teradata:

"PROC SQL;
CONNECT TO TERADATA(SERVER='xxxx' SCHEMA='VWDW' USER="xxxx" PASSWORD="xxxx" MODE=TERADATA);"

 

I want to see some table in my work/lib in SAS and make filters using my own table inside the SAS.

 

Is it possible?


Most likely yes, but exactly how depends on the query. 

arcastro
Calcite | Level 5

Thanks again! 

You can see a simple example below.

I am connecting in a Teradata Server, and I want to make a join with a table that is outside of this connection, like a Lib or Work. I just wanna make a filter using auxiliar table in my teradata query. This auxlliar tabela could be temporarily, no problem.

 

LIBNAME R_PNL '/sasusers/workgroup/PNL';

PROC SQL;
CONNECT TO TERADATA(SERVER='xxx' SCHEMA='VWDW' USER="xxxxx" PASSWORD="xxxx" MODE=TERADATA);
CREATE TABLE Test AS
SELECT * FROM CONNECTION TO TERADATA
(Select * FROM VWDW.VDW_TERA AS X
INNER JOIN R_PNL.COSTUMERS AS Y ON Y.ID = X.ID
);
DISCONNECT FROM TERADATA;
QUIT;

Reeza
Super User
LIBNAME R_PNL '/sasusers/workgroup/PNL';

proc sql noprint;
select distinct iD into :id_list separated by ", "
from r_pnl.costumers;
quit;


PROC SQL;
CONNECT TO TERADATA(SERVER='xxx' SCHEMA='VWDW' USER="xxxxx" PASSWORD="xxxx" MODE=TERADATA);
CREATE TABLE Test AS
SELECT * FROM CONNECTION TO TERADATA
(Select * FROM VWDW.VDW_TERA AS X
INNER JOIN R_PNL.COSTUMERS AS Y ON Y.ID  in (&id_list)
);
DISCONNECT FROM TERADATA;
QUIT;

Here's one way if the list of ID's is manageable (macro variables have a limit of 64k characters)

 

If it gets too big you can create a dynamic macro to generate the list instead.

 

arcastro
Calcite | Level 5

The auxiliar table has more than 65534 characters. 

 

ERROR: The length of the value of the macro variable ID_LIST (65540) exceeds the maximum length (65534). The value has been truncated to 65534 characters.

 

How would it be "dynamic macro"?

hackathon24-white-horiz.png

The 2025 SAS Hackathon has begun!

It's finally time to hack! Remember to visit the SAS Hacker's Hub regularly for news and updates.

Latest Updates

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.

SAS Training: Just a Click Away

 Ready to level-up your skills? Choose your own adventure.

Browse our catalog!

Discussion stats
  • 7 replies
  • 1666 views
  • 0 likes
  • 3 in conversation