ORCAL 临时创建表与删除表

 更新时间:2021年10月19日 09:43:23   作者:最爱白开水  
今天这篇文章就来给大家分享ORCAL 临时创建表与删除表的相关资料,如会话级临时表是指临时表中的数据只在会话生命周期之中存在,当用户退出会话结束的时候,Oracle自动清除临时表中数据。下面就跟小编一起进入文章学习起来吧

一.Orcal临时表分类

1.会话级临时表

  • 1).保存一个会话Session的数据。
  • 2).当会话退出时,临时表数据自动清空。表结构与元数据还存储在用户数据字典。

总结:会话级临时表是指临时表中的数据只在会话生命周期之中存在,当用户退出会话结束的时候,Oracle自动清除临时表中数据。

2.事务级临时表

  • 1).保存一个事务中需要的数据。
  • 2).当事务提交或则回滚的时候,临时表数据自动清空。表结构与元数据还存储在用户数据字典。

总结:事务级临时表是指临时表中的数据只在事务生命周期中存在,当事务提交或则回滚的时候,Oracle自动清除临时表中数据。

二.临时表创建

1.会话级临时表

1).先创建后插入数据

Create Global Temporary Table Table_Name (Col1 Type1,Col2 Type2...) On Commit Preserve Rows;

  Insert Into Table_Name Values("","");

2).创建时直接插入数据

CREATE GLOBAL TEMPORARY TABLE Table_Name ON COMMIT PRESERVE ROWS AS select Col1, Col2 from Query_Table_Name where...;


2.事务级临时表

1).先创建后插入数据

Create Global Temporary Table Table_Name (Col1 Type1,Col2 Type2...) On Commit Delete Rows;

  Insert Into Table_Name Values("","");

2).创建时直接插入数据

CREATE GLOBAL TEMPORARY TABLE Table_Name ON COMMIT Delete ROWS AS select Col1, Col2 from Query_Table_Name where...;

三.删除临时表

如果创建临时表的会话没有结束,则无法删除临时表,因为临时表还在使用之中。但是结束会话(关闭创建会话级临时表的命令窗口)后就可以删除了;

Drop Table Table_name;

四.删除时报错

描述:关闭原先的命令窗口,然后执行 Drop Table Table_name;
报错:ORA-14452:试图创建,更改或删除正在使用的临时表中的索引

1.清空表,然后删除表

TRUNCATE TABLE test_table;
drop table test_table;

2.杀掉进程,然后删除

SELECT sid, serial# FROM v$session
WHERE sid = (SELECT sid FROM v$lock
WHERE id1 = (SELECT object_id  FROM user_objects
WHERE object_name = upper('test_table')));

如果无权限则执行授权

grant select any dictionary to user;
查询到该session的sid和serial#:

然后杀掉进程:

lter system kill session 'sid,serial#';

最后进行删除

drop table test_table;

到此这篇关于ORCAL 临时创建表与删除表的文章就介绍到这了,更多相关ORCAL 表创建与删除内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:

相关文章

  • win10 oracle11g彻底删除并重装教程

    win10 oracle11g彻底删除并重装教程

    这篇文章主要介绍了win10 oracle11g彻底删除并重装教程,文中步骤介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-06-06
  • PLSQL环境配置详细图文步骤

    PLSQL环境配置详细图文步骤

    PL/SQL是Oracle对行业标准SQL的过程性扩展,下面这篇文章主要给大家介绍了关于PLSQL环境配置的详细图文步骤,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2024-03-03
  • oracle通过行范围查询取4至10行并排序

    oracle通过行范围查询取4至10行并排序

    这篇文章主要介绍了oracle如果查询取4至10行并排序,很简单,很实用,正在学习oracle的朋友可以参考下
    2014-09-09
  • Oracle中行列转换有哪些方法

    Oracle中行列转换有哪些方法

    这篇文章主要给大家介绍了关于Oracle中行列转换有哪些方法的相关资料,最近在工作中遇到了涉及到数据库行列之间相互转换的问题,所以这里给大家总结介绍下,需要的朋友可以参考下
    2023-08-08
  • 处理Oracle监听程序当前无法识别连接描述符中请求的服务异常(ORA-12514)

    处理Oracle监听程序当前无法识别连接描述符中请求的服务异常(ORA-12514)

    这篇文章介绍了处理Oracle监听程序当前无法识别连接描述符中请求的服务异常(ORA-12514),对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-12-12
  • ORACLE查看当前账号的相关信息

    ORACLE查看当前账号的相关信息

    ORACLE 12C 后新增了一个功能,它会记录用户的最后一次登录时间:SPARE6字段记录用户的最后一次登录时间,本文给大家ORACLE如何查看当前账号的相关信息,感兴趣的朋友一起看看吧
    2021-06-06
  • WINDOWS下使用DOS命令行连接oracle数据库

    WINDOWS下使用DOS命令行连接oracle数据库

    本文讲述了通过windows下的DOS命令连接oracle数据库并进行简单操作的方法
    2018-03-03
  • oracle数据库索引失效的问题及解决

    oracle数据库索引失效的问题及解决

    本文总结了在Oracle数据库中索引失效的一些常见场景,包括使用isnull、isnotnull、!=、<、>、函数处理、like前置%查询以及范围索引和等值索引同时存在等情况,通过实际的SQL查询验证,展示了索引失效的原因,并给出了相应的优化建议
    2025-01-01
  • Linux环境下Oracle安装参数设置方法详解

    Linux环境下Oracle安装参数设置方法详解

    这篇文章主要介绍了Linux环境下Oracle安装参数设置方法,本文通过代码给大家介绍的非常详细,具有一定的参考借鉴价值 ,需要的朋友可以参考下
    2019-06-06
  • sql in查询元素超过1000条的解决方案

    sql in查询元素超过1000条的解决方案

    在oracle数据库中sql使用in时,如果in的能数超过1000就会出问题,下面这篇文章主要给大家介绍了关于sql in查询元素超过1000条的解决方案,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-03-03

最新评论