> ## Documentation Index
> Fetch the complete documentation index at: https://docs.powersync.com/llms.txt
> Use this file to discover all available pages before exploring further.

# Grammar Reference (Sync Rules)

> Railroad diagram reference for the SQL grammar supported in legacy Sync Rules queries.

This page is a formal grammar reference for Sync Rules: it shows the syntax accepted for parameter queries and data queries using railroad diagrams. This page complements the [Supported SQL](/sync/supported-sql) guide, which explains in prose what you can write, with examples and restrictions.

**When to use this page:** If you need to check whether a construct is valid, see how parameter vs data query syntax differs, or you're used to grammar specs, use the diagrams and the "Used by" / "References" links to navigate. For most users just getting started, see [Supported SQL](/sync/supported-sql) and the [Sync Rules](/sync/rules/overview) docs.

## ParameterQuery

```sql theme={null}
SELECT id FROM users WHERE id = token_parameters.user_id
```

<img src="https://mintcdn.com/powersync/kwqMBYdK3iuUeGAO/sync/grammar/sync-rules/bucket-definitions--ParameterQuery.svg?fit=max&auto=format&n=kwqMBYdK3iuUeGAO&q=85&s=e215fbe72cfb2371501d1308b0ed453a" alt="ParameterQuery syntax diagram" width="341" height="122" data-path="sync/grammar/sync-rules/bucket-definitions--ParameterQuery.svg" />

