This is a project to generate useful SQL snippets for Koerber development.
Go to the release page and download the appropriate file for your IDE. The *.snippet
file is for SSMS and the sql.json
file is for VSCode/Azure Data Studio.
- Open the Command Palette with
Ctrl+Shift+P
and search for and selectSnippets: Configure Snippets
, thenSQL
- Copy the downloaded
sql.json
file and paste it into this opened buffer and save. - Alternatively, move the downloaded
sql.json
file to%APPDATA%\Code\User\snippets
for VSCode or%APPDATA%\azuredatastudio\User\snippets
for Azure Data Studio. - Open a new buffer, change the language to SQL, type
stopkd
, then hitEnter
to test snippet expansion.
- Open the Code Snippets Manager with
Ctrl+K, Ctrl+B
or clickingTools > Code Snippets Manager
. - Click
Add
and add a folder at%USERPROFILE%\Documents\SQL Server Management Studio\Code Snippets\SQL
where you're going to put the downloaded.snippet
file. I would name it something that would show up first in an alphabetical list (likeAAD
or.Koerber
) because of the way snippets work in SSMS. - Click
Import
and select the downloaded.snippet
file. - Select the folder you created and click
Finish
(this may take a few moments) and then hitOK
. - To open the available snippets, use the shortcut
Ctrl+K, Ctrl+X
. Select (by pressingEnter
) the folder you added (you want it to be first in the list so that you don't have to search for it!), typestopkd
, then hitEnter
. Thestopkd
JOIN
snippet expansion should work correctly.
Here is a graph of a subset of the schema that these snippets use. Each node is a table, and each relationship between two tables is an edge. Each node has a unique default alias. Each edge has a join attribute describing how one table joins to the other table's primary key. Note that tables in other databases than AAD like KoerberOneCore and REPOSITORY are included, too.
Using some graph algorithms, the shortest paths from a source node to a set of destination nodes can be found.
SSMS and Azure Data Studio (also VSCode) support custom snippets.
Each table in the schema can expand a table alias snippet to a FROM
line with the table name and WITH (NOLOCK)
. So sto
expands to:
FROM t_stored_item sto WITH (NOLOCK)
Here is the cool part. Type up to three table aliases, and a snippet is created that is a shortest set of paths from the first alias to the other two aliases. For example, stohumloc
would expand to:
JOIN t_hu_master hum WITH (NOLOCK)
ON sto.wh_id = hum.wh_id
AND sto.hu_id = hum.hu_id
JOIN t_location loc WITH (NOLOCK)
ON sto.wh_id = loc.wh_id
AND sto.location_id = loc.location_id
Because the two edges from sto
to hum
and from sto
to loc
is a shortest set of paths starting at sto
that visits both hum
and loc
.
Typing zonsto
would expand to:
JOIN t_zone_loca znl WITH (NOLOCK)
ON zon.wh_id = znl.wh_id
AND zon.zone = znl.zone
JOIN t_location loc WITH (NOLOCK)
ON znl.wh_id = loc.wh_id
AND znl.location_id = loc.location_id
JOIN t_stored_item sto WITH (NOLOCK)
ON loc.wh_id = sto.wh_id
AND loc.location_id = sto.location_id
Because a shortest path from zon
to sto
is through znl
and loc
.
You have to be careful, though, because there can be multiple shortest paths from a source to a set of destinations. For example, say you wanted to find all the sto
on each employee's fork. So you could try stoemp
, but you'd get:
JOIN t_pick_detail pkd WITH (NOLOCK)
ON sto.type = pkd.pick_id
JOIN t_employee emp WITH (NOLOCK)
ON pkd.user_assigned = emp.id
Joining through pkd is probably not what you want. So you can "refine" the snippet by specifying another table you want involved. So a fork is a location (loc
), so you can insert loc
in the middle or end of the snippet, and now stolocemp
gives you:
JOIN t_location loc WITH (NOLOCK)
ON sto.wh_id = loc.wh_id
AND sto.location_id = loc.location_id
JOIN t_employee emp WITH (NOLOCK)
ON loc.c1 = emp.id
Because now a shortest set of paths from sto
to loc
and emp
is through those two tables.
The snippet sel
expands to:
SELECT TOP 1000
*
The snippet btran
begins a transaction that is potentially inside another transaction and with proper error handling. A lot of base code does not do this properly.
The snippet ifelse
expands to IF
/ELSE
blocks.
Then there are two easter egg snippets, dragon
and dragoncow
.
The following generates two snippet files in the out/
folder: sql.json
(for VSCode/Azure Data Studio) and snippets.snippet
(for SSMS).
mkdir -p out;
clj -M -m snippets.core;
cp out/sql.json $WHOME/AppData/Roaming/Code/User/snippets/sql.json