I'm new to proc sql. I want to print the results of proc sql table
can you help me to do that??
@mona4u wrote:
I want to see all the rows that's match the criteria
No rows match that criteria so somethings wrong with the criteria or your data.
A simple select without a create table before it will write the result to the currently open ODS destination.
Describe your issue in a more specific manner, and don't forget to post the code you already tried (see https://communities.sas.com/t5/help/faqpage/faq-category-id/posting?nobounce).
this is the code that's I'm using. I don't see the results in the result viewer it's only print
The SAS System without a table |
proc sql ;
select empid, jobcode, salary,
salary*.06 as bonus
from sasuser.payrollmaster
where salary <3200
order by jobcode;
What do you mean by 'it's only print'?
When you do
proc sql;
select * from sashelp.class;
quit;
In Enterprise Guide you will see the resulting output in the formats you set in the EG options, in their respective tabs.
In SAS Studio, you see the contents of sashelp.class in the Results tab.
*Creates a data set named WANT in the work library;
proc sql ;
create table want as
select empid, jobcode, salary,
salary*.06 as bonus
from sasuser.payrollmaster
where salary <3200
order by jobcode;
quit;
*Prints the output to the current ODS open destinations, ie listing or html;
*note the lack of a create table statement, which I've used strikethrough.
proc sql ;/*create table want as*/
select empid, jobcode, salary,
salary*.06 as bonus
from sasuser.payrollmaster
where salary <3200
order by jobcode;
quit;
One of these should be what you're looking for.
that's the message that I got
9306 proc sql ;
9307 create table want as
9308 select empid, jobcode, salary,
9309 salary*.06 as bonus
9310 from sasuser.payrollmaster
9311 where salary <3200
9312 order by jobcode;
NOTE: Table WORK.WANT created, with 0 rows and 4 columns.
9313 quit;
NOTE: PROCEDURE SQL used (Total process time):
real time 0.03 seconds
cpu time 0.03 seconds
@mona4u wrote:
that's the message that I got
9306 proc sql ;
9307 create table want as
9308 select empid, jobcode, salary,
9309 salary*.06 as bonus
9310 from sasuser.payrollmaster
9311 where salary <3200
9312 order by jobcode;
NOTE: Table WORK.WANT created, with 0 rows and 4 columns.9313 quit;
NOTE: PROCEDURE SQL used (Total process time):
real time 0.03 seconds
cpu time 0.03 seconds
This simply means that no observations in the sasuser.payrollmaster dataset match your where condition.
Inspect your dataset.
there is obs bc I checked it by proc print
@mona4u wrote:
there is obs bc I checked it by proc print
NO.
Quote from your previous post:
9312 order by jobcode; NOTE: Table WORK.WANT created, with 0 rows and 4 columns. 9313 quit;
Zero means zero, period
If you want to create a new table, you have to tell SQL to do that:
proc sql;
create table want as
select *
from sashelp.class;
quit;
Consult the documentation: http://documentation.sas.com/?docsetId=sqlproc&docsetTarget=titlepage.htm&docsetVersion=9.4&locale=e...
it is wired I was able to print your table without creating a table but with mine I can't
If you run that:
proc sql ;
create table want as
select empid, jobcode, salary,
salary*.06 as bonus
from sasuser.payrollmaster
where salary <3200
order by jobcode;
quit;
and no rows are selected, then
proc sql ;
select empid, jobcode, salary,
salary*.06 as bonus
from sasuser.payrollmaster
where salary <3200
order by jobcode;
quit;
will create no output (you get an empty results tab).
I want to see all the rows that's match the criteria
@mona4u wrote:
I want to see all the rows that's match the criteria
No rows match that criteria so somethings wrong with the criteria or your data.
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.