当前位置: 首页 > news >正文

TDengine 中的视图

简介

从 v3.2.1.0 开始,TDengine 企业版提供视图功能,便于用户简化操作,提升用户间的分享能力。

视图(View)本质上是一个存储在数据库中的查询语句。视图(非物化视图)本身不包含数据,只有在从视图读取数据时才动态执行视图所指定的查询语句。我们在创建视图时指定一个名称,然后可以像使用普通表一样对其进行查询等操作。视图的使用需遵循以下规则:

  • 视图可以嵌套定义和使用,视图与创建时指定的或当前数据库绑定使用。
  • 在同一个数据库内,视图名称不允许重名,视图名跟表名也推荐不重名(不强制)。当出现视图与表名重名时,写入、查询、授权、回收权限等操作优先使用同名表。

语法

创建(更新)视图

CREATE [ OR REPLACE ] VIEW [db_name.]view_name AS query

说明:

  • 创建视图时可以指定视图绑定的数据库名(db_name),未明确指定时默认为当前连接绑定的数据库;
  • 查询语句(query)中推荐指定数据库名,支持跨库视图,未指定时默认为与视图绑定的数据库 (有可能非当前连接指定的数据库);

查看视图

  1. 查看某个数据库下的所有视图
SHOW [db_name.]VIEWS;
  1. 查看视图的创建语句
SHOW CREATE VIEW [db_name.]view_name;
  1. 查看视图列信息
DESCRIBE [db_name.]view_name;
  1. 查看所有视图信息
SELECT ... FROM information_schema.ins_views;

删除视图

DROP VIEW [IF EXISTS] [db_name.]view_name;

权限

说明

视图的权限分为 READ、WRITE、ALTER 三种,查询操作需要具备 READ 权限,写入操作需要具备 WRITE 权限,对视图本身的删改操作需要具备 ALTER 权限。

规则

  • 视图的创建者和 root 用户默认具备所有权限。
  • 对其他用户进行授权与回收权限可以通过 GRANT 和 REVOKE 语句进行,该操作只能由 root 用户进行。
  • 视图权限需单独授权与回收,通过 db.* 进行的授权与回收不含视图权限。
  • 视图可以嵌套定义与使用,同理对视图权限的校验也是递归进行的。
  • 为了方便视图的分享与使用,引入视图有效用户(即视图的创建用户)的概念,被授权用户可以使用视图有效用户的库、表及嵌套视图的读写权限。注:视图被 REPLACE 后有效用户也会被更新。

具体相关权限控制细则如下表所示:

序号操作权限要求
1CREATE VIEW
(创建新用户)
用户对视图所属数据库有 WRITE 权限

用户对视图的目标库、表、视图有查询权限,若查询中的对象是视图需满足当前表中第 8 条规则
2CREATE OR REPLACE VIEW
(覆盖旧视图)
用户对视图所属数据库有 WRITE 权限 且 对旧有视图有 ALTER 权限

用户对视图的目标库、表、视图有查询权限,若查询中的对象是视图需满足当前表中第 8 条规则
3DROP VIEW用户对视图有 ALTER 权限
4SHOW VIEWS
5SHOW CREATE VIEW
6DESCRIBE VIEW
7系统表查询
8SELECT FROM VIEW操作用户对视图有 READ 权限 且 操作用户或视图有效用户对视图的目标库、表、视图有 READ 权限
9INSERT INTO VIEW操作用户对视图有 WRITE 权限 且 操作用户或视图有效用户对视图的目标库、表、视图有 WRITE 权限
10GRANT/REVOKE只有 root 用户有权限

语法

授权
GRANT privileges ON [db_name.]view_name TO user_name
privileges: {
    ALL,
  | priv_type [, priv_type] ...
}
priv_type: {
    READ
  | WRITE
  | ALTER
}
回收权限
REVOKE privileges ON [db_name.]view_name FROM user_name
privileges: {
    ALL,
  | priv_type [, priv_type] ...
}
priv_type: {
    READ
  | WRITE
  | ALTER
}

使用场景

SQL 查询SQL 写入STMT 查询STMT 写入订阅流计算
支持暂不支持暂不支持暂不支持支持暂不支持

举例

  • 创建视图

    CREATE VIEW view1 AS SELECT _wstart, count(*) FROM table1 INTERVAL(1d);
    CREATE VIEW view2 AS SELECT ts, col2 FROM table1;
    CREATE VIEW view3 AS SELECT * from view1;
    
  • 查询数据

    SELECT * from view1;
    
  • 删除视图

    DROP VIEW view1;
    

访问官网

更多内容欢迎访问 TDengine 官网

http://www.dtcms.com/a/111858.html

相关文章:

  • Spring Boot 可扩展脱敏框架设计全解析 | 注解+策略模式+模板方法模式实战
  • Python Requests 库终极指南
  • Redis-13.在Java中操作Redis-Spring Data Redis使用方式-操作哈希类型的数据
  • 免费内网穿透方法
  • LocaDate、LocalTime、LocalDateTime
  • 如何设计好一张表
  • LLM 性能优化有哪些手段?
  • 软件工程面试题(二十七)
  • 硬件电路(23)-输入隔离高低电平有效切换电路
  • MYOJ_4342:(洛谷P1087)[NOIP 2004 普及组] FBI 树(二叉树实操,递归提高)
  • SQL Server数据库异常-[SqlException (0x80131904): 执行超时已过期] 操作超时问题及数据库日志已满的解决方案
  • Arduino示例代码讲解:Ping
  • c语言学习16——内存函数
  • 面向对象(2)
  • 多模态技术概述(一)
  • Visio | 将(.vsdx)导出为更清楚/高质量的图片(.png) | 在Word里面的visio图
  • 从感光sensor到显示屏,SOC并非唯一多样
  • 手动将ModelScope的模型下载到本地
  • Eclipse怎么创建java项目
  • 前端快速入门学习2-HTML
  • 编写实现一个简易的域名服务器
  • 长龙通信机CAN数据查看(工具版)
  • AI Agent设计模式一:Chain
  • 出现次数最多的子树元素和——深度优先搜索
  • 如何将Android 应用上传到国内各大应用市场
  • Webpack中loader的作用。
  • 【AI4CODE】5 Trae 锤一个基于百度Amis的Crud应用
  • AI+OCR:解锁数字化新视界
  • 33、web前端开发之JavaScript(二)
  • KingbaseES之KDts迁移Mysql