SAS Global Forum 2009
Coders' Corner
Paper 063-2009
Exploring the Undocumented PROC SQL _METHOD Option
Kirk Paul Lafler, Software Intelligence Corporation, Spring Valley, California
ABSTRACT
The SQL Procedure contains many powerful and elegant language features for SQL users to take advantage of. This paper explores the _METHOD option as an applications development and tuning tool. Attendees will learn how to use this undocumented and powerful option to better understand and control how a query processes.
INTRODUCTION
PROC SQL supports a powerful undocumented option called _METHOD. Although undocumented features like the _METHOD option should be used with caution, SAS users may find this option to provide far greater value than risk. In fact, the _METHOD option is worth exploring because of the benefits related to gaining a better understanding of the processes during specific PROC SQL operations, including complex table joins and subqueries.
APPLICATION OF THE _METHOD OPTION
The PROC SQL _METHOD option can be used as an effective way to analyze a query process as well as for debugging purposes. Information from using the _METHOD option is displayed on the Log using a variety of codes. The codes and their corresponding descriptions associated with the _METHOD option appear in the table below.
Code
SQXCRTA SQXSLCT SQXJSL SQXJM SQXJNDX SQXJHSH SQXSORT SQXSRC SQXFIL SQXSUMG SQXSUMN
Description
Create table as Select. Select statement or clause. Step loop join (Cartesian). Merge join operation. Index join operation. Hash join operation. Sort operation. Source rows from table. Rows filtration. Summary stats (aggregates) with GROUP BY clause. Summary stats with no GROUP BY clause.
In the following example a _METHOD option is specified to show the processing hierarchy in a two-way equi-join. As illustrated in the SAS Log, the PROC SQL optimizer utilized a hash join algorithm in the performance of the join. SQL Code PROC SQL _METHOD; SELECT MOVIES.TITLE, RATING, ACTOR_LEADING FROM MOVIES, ACTORS WHERE MOVIES.TITLE = ACTORS.TITLE; QUIT;
SAS Global Forum 2009
Coders' Corner
Log Results NOTE: SQL execution methods chosen are: sqxslct sqxjhsh sqxsrc( MOVIES ) sqxsrc( ACTORS )
CONCLUSION
The SQL Procedures _METHOD option provides users with a powerful and effective tool for gaining greater insight into complex join, subquery, and other programmatic operations.
REFERENCES
Lafler, Kirk Paul (2008), Exploring the Undocumented PROC SQL _METHOD Option, Proceedings of the 2008 Western Users of SAS Software (WUSS) Conference, Software Intelligence Corporation, Spring Valley, CA, USA. Lafler, Kirk Paul (2007), Undocumented and Hard-to-Find PROC SQL Features, Proceedings of the 2007 NorthEast SAS Users Group (NESUG) Conference, Software Intelligence Corporation, Spring Valley, CA, USA. Lafler, Kirk Paul (2007), Undocumented and Hard-to-Find PROC SQL Features, Proceedings of the 2007 PharmaSUG Conference, Software Intelligence Corporation, Spring Valley, CA, USA. Lafler, Kirk Paul (2006), A Hands-on Tour Inside the World of PROC SQL, Proceedings of the 31 Annual SAS Users Group International Conference, Software Intelligence Corporation, Spring Valley, CA, USA. Lafler, Kirk Paul (2004). PROC SQL: Beyond the Basics Using SAS, SAS Institute Inc., Cary, NC, USA. Lafler, Kirk Paul (2003), Undocumented and Hard-to-find PROC SQL Features, Proceedings of the 2007 Western Users of SAS Software (WUSS) Conference, Software Intelligence Corporation, Spring Valley, CA, USA. Lafler, Kirk Paul (2002). PROC SQL Programming Tips; Software Intelligence Corporation, Spring Valley, CA, USA.
st
ACKNOWLEDGMENTS
The author would like to thank Andrew Kuligowski and Diana Suhr, Coders Corner Section Chairs, as well as Lori Griffin, SGF 2009 Conference Chair for a great conference!
TRADEMARK CITATIONS
SAS and all other SAS Institute Inc. product or service names are registered trademarks or trademarks of SAS Institute Inc. in the USA and other countries.  indicates USA registration. Other brand and product names are trademarks of their respective companies.
AUTHOR BIO
Kirk Paul Lafler is consultant and founder of Software Intelligence Corporation and has been using SAS since 1979. Kirk provides IT consulting services and training to SAS users around the world. As a SAS Certified Professional, Kirk has written four books including PROC SQL: Beyond the Basics Using SAS, and more than three hundred peerreviewed articles. He has also been an Invited speaker at more than three hundred SAS International, regional, local, and special-interest user group conferences and meetings throughout North America. His popular SAS Tips column, Kirks Korner of Quick and Simple Tips, appears regularly in several SAS User Group newsletters and Web sites, and his fun-filled SASword Puzzles is featured in SAScommunity.org. Comments and suggestions can be sent to: Kirk Paul Lafler Software Intelligence Corporation World Headquarters P.O. Box 1390 Spring Valley, California 91979-1390 E-mail: KirkLafler@cs.com