**References:** [StaticParameterQuery](#staticparameterquery), [TableParameterQuery](#tableparameterquery), [TableValuedParameterQuery](#tablevaluedparameterquery)

***

## TableValuedParameterQuery

```sql theme={null}
SELECT value FROM json_each(token_parameters.tags)
```

<img src="https://mintcdn.com/powersync/P3T2yYhduAWQ8FNI/sync/grammar/sync-rules/bucket-definitions--TableValuedParameterQuery.svg?fit=max&auto=format&n=P3T2yYhduAWQ8FNI&q=85&s=68774f31d74586208943129599eebb5d" alt="TableValuedParameterQuery syntax diagram" width="981" height="102" data-path="sync/grammar/sync-rules/bucket-definitions--TableValuedParameterQuery.svg" />

**References:** [Identifier](#lexical-rules), [JsonEachCall](#jsoneachcall), [SelectItem](#selectitem), [WhereClause](#whereclause)

<Accordion title="Used by">
  [ParameterQuery](#parameterquery)
</Accordion>

***

## TableParameterQuery

```sql theme={null}
SELECT id, name FROM users WHERE org_id = token_parameters.org_id
```

<img src="https://mintcdn.com/powersync/P3T2yYhduAWQ8FNI/sync/grammar/sync-rules/bucket-definitions--TableParameterQuery.svg?fit=max&auto=format&n=P3T2yYhduAWQ8FNI&q=85&s=416ae375a4af7fcda273d4a525f15a24" alt="TableParameterQuery syntax diagram" width="741" height="102" data-path="sync/grammar/sync-rules/bucket-definitions--TableParameterQuery.svg" />

**References:** [Reference](#reference), [SelectItem](#selectitem), [WhereClause](#whereclause)

<Accordion title="Used by">
  [ParameterQuery](#parameterquery)
</Accordion>

***

## StaticParameterQuery

```sql theme={null}
SELECT token_parameters.user_id AS id
```

<img src="https://mintcdn.com/powersync/P3T2yYhduAWQ8FNI/sync/grammar/sync-rules/bucket-definitions--StaticParameterQuery.svg?fit=max&auto=format&n=P3T2yYhduAWQ8FNI&q=85&s=460e17c57ca34cc8a4b46abe3c65d8af" alt="StaticParameterQuery syntax diagram" width="557" height="102" data-path="sync/grammar/sync-rules/bucket-definitions--StaticParameterQuery.svg" />

**References:** [SelectItem](#selectitem), [WhereClause](#whereclause)

<Accordion title="Used by">
  [ParameterQuery](#parameterquery)
</Accordion>

***

## DataQuery

```sql theme={null}
SELECT id, name FROM users WHERE users.id = bucket.user_id
```

<img src="https://mintcdn.com/powersync/kwqMBYdK3iuUeGAO/sync/grammar/sync-rules/bucket-definitions--DataQuery.svg?fit=max&auto=format&n=kwqMBYdK3iuUeGAO&q=85&s=89609517fc1a9ee339c044644e5721f8" alt="DataQuery syntax diagram" width="781" height="132" data-path="sync/grammar/sync-rules/bucket-definitions--DataQuery.svg" />

**References:** [Reference](#reference), [SelectItem](#selectitem), [WhereClause](#whereclause)

***

## SelectItem

```sql theme={null}
name AS user_name
```

<img src="https://mintcdn.com/powersync/kwqMBYdK3iuUeGAO/sync/grammar/sync-rules/bucket-definitions--SelectItem.svg?fit=max&auto=format&n=kwqMBYdK3iuUeGAO&q=85&s=662db2df93fd82d28057e0cf07dbba1d" alt="SelectItem syntax diagram" width="417" height="72" data-path="sync/grammar/sync-rules/bucket-definitions--SelectItem.svg" />

**References:** [Expression](#expression), [Identifier](#lexical-rules)

<Accordion title="Used by">
  [TableValuedParameterQuery](#tablevaluedparameterquery), [TableParameterQuery](#tableparameterquery), [StaticParameterQuery](#staticparameterquery), [DataQuery](#dataquery)
</Accordion>

***

## JsonEachCall

```sql theme={null}
JSON_EACH(token_parameters.tags)
```

<img src="https://mintcdn.com/powersync/kwqMBYdK3iuUeGAO/sync/grammar/sync-rules/bucket-definitions--JsonEachCall.svg?fit=max&auto=format&n=kwqMBYdK3iuUeGAO&q=85&s=95b6f59351a79a184c288066268afffb" alt="JsonEachCall syntax diagram" width="409" height="62" data-path="sync/grammar/sync-rules/bucket-definitions--JsonEachCall.svg" />

**References:** [Expression](#expression)

<Accordion title="Used by">
  [TableValuedParameterQuery](#tablevaluedparameterquery)
</Accordion>

***

## WhereClause

```sql theme={null}
users.id = bucket.user_id AND active = true
```

<img src="https://mintcdn.com/powersync/P3T2yYhduAWQ8FNI/sync/grammar/sync-rules/bucket-definitions--WhereClause.svg?fit=max&auto=format&n=P3T2yYhduAWQ8FNI&q=85&s=bedaad8a9efe9834e8c938c61e882f8a" alt="WhereClause syntax diagram" width="489" height="162" data-path="sync/grammar/sync-rules/bucket-definitions--WhereClause.svg" />

**References:** [Predicate](#predicate), [WhereClause](#whereclause)

<Accordion title="Used by">
  [TableValuedParameterQuery](#tablevaluedparameterquery), [TableParameterQuery](#tableparameterquery), [StaticParameterQuery](#staticparameterquery), [DataQuery](#dataquery), [WhereClause](#whereclause)
</Accordion>

***

## Predicate

```sql theme={null}
status IS NOT NULL
```

<img src="https://mintcdn.com/powersync/kwqMBYdK3iuUeGAO/sync/grammar/sync-rules/bucket-definitions--Predicate.svg?fit=max&auto=format&n=kwqMBYdK3iuUeGAO&q=85&s=99ced9da86a6bf6db2e3c31df54a9958" alt="Predicate syntax diagram" width="493" height="192" data-path="sync/grammar/sync-rules/bucket-definitions--Predicate.svg" />

**References:** [Expression](#expression)

<Accordion title="Used by">
  [WhereClause](#whereclause)
</Accordion>

***

## Expression

```sql theme={null}
price * quantity + tax
```

<img src="https://mintcdn.com/powersync/kwqMBYdK3iuUeGAO/sync/grammar/sync-rules/bucket-definitions--Expression.svg?fit=max&auto=format&n=kwqMBYdK3iuUeGAO&q=85&s=424650902bba9c417a9142e6bfa06868" alt="Expression syntax diagram" width="957" height="91" data-path="sync/grammar/sync-rules/bucket-definitions--Expression.svg" />

### Operators

Binary operators supported in scalar expressions, listed from highest to lowest precedence.

<Note>
  PowerSync evaluates all binary operators with equal precedence (left to right). Use parentheses to control evaluation order.
</Note>

| Precedence | Operators          | Description                       |
| ---------- | ------------------ | --------------------------------- |
| 1          | `\|\|`             | String concatenation              |
| 2          | `*` `/` `%`        | Multiplication, division, modulo  |
| 3          | `+` `-`            | Addition, subtraction             |
| 4          | `&` `\|` `<<` `>>` | Bitwise AND, OR, left/right shift |
| 5          | `<` `>` `<=` `>=`  | Less than, greater than, etc.     |
| 6          | `=` `!=`           | Equal, not equal                  |

**References:** [PrimaryExpression](#primaryexpression), [PropertyAccess](#propertyaccess)

<Accordion title="Used by">
  [SelectItem](#selectitem), [JsonEachCall](#jsoneachcall), [Predicate](#predicate), [CastExpression](#castexpression), [FunctionCall](#functioncall), [PrimaryExpression](#primaryexpression)
</Accordion>

***

## PropertyAccess

```sql theme={null}
->'address'->>'city'
```

<img src="https://mintcdn.com/powersync/kwqMBYdK3iuUeGAO/sync/grammar/sync-rules/bucket-definitions--PropertyAccess.svg?fit=max&auto=format&n=kwqMBYdK3iuUeGAO&q=85&s=a701046c32066aa67990ecb7db09d93b" alt="PropertyAccess syntax diagram" width="377" height="100" data-path="sync/grammar/sync-rules/bucket-definitions--PropertyAccess.svg" />

**References:** [IntegerLiteral](#lexical-rules), [StringLiteral](#lexical-rules)

<Accordion title="Used by">
  [Expression](#expression)
</Accordion>

***

## Reference

```sql theme={null}
users.id
```

<img src="https://mintcdn.com/powersync/kwqMBYdK3iuUeGAO/sync/grammar/sync-rules/bucket-definitions--Reference.svg?fit=max&auto=format&n=kwqMBYdK3iuUeGAO&q=85&s=ad7e46bb76e38ca2c46ff75eca80cc5e" alt="Reference syntax diagram" width="409" height="72" data-path="sync/grammar/sync-rules/bucket-definitions--Reference.svg" />

**References:** [Identifier](#lexical-rules)

<Accordion title="Used by">
  [TableParameterQuery](#tableparameterquery), [DataQuery](#dataquery), [FunctionCall](#functioncall), [PrimaryExpression](#primaryexpression)
</Accordion>

***

## CastExpression

```sql theme={null}
CAST(age AS TEXT)
```

<img src="https://mintcdn.com/powersync/kwqMBYdK3iuUeGAO/sync/grammar/sync-rules/bucket-definitions--CastExpression.svg?fit=max&auto=format&n=kwqMBYdK3iuUeGAO&q=85&s=58c7dd9f8bc5396d6b5701678ecdd2c0" alt="CastExpression syntax diagram" width="541" height="182" data-path="sync/grammar/sync-rules/bucket-definitions--CastExpression.svg" />

**References:** [Expression](#expression)

<Accordion title="Used by">
  [PrimaryExpression](#primaryexpression)
</Accordion>

***

## FunctionCall

```sql theme={null}
upper(name)
```

<img src="https://mintcdn.com/powersync/kwqMBYdK3iuUeGAO/sync/grammar/sync-rules/bucket-definitions--FunctionCall.svg?fit=max&auto=format&n=kwqMBYdK3iuUeGAO&q=85&s=d347a2a418cfdaa7af9dd9da2ab24bad" alt="FunctionCall syntax diagram" width="449" height="102" data-path="sync/grammar/sync-rules/bucket-definitions--FunctionCall.svg" />

**References:** [Expression](#expression), [Reference](#reference)

<Accordion title="Used by">
  [PrimaryExpression](#primaryexpression)
</Accordion>

***

## PrimaryExpression

```sql theme={null}
(price + tax)
```

<img src="https://mintcdn.com/powersync/kwqMBYdK3iuUeGAO/sync/grammar/sync-rules/bucket-definitions--PrimaryExpression.svg?fit=max&auto=format&n=kwqMBYdK3iuUeGAO&q=85&s=e9525ae1eb54a181390c8936447c8b27" alt="PrimaryExpression syntax diagram" width="337" height="302" data-path="sync/grammar/sync-rules/bucket-definitions--PrimaryExpression.svg" />

**References:** [CastExpression](#castexpression), [Expression](#expression), [FunctionCall](#functioncall), [NumericLiteral](#lexical-rules), [Reference](#reference), [StringLiteral](#lexical-rules)

<Accordion title="Used by">
  [Expression](#expression)
</Accordion>

***

## Lexical Rules

| Token                             | Examples                                                           | Rule                                    |
| --------------------------------- | ------------------------------------------------------------------ | --------------------------------------- |
| [Identifier](#identifier)         | `user_id`, `MY_TABLE`, `"Column Name"`, `"with ""quotes"" inside"` | `[A-Z_] ([A-Z_0-9])*`                   |
| [StringLiteral](#stringliteral)   | `'hello'`, `'it''s'`, `''`                                         | `"'" ([\x20-\x26] \| [\x28-\x7E])* "'"` |
| [IntegerLiteral](#integerliteral) | `0`, `42`, `12345`                                                 | `([0-9])+`                              |
| [NumericLiteral](#numericliteral) | `3.14`, `42`, `0.5`                                                | `([0-9])+ ("." ([0-9])+)?`              |

### Identifier

Bare identifiers are normalized to lower case and may contain letters, digits, and underscores. Double-quoted identifiers ("name") allow any printable character and support escaped quotes ("").

<Accordion title="Used by">
  [TableValuedParameterQuery](#tablevaluedparameterquery), [SelectItem](#selectitem), [Reference](#reference)
</Accordion>

### StringLiteral

Single-quoted string literal. Embedded single quotes are escaped by doubling them ('').

<Accordion title="Used by">
  [PropertyAccess](#propertyaccess), [PrimaryExpression](#primaryexpression)
</Accordion>

### IntegerLiteral

One or more decimal digits (0-9).

<Accordion title="Used by">
  [PropertyAccess](#propertyaccess)
</Accordion>

### NumericLiteral

Decimal number: one or more digits with an optional fractional part (.digits).

<Accordion title="Used by">
  [PrimaryExpression](#primaryexpression)
</Accordion>
