From d53f622776b2f1fb6ba84f36ac8cabd228514a1e Mon Sep 17 00:00:00 2001 From: yabwon Date: Tue, 15 Sep 2020 13:02:37 +0200 Subject: [PATCH] SQLinDS, version 2.2 SQLinDS, version 2.2 - documentation updated, macroarray.md created --- packages/sqlinds.md | 86 +++++++++++++++++++++++++++++++------------ packages/sqlinds.zip | Bin 11321 -> 11545 bytes 2 files changed, 63 insertions(+), 23 deletions(-) diff --git a/packages/sqlinds.md b/packages/sqlinds.md index 63886a9..2bea158 100644 --- a/packages/sqlinds.md +++ b/packages/sqlinds.md @@ -1,5 +1,14 @@ +- [The SQLinDS package [ver. 2.2]](#sqlinds-package) +- [Content description](#content-description) + * [library `dsSQL`](#library-dssql) + * [`%dsSQL_inner()` macro](#dssql-inner-macro) + * [`%SQL()` macro](#dssql-inner-macro) + * [`dsSQL()` function](#dssql-function) + * [License](#license) + +--- -# The SQLinDS package [ver. 2.2] ############################################### +# The SQLinDS package [ver. 2.2] ############################################### The **SQLinDS** package is an implementation of the *macro-function-sandwich* concept introduced in the @@ -9,8 +18,8 @@ the article by *Mike Rhoads (Westat, Rockville)*. Copy of the article is available at: [https://support.sas.com/resources/papers/proceedings12/004-2012.pdf](https://support.sas.com/resources/papers/proceedings12/004-2012.pdf) -Package provides ability to *execute* SQL queries inside a datastep, e.g. -~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~{.sas} +Package provides ability to *execute* SQL queries inside a data step, e.g. +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~sas data class; set %SQL(select * from sashelp.class); run; @@ -26,45 +35,59 @@ SQLinDS package contains the following components: 3. `%dsSQL_inner()` macro (internal) 4. Library `DSSQL` (created as a subdirectory of the `WORK` library) +--- + +Package contains: +1. libname dssql +2. macro dssql_inner +3. macro sql +4. function dssql + Required SAS Components: - Base SAS Software + *Base SAS Software* *SAS package generated by generatePackage, version 20200911* The SHA256 hash digest for package SQLinDS: -`DD5E319EB5AA29C7054EC428072F987E77C29D36874DED1AE5C62E4B300845EB` +`B280D0B72DB77001ADAAE9C1612B67AD30C2C672371B27F1ACB12016C7A1363D` + +--- +# Content description ############################################################################################ -### Content description ####################################################### +## >>> library `dsSQL`: <<< ######################## -## >>> library `dsSQL`: <<< ################################### - -The dsSQL library stores temporary views +The `dsSQL` library stores temporary views generated during the `%SQL()` macro execution. If possible a subdirectory of the `WORK` location is created, like: -~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~{.sas} +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~sas LIBNAME dsSQL BASE "%sysfunc(pathname(WORK))/dsSQLtmp"; ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ if not possible, then redirects to the `WORK` location, like: -~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~{.sas} +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~sas LIBNAME dsSQL BASE "%sysfunc(pathname(WORK))"; ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ +--- -## >>> `%dsSQL_Inner()` macro: <<< ############################################# + +## >>> `%dsSQL_Inner()` macro: <<< ############# **Internal** macro called by `dsSQL()` function. -The macro generates a uniqualy named sql view on the fly -which is then stored in the `DSSQL` library. +The macro generates a uniquely named SQL view on the fly +which is then stored in the `dsSQL` library. Recommended for *SAS 9.3* and higher. +--- -## >>> `%SQL()` macro: <<< ##################################################### -The *main* macro which allows to use + +## >>> `%SQL()` macro: <<< ########################### + +The **main** macro which allows to use SQL queries in the data step. Recommended for *SAS 9.3* and higher. @@ -74,37 +97,39 @@ by *Mike Rhoads* (Westat, Rockville), available at: [https://support.sas.com/resources/papers/proceedings12/004-2012.pdf](https://support.sas.com/resources/papers/proceedings12/004-2012.pdf) ### SYNTAX: ################################################################### -~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~{.sas} +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~sas %sql() ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ -The sql querry code is limited to *32000* bytes. +The sql query code is limited to *32000* bytes. ### EXAMPLES: ################################################################# **EXAMPLE 1**: simple SQL query -~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~{.sas} +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~sas data class_subset; set %SQL(select name, sex, height from sashelp.class where age > 12); run; ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ **EXAMPLE 2**: query with dataset options -~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~{.sas} +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~sas data renamed; set %SQL(select * from sashelp.class where sex = "F")(rename = (age=age2)); run; ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ **EXAMPLE 3**: dictionaries in the data step -~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~{.sas} +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~sas data dictionary; set %SQL(select * from dictionary.macros); run; ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ +--- -## >>> `dsSQL()` function: <<< ################################################# + +## >>> `dsSQL()` function: <<< #################### **Internal** function called by the `%SQL()` macro. The function pass a query code from the `%SQL()` @@ -112,8 +137,21 @@ macro to the `%dsSQL_Inner()` internal macro. Recommended for *SAS 9.3* and higher. +### SYNTAX: ################################################################### +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~sas +dsSQL(unique_index_2, query) +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +**Arguments description**: + +1. `unique_index_2` - *Numeric*, internal variable, a unique index for views. + +2. `query` - *Character*, internal variable, contains query text. + +--- ## License #################################################################### + Copyright (c) 2012 Mike Rhoads Permission is hereby granted, free of charge, to any person obtaining a copy @@ -132,4 +170,6 @@ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE -SOFTWARE. \ No newline at end of file +SOFTWARE. + +--- diff --git a/packages/sqlinds.zip b/packages/sqlinds.zip index 987c0452c6b0a491bcda38f5455703be9de33b8d..a98f358c0d91e4a5f0a0cb5f70da4191d2b7afe3 100644 GIT binary patch delta 8171 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