2022-07-29 01:47:36 +08:00
```meta
type: plug
uri: core:query
repo: https://github.com/silverbulletmd/silverbullet
author: Silver Bullet Authors
```
2022-07-30 19:11:24 +08:00
### 1. What?
2022-07-30 23:42:25 +08:00
The query plug is a built-in plug implementing the `<!-- #query -->` mechanism. You can use query plug to automatically receive information from your pages.
2022-07-30 00:05:43 +08:00
2022-07-30 19:11:24 +08:00
### 2. Syntax
2022-07-30 19:52:41 +08:00
1. _start with_ : `<!-- #query [QUERY GOES HERE] -->`
2. _end with_ : `<!-- /query -->`
3. _write your query_ : replace `[QUERY GOES HERE]` with any query you want using options below
2022-07-30 23:42:25 +08:00
4. _available query options_ : Usage of options is similar to SQL except special `render` option. Render option is to use display the data in a format that you created in a separate template
2022-07-30 00:05:43 +08:00
* `where`
2022-07-30 23:42:25 +08:00
* `order by`
2022-07-30 00:05:43 +08:00
* `limit`
* `select`
* `render`
2022-07-30 19:52:41 +08:00
P.S.: If you are a developer or have a technical knowledge to read a code and would like to know more about syntax, please check out [query grammar ](https://github.com/silverbulletmd/silverbullet/blob/main/packages/plugs/query/query.grammar ).
2022-07-30 00:05:43 +08:00
2022-07-30 19:11:24 +08:00
### 3. How to run a query?
2022-07-30 19:52:41 +08:00
After writing the query, there are three options:
2022-07-30 00:05:43 +08:00
* Open the **command palette** and run **Materialized Queries: Update**
2022-07-30 19:52:41 +08:00
* Use shortcut: hit **Alt-q** (Windows, Linux) or **Option-q** (Mac)
2022-07-30 19:03:57 +08:00
* Go to another page and come back to the page where query is located
2022-07-30 00:05:43 +08:00
2022-07-30 23:42:25 +08:00
After using one of the options, the “body” of the query is replaced with the new results of the query data will be displayed.
2022-07-30 19:11:24 +08:00
### 4. Data sources
2022-07-30 19:52:41 +08:00
Available data sources can be categorized as:
2022-07-30 19:11:24 +08:00
1. Builtin data sources
2. Data that can be inserted by users
2022-07-30 19:13:43 +08:00
3. Plug’ s data sources
2022-07-30 19:11:24 +08:00
2022-07-30 19:52:41 +08:00
Best part about data sources: there is an auto completion. 🎉
2022-07-30 23:42:25 +08:00
Start writing `<!— #query ` or simply use `/query` slash command, it will show you all available data sources. 🤯
2022-07-30 19:11:24 +08:00
2022-07-30 23:42:25 +08:00
#### 4.1. Available data sources
2022-07-30 19:52:41 +08:00
* `page` : list of all pages 📄
* `task` : list of all tasks created with `[]` syntax ✅
* `full-text` : use it with `where phrase = "SOME_TEXT"` . List of all pages where `SOME_TEXT` is mentioned ✍️
* `item` : list of ordered and unordered items such as bulleted lists ⏺️
* `tags` : list of all hashtags used in all pages ⚡
* `link` : list of all pages giving a link to the page where query is written 🔗
2022-07-30 23:42:25 +08:00
* `data` : You can insert a data using the syntax below 🖥️. You can query the data using `data` option.
2022-07-30 19:13:43 +08:00
```data
name: John
age: 50
city: Milan
country: Italy
---
name: Jane
age: 53
city: Rome
country: Italy
---
name: Francesco
age: 28
city: Berlin
country: Germany
```
<!-- #query data where age > 20 and country = "Italy" -->
2022-08-09 21:37:47 +08:00
|name|age|city |country|page |pos |
|----|--|-----|-----|--------|----|
|John|50|Milan|Italy|🔌 Query|2277|
|Jane|53|Rome |Italy|🔌 Query|2323|
2022-07-30 19:11:24 +08:00
<!-- /query -->
2022-07-30 23:42:25 +08:00
#### 4.2 Plugs’ data sources
2022-07-30 19:52:41 +08:00
Certain plugs can also provide special data sources to query a certain data. Some examples are
2022-07-30 19:16:40 +08:00
* [[🔌 Github]] provides `gh-pull` to query PRs for selected repo
* [[🔌 Mattermost]] provides `mm-saved` to fetch (by default 15) saved posts in Mattermost
2022-07-30 19:52:41 +08:00
For complete list of data sources, please check plugs’ pages.
2022-07-30 19:22:41 +08:00
### 5. Examples
2022-07-30 19:52:41 +08:00
We will walk you through a set of examples starting from very basic one until to format the data using templates.
2022-07-30 19:22:41 +08:00
Our goal in this exercise is to (i) get all plug pages (ii) ordered by last modified time and (iii) display in a nice format.
For the sake of simplicity, we will use `page` data source and limit the results not to spoil the page.
#### 5.1 Simple query without any condition
2022-07-30 19:29:23 +08:00
**Goal:** We would like to get the list of all pages.
2022-07-30 19:22:41 +08:00
2022-07-30 19:52:41 +08:00
**Result:** Look at the data. This is more than we need. The query even gives us template pages. Lets try to limit it in the next step.
2022-07-30 19:22:41 +08:00
<!-- #query page limit 10 -->
2022-08-09 21:37:47 +08:00
|name |lastModified |perm|tags |type|uri |repo |author |
2022-07-30 19:22:41 +08:00
|--|--|--|--|--|--|--|--|
2022-08-09 21:37:47 +08:00
|SETTINGS |1659437160849|rw|undefined|undefined|undefined |undefined |undefined |
|Silver Bullet |1660051168973|rw|undefined|undefined|undefined |undefined |undefined |
|CHANGELOG |1660050383951|rw|undefined|undefined|undefined |undefined |undefined |
|Mattermost Plugin|1658755340866|rw|undefined|undefined|undefined |undefined |undefined |
|PLUGS |1659437423367|rw|undefined|undefined|undefined |undefined |undefined |
|index |1659440751554|rw|undefined|undefined|undefined |undefined |undefined |
|template/plug |1658751100952|rw|undefined|undefined|undefined |undefined |undefined |
|template/tasks |1657890041936|rw|#each|undefined|undefined |undefined |undefined |
|💡 Inspiration |1658133917441|rw|undefined|undefined|undefined |undefined |undefined |
|🔌 Backlinks |1658760465195|rw|undefined|plug|ghr:Willyfrog/silverbullet-backlinks|https://github.com/Willyfrog/silverbullet-backlinks|Guillermo Vayá|
2022-07-30 19:22:41 +08:00
<!-- /query -->
2022-07-30 19:52:41 +08:00
#### 5.2 Simple query with a condition
**Goal:** We would like to get all plug pages and sorted by last modified time.
2022-07-30 19:29:23 +08:00
2022-07-30 19:52:41 +08:00
**Result:** Okay, this what we wanted but there are also information such as perm, type and lastModified that we don't need.
2022-07-30 19:24:23 +08:00
<!-- #query page where type = "plug" order by lastModified desc limit 5 -->
2022-08-09 21:37:47 +08:00
|name |lastModified |perm|type|uri |repo |author |
2022-07-30 19:24:23 +08:00
|--|--|--|--|--|--|--|
2022-08-09 21:37:47 +08:00
|🔌 Query |1660051209241|rw|plug|core:query |https://github.com/silverbulletmd/silverbullet |Silver Bullet Authors|
|🔌 Github|1660050280511|rw|plug|github:silverbulletmd/silverbullet-github/github.plug.json|https://github.com/silverbulletmd/silverbullet-github|Zef Hemel |
|🔌 Mount |1658760601369|rw|plug|github:silverbulletmd/silverbullet-mount/mount.plug.json |https://github.com/silverbulletmd/silverbullet-mount |Zef Hemel |
|🔌 Git |1658760545612|rw|plug|github:silverbulletmd/silverbullet-github/github.plug.json|https://github.com/silverbulletmd/silverbullet-github|Zef Hemel |
|🔌 Ghost |1658760515320|rw|plug|github:silverbulletmd/silverbullet-ghost/ghost.plug.json |https://github.com/silverbulletmd/silverbullet-ghost |Zef Hemel |
2022-07-30 19:24:23 +08:00
<!-- /query -->
2022-07-30 19:29:23 +08:00
#### 5.3 Query to select only certain fields
2022-07-30 19:52:41 +08:00
**Goal:** We would like to get all plug pages, select only `name` , `author` and `repo` columns and sort by last modified time.
2022-07-30 19:29:23 +08:00
2022-07-30 19:52:41 +08:00
**Result:** Okay, this is much better. However, I believe this needs a touch from a visual perspective.
2022-07-30 19:29:23 +08:00
2022-07-30 19:36:25 +08:00
<!-- #query page select name author repo uri where type = "plug" order by lastModified desc limit 5 -->
2022-08-09 21:37:47 +08:00
|name |author |repo |
2022-07-30 19:36:25 +08:00
|--|--|--|
2022-08-09 21:37:47 +08:00
|🔌 Query |Silver Bullet Authors|https://github.com/silverbulletmd/silverbullet |
|🔌 Github|Zef Hemel |https://github.com/silverbulletmd/silverbullet-github|
|🔌 Mount |Zef Hemel |https://github.com/silverbulletmd/silverbullet-mount |
|🔌 Git |Zef Hemel |https://github.com/silverbulletmd/silverbullet-github|
|🔌 Ghost |Zef Hemel |https://github.com/silverbulletmd/silverbullet-ghost |
2022-07-30 19:29:23 +08:00
<!-- /query -->
2022-07-30 19:36:25 +08:00
#### 5.4 Display the data in a format defined by a template
2022-07-30 19:52:41 +08:00
**Goal:** We would like to display the data from step 5.3 in a nice format using bullet points with links to Plug pages, with author name and link to their GitHub repo.
2022-07-30 19:36:25 +08:00
2022-07-30 19:52:41 +08:00
**Result:** Here you go. This is the result we would like to achieve 🎉. Did you see how I used `render` and `template/plug` in a query? 🚀
2022-07-30 19:36:25 +08:00
2022-08-09 21:37:47 +08:00
<!-- #query page select name author repo uri where type = "plug" order by lastModified desc limit 5 render [[template/plug]] -->
2022-07-30 19:36:25 +08:00
* [[🔌 Query]] by **Silver Bullet Authors** ([repo](https://github.com/silverbulletmd/silverbullet))
2022-08-09 21:37:47 +08:00
* [[🔌 Github]] by **Zef Hemel** ([repo](https://github.com/silverbulletmd/silverbullet-github))
* [[🔌 Mount]] by **Zef Hemel** ([repo](https://github.com/silverbulletmd/silverbullet-mount))
2022-07-30 19:36:25 +08:00
* [[🔌 Git]] by **Zef Hemel** ([repo](https://github.com/silverbulletmd/silverbullet-github))
2022-08-09 21:37:47 +08:00
* [[🔌 Ghost]] by **Zef Hemel** ([repo](https://github.com/silverbulletmd/silverbullet-ghost))
2022-07-30 19:52:41 +08:00
<!-- /query -->
PS: You don't need select only certain fields to use templates. Templates are smart enough to get only the information needed to render the data.
Therefore, following queries are same in terms of end result when using the templates.
```yaml
2022-08-09 21:37:47 +08:00
<!-- #query page select name author repo uri where type = "plug" order by lastModified desc limit 5 render [[template/plug]] -->
2022-07-30 19:52:41 +08:00
```
```yaml
2022-08-09 21:37:47 +08:00
<!-- #query page where type = "plug" order by lastModified desc limit 5 render [[template/plug]] -->
2022-07-30 19:52:41 +08:00
```