Skip to content

Commit

Permalink
Add a SQL span naming suggestion: <db.operation> <db.name>.<db.sql.ta…
Browse files Browse the repository at this point in the history
…ble> (open-telemetry#1219)

Co-authored-by: Armin Ruech <[email protected]>
Co-authored-by: Yuri Shkuro <[email protected]>
Co-authored-by: Christian Neumüller <[email protected]>
  • Loading branch information
4 people authored Nov 24, 2020
1 parent 54493e0 commit 99279a1
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 4 deletions.
4 changes: 3 additions & 1 deletion CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,9 @@ Updates:

- `process.runtime.description` resource convention: Add `java.vm.name`
([#1242](https://github.com/open-telemetry/opentelemetry-specification/pull/1242))

- Refine span name guideline for SQL database spans
([#1219](https://github.com/open-telemetry/opentelemetry-specification/pull/1219))

## v0.7.0 (11-18-2020)

New:
Expand Down
13 changes: 10 additions & 3 deletions specification/trace/semantic_conventions/database.md
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,13 @@
**Span kind:** MUST always be `CLIENT`.

The **span name** SHOULD be set to a low cardinality value representing the statement executed on the database.
It may be a stored procedure name (without arguments), SQL statement without variable arguments, operation name, etc.
It MAY be a stored procedure name (without arguments), DB statement without variable arguments, operation name, etc.
Since SQL statements may have very high cardinality even without arguments, SQL spans SHOULD be named the
following way, unless the statement is known to be of low cardinality:
`<db.operation> <db.name>.<db.sql.table>`, provided that `db.operation` and `db.sql.table` are available.
If `db.sql.table` is not available due to its semantics, the span SHOULD be named `<db.operation> <db.name>`.
It is not recommended to attempt any client-side parsing of `db.statement` just to get these properties,
they should only be used if the library being instrumented already provides them.
When it's otherwise impossible to get any meaningful span name, `db.name` or the tech-specific database name MAY be used.

## Connection-level attributes
Expand Down Expand Up @@ -178,7 +184,7 @@ For example, when retrieving a document, `db.operation` would be set to (literal

| Key | Value |
| :---------------------- | :----------------------------------------------------------- |
| Span name | `"SELECT * FROM orders WHERE order_id = ?"` |
| Span name | `"SELECT ShopDb.orders"` |
| `db.system` | `"mysql"` |
| `db.connection_string` | `"Server=shopdb.example.com;Database=ShopDb;Uid=billing_user;TableCache=true;UseCompression=True;MinimumPoolSize=10;MaximumPoolSize=50;"` |
| `db.user` | `"billing_user"` |
Expand All @@ -188,7 +194,8 @@ For example, when retrieving a document, `db.operation` would be set to (literal
| `net.transport` | `"IP.TCP"` |
| `db.name` | `"ShopDb"` |
| `db.statement` | `"SELECT * FROM orders WHERE order_id = 'o4711'"` |
| `db.operation` | not set |
| `db.operation` | `"SELECT"` |
| `db.sql.table` | `"orders"` |

### Redis

Expand Down

0 comments on commit 99279a1

Please sign in to comment.