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

【Oracle专栏】实用SQL、查询处理

 Oracle相关文档,希望互相学习,共同进步

风123456789~-CSDN博客


1.背景

  Oracle实用查询SQL、执行处理。主要包括:

        1)配置密码有效期

        2)数据泵导入导出

        3)表空间、用户创建

        4)循环调用、死锁、SQL执行进度

2. 配置密码有效期

1)查询密码有效时长

select * from dba_profiles where profile='DEFAULT' AND resource_name='PASSWORD_LIFE_TIME';

2)查询当前用户密码到期日

select username,account_status,expiry_date,profile from dba_users;

3)设置密码永不到期

alter profile default limit password_life_time '90';  --90天到期
alter profile default limit password_life_time  unlimited;  --永久到期

2.数据泵导入导出 

1)expdp 导出

Expdp nh_mcro_collect/xx@orclpdb1 directory=BACKUP dumpfile=x.dmp  logfile=x.log compression=all

2)impdp导入

impdp NH_MCRO_COLLECT_MOVE/x@192.xx.xx.xx/orclpdb1 dumpfile=x.dmp directory=BACKUP logfile=x.log   remap_tablespace=NY_DATA_COLLECT:NH_MCRO_COLLECT_DATA remap_schema=nh_mcro_collect:nh_mcro_collect_move 

3.实用执行

3.1 sql执行进度

     查询sql执行百分比,很实用。

--sql执行进度:
SELECT SE.SID,  
        OPNAME,  
        TRUNC(SOFAR / TOTALWORK * 100, 2) || '%' AS PCT_WORK,  
        ELAPSED_SECONDS ELAPSED,  
        ROUND(ELAPSED_SECONDS * (TOTALWORK - SOFAR) / SOFAR) REMAIN_TIME,  
        SQL_TEXT  
FROM V$SESSION_LONGOPS SL, V$SQLAREA SA, V$SESSION SE  
WHERE SL.SQL_HASH_VALUE = SA.HASH_VALUE  
AND SL.SID = SE.SID  
AND SOFAR != TOTALWORK  
ORDER BY SE.SID; 

3.2 查询死锁 

--死锁 
 SELECT OBJECT_NAME,
       SESSION_ID SID,
       MACHINE,
       VS.MODULE,
       'ALTER   SYSTEM   KILL   SESSION   ''' || SESSION_ID || ', ' || SERIAL# ||  '''; ' KILL_SESSION,
       VS.STATUS,
       VS.ACTION,
       SERIAL#,
       ORACLE_USERNAME,
       OS_USER_NAME
  FROM V$LOCKED_OBJECT VO, V$SESSION VS, ALL_OBJECTS AO
 WHERE VO.SESSION_ID = VS.SID
   AND AO.OBJECT_ID = VO.OBJECT_ID
   AND NVL(VS.ACTION, '   ') <> 'Service   Management '
 ORDER BY OBJECT_NAME, MACHINE, VS.MODULE;

3.3 循环调用过程-按月份

--月份循环
function day_end_once(pDataIssue in varchar2) return varchar2 is
    vResult varchar2(10);
    vData_id  varchar2(7);
    v_date    date;
  begin
    vResult := '0';
   
    v_date := date '2022-01-01';
  
    loop
      vData_id := to_char(v_date, 'yyyy-mm');
    
      /*----业务执行过程  2024.7.8                     ----*/
      IF pg_nh_yw_xx.get_nh_yw_xx(vData_id) = '1' THEN
        vResult := '1';
      END IF;
    
      exit when vData_id = pDataIssue;
      v_date := add_months(v_date, 1);
    end loop;
End;

--循环跑批 test

declare 
   date_id  varchar2(32);
   vResult  Varchar2(4000); 
begin
   vResult :='0';
   date_id :='2022-01';

  loop  

      
    vResult := pg_mp_szmx.get_mp_szmx(date_id);      
    exit when date_id = '2022-12' ;
    date_id:= to_char(add_months(to_date(date_id,'yyyy-MM'),1),'yyyy-MM') ;
  
  end loop ;

end ;

普通调用:

--调用
begin
  -- Call the function
  :result := pg_as_org_range.get_as_expenditure_range(pDataIssue => :pDataIssue);
end;


begin
  -- Call the function
  :result := pg_as_org_range.get_as_income_range(pDataIssue => :pDataIssue);
end;

3.4 查询2个月份之间月份清单

sql语句:

--两个月份之间的月份清单:

SELECT TO_CHAR(ADD_MONTHS(start_date, LEVEL - 1), 'YYYY-MM') AS month
FROM (SELECT TO_DATE('2022-01', 'YYYY-MM') AS start_date,
             TO_DATE('2024-08', 'YYYY-MM') AS end_date
      FROM DUAL)
CONNECT BY LEVEL <= MONTHS_BETWEEN(end_date, start_date) + 1;

3.5 创建用户

create user NH_MCRO_COLLECT_MOVE  identified by xxx
  default tablespace NH_MCRO_COLLECT_DATA
  temporary tablespace TEMP
  profile DEFAULT
  quota unlimited on NH_MCRO_COLLECT_data
  quota unlimited on ny_data;

grant read, write on directory SYS.BACKUP to NH_MCRO_COLLECT_MOVE;
-- Grant/Revoke role privileges 
grant connect to NH_MCRO_COLLECT_MOVE;
grant exp_full_database to NH_MCRO_COLLECT_MOVE;
grant imp_full_database to NH_MCRO_COLLECT_MOVE;
grant resource to NH_MCRO_COLLECT_MOVE;

