forked from pingcap/docs-cn
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add documentation for TiDB specific SQL functions (pingcap#6520)
- Loading branch information
1 parent
90c5786
commit dbbe459
Showing
3 changed files
with
197 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,196 @@ | ||
--- | ||
title: TiDB 特有的函数 | ||
summary: 学习使用 TiDB 特有的函数。 | ||
--- | ||
|
||
# TiDB 特有的函数 | ||
|
||
本文档介绍 TiDB 特有的函数。 | ||
|
||
## TIDB_BOUNDED_STALENESS | ||
|
||
`TIDB_BOUNDED_STALENESS` 是 TiDB 的内部函数,用于指定一个时间范围。用法为 `TIDB_BOUNDED_STALENESS(t1, t2)`,其中 t1 和 t2 为时间范围的两端,支持使用日期时间和时间函数。 | ||
|
||
使用该函数,TiDB 会在指定的时间范围内选择一个合适的时间戳,该时间戳能保证所访问的副本上不存在开始于这个时间戳之前且还没有提交的相关事务,即能保证所访问的可用副本上执行读取操作而且不会被阻塞。 | ||
|
||
## TIDB_DECODE_KEY | ||
|
||
`TIDB_DECODE_KEY` 函数用于将 TiDB 编码的键输入解码为包含 `_tidb_rowid` 和 `table_id` 的 JSON 结构。你可以在一些系统表和日志输出中找到 TiDB 的编码键。 | ||
|
||
### 语法图 | ||
|
||
```ebnf+diagram | ||
TableStmt ::= | ||
"TIDB_DECODE_KEY(" STR ")" | ||
``` | ||
|
||
### 示例 | ||
|
||
{{< copyable "sql" >}} | ||
|
||
```sql | ||
SELECT START_KEY, TIDB_DECODE_KEY(START_KEY) FROM information_schema.tikv_region_status WHERE table_name='t1' AND REGION_ID=2\G | ||
``` | ||
|
||
```sql | ||
*************************** 1. row *************************** | ||
START_KEY: 7480000000000000FF3B5F728000000000FF1DE3F10000000000FA | ||
TIDB_DECODE_KEY(START_KEY): {"_tidb_rowid":1958897,"table_id":"59"} | ||
1 row in set (0.00 sec) | ||
``` | ||
|
||
### MySQL 兼容性 | ||
|
||
`TIDB_DECODE_KEY` 是 TiDB 特有的函数,和 MySQL 不兼容。 | ||
|
||
## TIDB_DECODE_PLAN | ||
|
||
`TIDB_DECODE_PLAN` 函数用于解码 TiDB 执行计划。你可以在慢查询日志中找到 TiDB 执行计划。 | ||
|
||
### 语法图 | ||
|
||
```ebnf+diagram | ||
TableStmt ::= | ||
"TIDB_DECODE_PLAN(" STR ")" | ||
``` | ||
|
||
### 示例 | ||
|
||
{{< copyable "sql" >}} | ||
|
||
```sql | ||
SELECT tidb_decode_plan('8QIYMAkzMV83CQEH8E85LjA0CWRhdGE6U2VsZWN0aW9uXzYJOTYwCXRpbWU6NzEzLjHCtXMsIGxvb3BzOjIsIGNvcF90YXNrOiB7bnVtOiAxLCBtYXg6IDU2OC41wgErRHByb2Nfa2V5czogMCwgcnBjXxEpAQwFWBAgNTQ5LglZyGNvcHJfY2FjaGVfaGl0X3JhdGlvOiAwLjAwfQkzLjk5IEtCCU4vQQoxCTFfNgkxXzAJMwm2SGx0KHRlc3QudC5hLCAxMDAwMCkNuQRrdgmiAHsFbBQzMTMuOMIBmQnEDDk2MH0BUgEEGAoyCTQzXzUFVwX1oGFibGU6dCwga2VlcCBvcmRlcjpmYWxzZSwgc3RhdHM6cHNldWRvCTk2ISE2aAAIMTUzXmYA')\G | ||
``` | ||
|
||
```sql | ||
*************************** 1. row *************************** | ||
tidb_decode_plan('8QIYMAkzMV83CQEH8E85LjA0CWRhdGE6U2VsZWN0aW9uXzYJOTYwCXRpbWU6NzEzLjHCtXMsIGxvb3BzOjIsIGNvcF90YXNrOiB7bnVtOiAxLCBtYXg6IDU2OC41wgErRHByb2Nfa2V5czogMCwgcnBjXxEpAQwFWBAgNTQ5LglZyGNvcHJfY2FjaGVfaGl0X3JhdGlvOiAwLjAwfQkzLjk5IEtCCU4vQQoxCTFfNgkxXz: id task estRows operator info actRows execution info memory disk | ||
TableReader_7 root 319.04 data:Selection_6 960 time:713.1µs, loops:2, cop_task: {num: 1, max: 568.5µs, proc_keys: 0, rpc_num: 1, rpc_time: 549.1µs, copr_cache_hit_ratio: 0.00} 3.99 KB N/A | ||
└─Selection_6 cop[tikv] 319.04 lt(test.t.a, 10000) 960 tikv_task:{time:313.8µs, loops:960} N/A N/A | ||
└─TableFullScan_5 cop[tikv] 960 table:t, keep order:false, stats:pseudo 960 tikv_task:{time:153µs, loops:960} N/A N/A | ||
``` | ||
### MySQL 兼容性 | ||
`TIDB_DECODE_PLAN` 是 TiDB 特有的函数,和 MySQL 不兼容。 | ||
## TIDB_IS_DDL_OWNER | ||
`TIDB_IS_DDL_OWNER` 函数用于检查你连接的 TiDB 实例是否是 DDL Owner。DDL Owner 代表集群中所有其他节点执行 DDL 语句的 TiDB 实例。 | ||
### 语法图 | ||
```ebnf+diagram | ||
TableStmt ::= | ||
"TIDB_IS_DDL_OWNER())" | ||
``` | ||
### 示例 | ||
{{< copyable "sql" >}} | ||
```sql | ||
SELECT tidb_is_ddl_owner(); | ||
``` | ||
```sql | ||
+---------------------+ | ||
| tidb_is_ddl_owner() | | ||
+---------------------+ | ||
| 1 | | ||
+---------------------+ | ||
1 row in set (0.00 sec) | ||
``` | ||
### MySQL 兼容性 | ||
`TIDB_IS_DDL_OWNER` 是 TiDB 特有的函数,和 MySQL 不兼容。 | ||
### 另请参阅 | ||
- [ADMIN SHOW DDL](/sql-statements/sql-statement-admin-show-ddl.md) | ||
- [ADMIN CANCEL DDL](/sql-statements/sql-statement-admin-cancel-ddl.md) | ||
## TIDB_PARSE_TSO | ||
`TIDB_PARSE_TSO` 函数用于从 TiDB TSO 时间戳中提取物理时间戳。 | ||
TSO 指 Time Stamp Oracle,是 PD (Placement Driver) 为每个事务提供的单调递增的时间戳。 | ||
TSO 是一串数字,包含以下两部分: | ||
- 一个物理时间戳 | ||
- 一个逻辑计数器 | ||
### 语法图 | ||
```ebnf+diagram | ||
TableStmt ::= | ||
"TIDB_PARSE_TSO(" NUM ")" | ||
``` | ||
### 示例 | ||
{{< copyable "sql" >}} | ||
```sql | ||
BEGIN; | ||
SELECT TIDB_PARSE_TSO(@@tidb_current_ts); | ||
ROLLBACK; | ||
``` | ||
```sql | ||
+-----------------------------------+ | ||
| TIDB_PARSE_TSO(@@tidb_current_ts) | | ||
+-----------------------------------+ | ||
| 2021-05-26 11:33:37.776000 | | ||
+-----------------------------------+ | ||
1 row in set (0.0012 sec) | ||
``` | ||
以上示例使用 `TIDB_PARSE_TSO` 函数从 `tidb_current_ts` 会话变量提供的可用时间戳编号中提取物理时间戳。因为每个事务都会分配到时间戳,所以此函数在事务中运行。 | ||
### MySQL 兼容性 | ||
`TIDB_PARSE_TSO` 是 TiDB 特有的函数,和 MySQL 不兼容。 | ||
### 另请参阅 | ||
- [`tidb_current_ts`](/system-variables.md#tidb_current_ts) | ||
## TIDB_VERSION | ||
`TIDB_VERSION` 函数用于获取当前连接的 TiDB 服务器版本和构建详细信息。向 GitHub 上提交 issue 时,你可使用此函数获取相关信息。 | ||
### 语法图 | ||
```ebnf+diagram | ||
TableStmt ::= | ||
"TIDB_VERSION()" | ||
``` | ||
### 示例 | ||
{{< copyable "sql" >}} | ||
```sql | ||
SELECT TIDB_VERSION()\G | ||
``` | ||
```sql | ||
*************************** 1. row *************************** | ||
TIDB_VERSION(): Release Version: v5.1.0-alpha-13-gd5e0ed0aa-dirty | ||
Edition: Community | ||
Git Commit Hash: d5e0ed0aaed72d2f2dfe24e9deec31cb6cb5fdf0 | ||
Git Branch: master | ||
UTC Build Time: 2021-05-24 14:39:20 | ||
GoVersion: go1.13 | ||
Race Enabled: false | ||
TiKV Min Version: v3.0.0-60965b006877ca7234adaced7890d7b029ed1306 | ||
Check Table Before Drop: false | ||
1 row in set (0.00 sec) | ||
``` | ||
### MySQL 兼容性 | ||
`TIDB_VERSION` 是 TiDB 特有的函数,和 MySQL 不兼容。如果要求兼容 MySQL,可以使用 `VERSION` 获取版本信息,但结果不包含详细的构建信息。 |