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

一、达梦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余个!紧急处理数据库生产事故上百起,挽回数据丢失所造成的灾难损失不计其数!并为某国家级大数据系统的技术方案(国家知识产权局颁布)专利权的第一专利发明人!

在这里插入图片描述

在这里插入图片描述

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 达梦数据库中,在创建时如果已经存在,可以使用"if not exists"语句来判断是否存在。具体的语法如下: ```sql create table if not exists 名( 列名1 数据类型1, 列名2 数据类型2, ... ); ``` 在这个语句中,如果名已经存在,则不会执行创建的操作,而是直接跳过该语句继续执行后面的语句。这样可以避免因为重复创建而导致的错误。 下面是一个示例: ```sql create table if not exists student( id int, name varchar(50), age int ); ``` 如果student已经存在,则不会执行创建的操作。如果不存在,则会创建一个名为student的,该包含id、name和age三个列。 使用"if not exists"语句可以保证在创建时不会因为已存在而报错,提高了创建的稳定性和可靠性。 ### 回答2: 达梦数据库创建时,如果已经存在,可以使用SQL语句来处理。一种常用的方法是使用"IF NOT EXISTS"关键字来判断是否存在,如果不存在则创建。 例如,使用以下SQL语句创建: ``` CREATE TABLE IF NOT EXISTS mytable ( id INT PRIMARY KEY, name VARCHAR(50) ); ``` 如果名为mytable的已经存在,则这条SQL语句不会执行任何操作。如果不存在,则会创建一个名为mytable的,并定义id和name两个字段。 此外,还可以使用"DROP TABLE IF EXISTS"语句,先判断是否存在,如果存在则删除该,然后再创建新的。 ``` DROP TABLE IF EXISTS mytable; CREATE TABLE mytable ( id INT PRIMARY KEY, name VARCHAR(50) ); ``` 这种方法可以用来先删除旧并创建新,确保的结构与定义完全一致。 总而言之,达梦数据库创建时,如果已经存在,可以使用IF语句来判断的存在与否,并采取相应的操作,以确保的创建与定义。 ### 回答3: 达梦数据库在创建时,如果已经存在,可以使用SQL语句进行的处理。一般情况下,有以下几种操作方式: 1. 忽略已存在的:使用`CREATE TABLE IF NOT EXISTS`语句可以创建,如果已经存在,则忽略该操作。这样就不会对已经存在的进行任何修改,保持原有结构的完整性。 2. 删除已存在的:可以使用`DROP TABLE IF EXISTS`语句删除已存在的,然后再创建新的。这样会先删除原有的,然后重新创建一个新的结构。 3. 修改已存在的:使用`ALTER TABLE`语句可以对已存在的进行修改。可以添加、删除、修改列的定义,也可以增加、删除、修改的约束,如主键、外键等。 需要注意的是,对于已存在的进行删除或修改操作时,可能会导致数据的丢失或结构的改变,因此在执行操作前一定要谨慎进行,并备份好相关数据。 达梦数据库创建时如果已存在,通过使用上述的相关SQL语句,可以灵活地处理已存在的,保证数据库的完整性和数据的有效性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

技术很渣

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值