-- Grant/Revoke system privileges 
grant create database link to NH_MCRO_COLLECT_MOVE;
grant create procedure to NH_MCRO_COLLECT_MOVE;
grant create public database link to NH_MCRO_COLLECT_MOVE;
grant create sequence to NH_MCRO_COLLECT_MOVE;
grant create session to NH_MCRO_COLLECT_MOVE;
grant create table to NH_MCRO_COLLECT_MOVE;
grant create view to NH_MCRO_COLLECT_MOVE;
grant debug connect session to NH_MCRO_COLLECT_MOVE;
grant execute any procedure to NH_MCRO_COLLECT_MOVE;
grant select any table to NH_MCRO_COLLECT_MOVE;

3.6 表空间扩展

查询表空间大小:

SELECT TABLESPACE_NAME, SUM(BYTES) / 1024 / 1024 / 1024 AS "TOTAL_GB", SUM(MAXBYTES) / 1024 / 1024 / 1024 AS "MAX_GB", SUM(BYTES - MAXBYTES) / 1024 / 1024 / 1024 AS "FREE_GB"

FROM DBA_DATA_FILES

GROUP BY TABLESPACE_NAME;
 

创建表空间:

CREATE TABLESPACE tablespace_name DATAFILE '数据文件路径' SIZE 大小 [AUTOEXTEND ON NEXT 100M MAXSIZE UNLIMITED];
 

增加表空间:

ALTER TABLESPACE xxx ADD DATAFILE '新数据文件的存储位置' SIZE 数据文件大小;

临时表空间大小和数据文件路径:

SELECT tablespace_name, file_name, bytes/1024/1024 "Size_MB"

               maxbytes / 1024 / 1024/1024 AS max_size_Gb,
FROM dba_temp_files;

临时表空间扩展:
ALTER TABLESPACE temp ADD TEMPFILE '/u01/app/oracle/oradata/yourdb/temp02.dbf' SIZE 100M AUTOEXTEND ON NEXT 1024M MAXSIZE UNLIMITED;

如:ALTER TABLESPACE TEMP  ADD TEMPFILE '+DATA/TEMP/TEMP02.DBF'
SIZE 1G  AUTOEXTEND ON NEXT 1024M MAXSIZE UNLIMITED

结束:ok 


项目管理--相关知识   

项目管理-项目绩效域1/2-CSDN博客

项目管理-项目绩效域1/2_八大绩效域和十大管理有什么联系-CSDN博客

项目管理-项目绩效域2/2_绩效域 团不策划-CSDN博客

高项-案例分析万能答案(作业分享)-CSDN博客

项目管理-计算题公式【复习】_项目管理进度计算题公式:乐观-CSDN博客

项目管理-配置管理与变更-CSDN博客

项目管理-项目管理科学基础-CSDN博客

项目管理-高级项目管理-CSDN博客

项目管理-相关知识(组织通用治理、组织通用管理、法律法规与标准规范)-CSDN博客


Oracle其他文档,希望互相学习,共同进步

Oracle-找回误删的表数据(LogMiner 挖掘日志)_oracle日志挖掘恢复数据-CSDN博客

oracle 跟踪文件--审计日志_oracle审计日志-CSDN博客

ORA-12899报错,遇到数据表某字段长度奇怪现象:“Oracle字符型,长度50”但length查却没有50_varchar(50) oracle 超出截断-CSDN博客

EXP-00091: Exporting questionable statistics.解决方案-CSDN博客

Oracle 更换监听端口-CSDN博客


http://www.kler.cn/a/487926.html

相关文章:

  • 是德科技M9010A PXIe 机箱+M9037A模块,台式应用的理想之选
  • 目标检测中的Bounding Box(边界框)介绍:定义以及不同表示方式
  • ios脚本巨魔商店多巴胺越狱基本操作教程
  • 日语IT用语笔记
  • Leecode刷题C语言之字符串中最大的3位相同数字
  • 闲谭SpringBoot--ShardingSphere分库分表探究
  • 【update 更新数据语法合集】.NET开源ORM框架 SqlSugar 系列
  • 跨域问题,开发
  • QML states和transitions的使用
  • 油猴支持阿里云自动登陆插件
  • kotlin项目无法访问Java类的问题
  • 龙蜥Linux系统部署docker21.1.3版本
  • 同域名前后端分离项目 nginx配置实践
  • LCE(Local Cascade Ensemble)预测模型和LSTM(Long Short-Term Memory)模型在效果和特点上存在显著差异
  • 3D目标检测数据集——kitti数据集
  • 计算机网络之---HTTP协议
  • TDengine + MQTT :车联网时序数据库如何高效接入
  • 第一天 了解HarmonyOS的起源、发展、核心特性
  • 每天40分玩转Django:Django 实操图书管理系统
  • 一款面向数字孪生的数据中台
  • QT 常用控件的常用方法
  • Zookeeper 集群安装
  • 机房预约系统|Java|SSM|JSP|
  • 在 Vivado 的 Block Design 中,如果你不想让某个 IP 核的引脚连接到外部引脚,可以通过以下几种方法来处理:
  • Flutter Web 选取并上传图片
  • 在ubuntu下对NFS做性能测试