高级DBA教你达梦8数据库判断表、字段、索引是否存在SQL语句方法全网独一份

您所在的位置:网站首页 dba_segments表或视图不存在 高级DBA教你达梦8数据库判断表、字段、索引是否存在SQL语句方法全网独一份

高级DBA教你达梦8数据库判断表、字段、索引是否存在SQL语句方法全网独一份

2024-07-12 14:57| 来源: 网络整理| 查看: 265

一、达梦8数据库判断表是否存在语句方法

我们再实际工作中需要判断数据库表是否存在。

方法1 select count(*) from dba_segments where dba_segments.OWNER=' 用户名' and SEGMENT_NAME='表名'

用这个方法查询性能很差,要几乎10秒效率太低 在这里插入图片描述

方法2(推荐) select COUNT(*) from sysobjects where NAME='表名'

执行时间1毫秒

在这里插入图片描述

方法3 select object_id from all_objects where object_type='TABLE' and OBJECT_NAME='表名称'

object_id 存在表就存在!

执行时间7毫秒 在这里插入图片描述

二、判断某个表的某个字段是否存在 SELECT COUNT(*) AS CNT FROM DBA_TAB_COLUMNS where TABLE_NAME='PRODUCT' and COLUMN_NAME = 'NAME' AND OWNER='PRODUCTION'

在这里插入图片描述

三、判断索引是否存在 (1)查询索引名称为A的索引是否存在 select * from USER_IND_COLUMNS where TABLE_NAME='表名称' and index_name='索引名称' (2)查询某个字段在某表是否已经建立了索引,或者是包含这个字段的索引有哪些? select * from USER_IND_COLUMNS where TABLE_NAME='表名称' AND "COLUMN_NAME"='字段名称' 四、查询表占用的硬盘空间 --查看用户下面每张表占用的磁盘空间 SELECT T.OWNER, T.SEGMENT_NAME, T.SEGMENT_TYPE, T.TABLESPACE_NAME, T.BYTES, T.BYTES/1024 BYTE_KB, T.BYTES/1024/1024 BYTE_MB FROM DBA_SEGMENTS T WHERE --T.OWNER = 'SYSDBA' AND -- 用户/模式名 T.SEGMENT_TYPE IN ('TABLE','INDEX') ORDER BY T.BYTES DESC;

笔者简介 国内某一线知名软件公司企业认证在职员工:任JAVA高级研发工程师,大数据领域专家,数据库领域专家兼任高级DBA!10年软件开发经验!现任国内某大型软件公司大数据研发工程师、MySQL数据库DBA,软件架构师。直接参与设计国家级亿级别大数据项目!并维护真实企业级生产数据库300余个!紧急处理数据库生产事故上百起,挽回数据丢失所造成的灾难损失不计其数!并为某国家级大数据系统的技术方案(国家知识产权局颁布)专利权的第一专利发明人!

在这里插入图片描述

在这里插入图片描述



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3