视图

    TiDB 支持视图,视图是一张虚拟表,该虚拟表的结构由创建视图时的 SELECT 语句定义。使用视图一方面可以对用户只暴露安全的字段及数据,进而保证底层表的敏感字段及数据的安全。另一方面,将频繁出现的复杂查询定义为视图,可以使复杂查询更加简单便捷。

    查询一个视图和查询一张普通表类似。但是 TiDB 在真正执行查询视图时,会将视图展开成创建视图时定义的 SELECT 语句,进而执行展开后的查询语句。

    通过以下方式,可以查看 view 相关的信息。

    使用该语句可以查看 view 对应的创建语句,及创建 view 时对应的 character_set_clientcollation_connection 系统变量值。

    1. +------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------+----------------------+----------------------+
    2. | View | Create View | character_set_client | collation_connection |
    3. +------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------+----------------------+----------------------+
    4. | v | CREATE ALGORITHM=UNDEFINED DEFINER=`root`@`127.0.0.1` SQL SECURITY DEFINER VIEW `v` (`a`) AS SELECT `s`.`a` FROM `test`.`t` LEFT JOIN `test`.`s` ON `t`.`a`=`s`.`a` | utf8 | utf8_general_ci |
    5. +------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------+----------------------+----------------------+
    6. 1 row in set (0.00 sec)

    示例:

    1. select * from information_schema.views;

    通过查询该表可以查看 view 的相关元信息,如 TABLE_CATALOGTABLE_SCHEMATABLE_NAMEVIEW_DEFINITIONCHECK_OPTIONIS_UPDATABLEDEFINERSECURITY_TYPECHARACTER_SET_CLIENTCOLLATION_CONNECTION 等。

    1. +---------------+--------------+------------+------------------------------------------------------------------------+--------------+--------------+----------------+---------------+----------------------+----------------------+
    2. | TABLE_CATALOG | TABLE_SCHEMA | TABLE_NAME | VIEW_DEFINITION | CHECK_OPTION | IS_UPDATABLE | DEFINER | SECURITY_TYPE | CHARACTER_SET_CLIENT | COLLATION_CONNECTION |
    3. +---------------+--------------+------------+------------------------------------------------------------------------+--------------+--------------+----------------+---------------+----------------------+----------------------+
    4. | def | test | v | SELECT `s`.`a` FROM `test`.`t` LEFT JOIN `test`.`s` ON `t`.`a`=`s`.`a` | CASCADED | NO | root@127.0.0.1 | DEFINER | utf8 | utf8_general_ci |
    5. +---------------+--------------+------------+------------------------------------------------------------------------+--------------+--------------+----------------+---------------+----------------------+----------------------+
    6. 1 row in set (0.00 sec)
    1. curl http://127.0.0.1:10080/schema/test/v

    通过访问 http://{TiDBIP}:10080/schema/{db}/{view} 可以得到对应 view 的所有元信息。

    1. {
    2. "id": 122,
    3. "name": {
    4. "O": "v",
    5. "L": "v"
    6. },
    7. "charset": "utf8",
    8. "collate": "utf8_general_ci",
    9. "cols": [
    10. {
    11. "name": {
    12. "O": "a",
    13. "L": "a"
    14. },
    15. "offset": 0,
    16. "origin_default": null,
    17. "default": null,
    18. "default_is_expr": false,
    19. "generated_expr_string": "",
    20. "generated_stored": false,
    21. "dependences": null,
    22. "type": {
    23. "Tp": 0,
    24. "Flag": 0,
    25. "Flen": 0,
    26. "Decimal": 0,
    27. "Charset": "",
    28. "Collate": "",
    29. "Elems": null
    30. },
    31. "state": 5,
    32. "comment": "",
    33. "hidden": false,
    34. "version": 0
    35. }
    36. ],
    37. "index_info": null,
    38. "fk_info": null,
    39. "state": 5,
    40. "pk_is_handle": false,
    41. "is_common_handle": false,
    42. "comment": "",
    43. "auto_inc_id": 0,
    44. "auto_id_cache": 0,
    45. "auto_rand_id": 0,
    46. "max_col_id": 1,
    47. "max_idx_id": 0,
    48. "update_timestamp": 416801600091455490,
    49. "ShardRowIDBits": 0,
    50. "max_shard_row_id_bits": 0,
    51. "auto_random_bits": 0,
    52. "pre_split_regions": 0,
    53. "partition": null,
    54. "view": {
    55. "view_algorithm": 0,
    56. "view_definer": {
    57. "Hostname": "127.0.0.1",
    58. "CurrentUser": false,
    59. "AuthUsername": "root",
    60. "AuthHostname": "%"
    61. },
    62. "view_security": 0,
    63. "view_select": "SELECT `s`.`a` FROM `test`.`t` LEFT JOIN `test`.`s` ON `t`.`a`=`s`.`a`",
    64. "view_checkoption": 1,
    65. "view_cols": null
    66. },
    67. "sequence": null,
    68. "Lock": null,
    69. "version": 3,
    70. "tiflash_replica": null
    71. }

    以下例子将创建一个视图,并在该视图上进行查询,最后删除该视图。

    1. Query OK, 0 rows affected (0.01 sec)
    1. insert into t values(1, 1),(2,2),(3,3);
    1. Query OK, 3 rows affected (0.00 sec)
    2. Records: 3 Duplicates: 0 Warnings: 0
    1. create table s(a int);
    1. Query OK, 0 rows affected (0.01 sec)
    1. Query OK, 2 rows affected (0.01 sec)
    2. Records: 2 Duplicates: 0 Warnings: 0
    1. create view v as select s.a from t left join s on t.a = s.a;
    1. Query OK, 0 rows affected (0.01 sec)
    1. select * from v;
    1. +------+
    2. | a |
    3. +------+
    4. | NULL |
    5. | 2 |
    6. | 3 |
    7. +------+
    8. 3 rows in set (0.00 sec)
    1. Query OK, 0 rows affected (0.02 sec)

    目前 TiDB 中的视图有以下局限性:

    • 不支持物化视图。
    • TiDB 中视图为只读视图,不支持对视图进行 UPDATEINSERTDELETETRUNCATE 等写入操作。
    • 对已创建的视图仅支持 DROP 的 DDL 操作,即 。