达梦数据库sql笔记

文章目录

  • [1 日期时间函数](#1 日期时间函数)
    • [1.1 now()](#1.1 now())
  • [2 权限相关](#2 权限相关)
  • [3 锁](#3 锁)
    • [3.1 某张表上的某种锁是由哪个会话操作加上的](#3.1 某张表上的某种锁是由哪个会话操作加上的)
  • [4 表空间](#4 表空间)
  • [5 查看一个模式下的每一张表占据的硬盘空间的大小](#5 查看一个模式下的每一张表占据的硬盘空间的大小)

1 日期时间函数

1.1 now()

语法:NOW(n)

功能:返回系统的当前时间戳。等价于 GETDATE()

参数:n:指定毫秒的精度。取值范围 0-6,默认为 6。

2 权限相关

为一个用户移除 PUBLIC 角色(默认可能隐含权限)

sql 复制代码
REVOKE PUBLIC FROM WY_RES_READ;

1、 创建一个角色,并将一个模式下的所有的表的查询权限赋给创建好的角色,然后将角色赋给 另外一个用户。

sql 复制代码
-- 创建只读角色
--CREATE ROLE WY_GQ_IIMS_READONLY;

-- 授权角色访问模式下的所有表
BEGIN
    FOR rec IN (
        SELECT TABLE_NAME 
		FROM ALL_TABLES 
		WHERE OWNER = 'WY_GQ_IIMS'
    ) 
    LOOP
        EXECUTE IMMEDIATE 
            'GRANT SELECT ON WY_GQ_IIMS.' || rec.TABLE_NAME || ' TO WY_GQ_IIMS_READONLY';
    END LOOP;
END;
/

-- 将角色授予用户
GRANT WY_GQ_IIMS_READONLY TO WY_RES_READ;

3 锁

3.1 某张表上的某种锁是由哪个会话操作加上的

sql 复制代码
select 
	a.*,b.NAME,c.SESS_ID,c.CLNT_IP,c.SQL_TEXT 
from 
	v$lock a
	left join sysobjects b on b.ID=a.TABLE_ID
	left join v$sessions c on a.TRX_ID=c.TRX_ID
where 
	b.NAME LIKE '%recent_a%'
	and c.CREATE_TIME > '2025-08-05';

4 表空间

sql 复制代码
SELECT 
  ID AS "表空间ID",
  NAME AS "表空间名称",
  CACHE AS "缓存策略",
  TYPE$ AS "类型(0=数据,1=临时,2=回滚)",
  STATUS$ AS "状态(0=联机,1=脱机)",
  TOTAL_SIZE*16/1024/1024 AS "总大小(GB)",
  USED_SIZE*16/1024/1024 AS "已使用大小(GB)"
FROM 
	V$TABLESPACE
order by USED_SIZE DESC;

select tablespace_name,file_name,status, bytes/1024/1024/1024 as "GB" from DBA_DATA_FILES order by "GB" DESC;

-- 查看页大小
SELECT SF_GET_PAGE_SIZE();

select 
	*
FROM 
	V$TABLESPACE;

select * from DBA_DATA_FILES;


5 查看一个模式下的每一张表占据的硬盘空间的大小

sql 复制代码
SELECT 
    t.owner AS "模式",
    t.table_name AS "表名",
    ROUND(COALESCE(s.seg_size, 0) / 1024 / 1024, 2) AS "表数据空间(MB)",
    ROUND(COALESCE(idx.idx_size, 0) / 1024 / 1024, 2) AS "索引空间(MB)",
    ROUND(COALESCE(s.seg_size + idx.idx_size, 0) / 1024 / 1024 / 1024, 2) AS "总占用空间(GB)"
FROM 
    dba_tables t
LEFT JOIN 
    (SELECT owner, segment_name, SUM(bytes) AS seg_size 
     FROM dba_segments 
     WHERE segment_type = 'TABLE' 
     GROUP BY owner, segment_name) s 
    ON t.owner = s.owner AND t.table_name = s.segment_name
LEFT JOIN 
    (SELECT i.owner, i.table_name, SUM(s.bytes) AS idx_size 
     FROM dba_indexes i 
     JOIN dba_segments s ON i.index_name = s.segment_name 
     WHERE s.segment_type = 'INDEX' 
     GROUP BY i.owner, i.table_name) idx 
    ON t.owner = idx.owner AND t.table_name = idx.table_name
WHERE 
    t.owner = 'SJZT_MD'  -- 替换为实际模式名
ORDER BY 
    "总占用空间(GB)" DESC;


select 
	sum("总占用空间(GB)")
from (
SELECT 
    t.owner AS "模式",
    t.table_name AS "表名",
    ROUND(COALESCE(s.seg_size, 0) / 1024 / 1024, 2) AS "表数据空间(MB)",
    ROUND(COALESCE(idx.idx_size, 0) / 1024 / 1024, 2) AS "索引空间(MB)",
    ROUND(COALESCE(s.seg_size + idx.idx_size, 0) / 1024 / 1024 / 1024, 2) AS "总占用空间(GB)"
FROM 
    dba_tables t
LEFT JOIN 
    (SELECT owner, segment_name, SUM(bytes) AS seg_size 
     FROM dba_segments 
     WHERE segment_type = 'TABLE' 
     GROUP BY owner, segment_name) s 
    ON t.owner = s.owner AND t.table_name = s.segment_name
LEFT JOIN 
    (SELECT i.owner, i.table_name, SUM(s.bytes) AS idx_size 
     FROM dba_indexes i 
     JOIN dba_segments s ON i.index_name = s.segment_name 
     WHERE s.segment_type = 'INDEX' 
     GROUP BY i.owner, i.table_name) idx 
    ON t.owner = idx.owner AND t.table_name = idx.table_name
WHERE 
    t.owner = 'SJZT_MD'  -- 替换为实际模式名
ORDER BY 
    "总占用空间(GB)" DESC
)
相关推荐
码以致用6 小时前
StarRocks笔记
数据库·starrocks·olap·1024程序员节
大G的笔记本6 小时前
JVM 分代收集算法(Generational GC) 的原理和执行流程
1024程序员节
这张生成的图像能检测吗6 小时前
(论文速读)开放词汇3D场景理解的掩蔽点-实体对比
人工智能·计算机视觉·图像生成·1024程序员节·开放词汇·3d重建
eguid_16 小时前
【开源项目分享】JNSM1.2.0,支持批量管理的jar包安装成Windows服务可视化工具,基于Java实现的支持批量管理已经安装服务的可视化工具
java·开源·jar·1024程序员节·windows服务·jar包安装成服务·exe安装成服务
何如千泷6 小时前
【论文阅读】Qwen2.5-VL Technical Report
论文阅读·大模型·多模态·1024程序员节
歪歪1006 小时前
在C#中详细介绍一下Visual Studio中如何使用数据可视化工具
开发语言·前端·c#·visual studio code·visual studio·1024程序员节
北城笑笑6 小时前
Server 15 ,VMware ESXi 实战指南:Ubuntu 20.04.6 版本虚拟机静态 IP 配置、分辨率固定及远程访问实践
linux·运维·ubuntu·1024程序员节
小马哥learn6 小时前
使用 WebSocket 实现手机控制端与电脑展示端的实时通信,支持断线重连、状态同步和双向数据交互。(最优方案)
1024程序员节
Eiceblue7 小时前
如何通过 C# 高效读写 Excel 工作表
c#·visual studio·1024程序员节