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

网站源码是用什么做的做网站 买空间

网站源码是用什么做的,做网站 买空间,给企业做网站的业务员,北京市网站设计Oracle 19C介绍了一个私人临时表的概念,私有临时表的概念是基于内存的临时表,该表在会话结束时或事务结束时取决于设置。 如果您从不同的数据库引擎(例如 SQL Server)转向 Oracle,您可能会对 Oracle 的临时表概念感到困…

Oracle 19C介绍了一个私人临时表的概念,私有临时表的概念是基于内存的临时表,该表在会话结束时或事务结束时取决于设置。

    如果您从不同的数据库引擎(例如 SQL Server)转向 Oracle,您可能会对 Oracle 的临时表概念感到困惑。在SQL Server中,开发人员会定期创建临时表来完成一些工作并删除它。

在 Oracle 中,全局临时表 (GTT) 是一个永久元数据对象,它在特定于事务或特定于会话的基础上将行保存在临时段中。动态创建和删除 GTT 被认为是不正常的。随着私有临时表的引入,Oracle 有了一个类似于其他引擎中的选项,其中表对象本身是临时的,而不仅仅是数据。

一、临时表类型

Oracle 支持两种类型的临时表。

  • 全局临时表:自 Oracle 8i 起可用。这里讨论过。
  • 私有临时表:从 Oracle 18c 开始可用,也是本文的主题。

二、私有临时表的命名

PRIVATE_TEMP_TABLE_PREFIX 初始化参数默认为“ORA$PTT_”,定义创建私有临时表时名称中必须使用的前缀。在下面的示例中,我们创建一个私有临时表,但未在名称中使用正确的前缀,这会导致错误。

CREATE PRIVATE TEMPORARY TABLE my_temp_table (id           NUMBER,description  VARCHAR2(20)
);CREATE PRIVATE TEMPORARY TABLE my_temp_table (*
ERROR at line 1:
ORA-00903: invalid table nameSQL>

三、创建私有临时表

如果您使用过全局临时表,那么创建私有临时表的语法看起来会很熟悉。

ON COMMIT DROP DEFINITION 子句(默认值)指示应在事务结束或会话结束时删除表。

CREATE PRIVATE TEMPORARY TABLE ora$ptt_my_temp_table (id           NUMBER,description  VARCHAR2(20)
)
ON COMMIT DROP DEFINITION;-- Insert, but don't commit, then check contents of PTT.
INSERT INTO ora$ptt_my_temp_table VALUES (1, 'ONE');SELECT COUNT(*) FROM ora$ptt_my_temp_table;COUNT(*)
----------1SQL>-- Commit and check contents.
COMMIT;SELECT COUNT(*) FROM ora$ptt_my_temp_table;
SELECT COUNT(*) FROM ora$ptt_my_temp_table*
ERROR at line 1:
ORA-00942: table or view does not existSQL>
相反,ON COMMIT PRESERVE DEFINITION 子句指示表和任何数据应在事务结束后持续存在。该表将在会话结束时删除。
CREATE PRIVATE TEMPORARY TABLE ora$ptt_my_temp_table (id           NUMBER,description  VARCHAR2(20)
)
ON COMMIT PRESERVE DEFINITION;-- Insert, but don't commit, then check contents of PTT.
INSERT INTO ora$ptt_my_temp_table VALUES (1, 'ONE');SELECT COUNT(*) FROM ora$ptt_my_temp_table;COUNT(*)
----------1SQL>-- Commit and check contents.
COMMIT;SELECT COUNT(*) FROM ora$ptt_my_temp_table;COUNT(*)
----------1SQL>-- Reconnect and check contents of GTT.
CONN test/test@pdb1SELECT COUNT(*) FROM ora$ptt_my_temp_table;
SELECT COUNT(*) FROM ora$ptt_my_temp_table*
ERROR at line 1:
ORA-00942: table or view does not existSQL>
上面的输出显示该表在提交后仍然存在,但在我们断开连接并创建新会话时被删除。

我们还可以使用 CTAS 方法创建私有临时表。
CREATE PRIVATE TEMPORARY TABLE ora$ptt_emp AS
SELECT * FROM emp;

四、私有临时表和PL/SQL

永久 PL/SQL 对象直接引用临时对象是没有意义的,因为它在编译时不存在。如果您想使用永久对象中的私有临时表,则必须使用动态 SQL 来完成。以下愚蠢的示例创建一个使用私有临时表的存储函数。

CREATE OR REPLACE FUNCTION ptt_test (p_id IN NUMBER)
RETURN VARCHAR2
ASl_sql     VARCHAR2(32767);l_return  VARCHAR2(30);
BEGINl_sql := 'CREATE PRIVATE TEMPORARY TABLE ora$ptt_my_temp_table (id           NUMBER,description  VARCHAR2(20))ON COMMIT DROP DEFINITION';EXECUTE IMMEDIATE l_sql;EXECUTE IMMEDIATE q'[INSERT INTO ora$ptt_my_temp_table VALUES (1, 'ONE')]';EXECUTE IMMEDIATE 'SELECT description INTO :l_return FROM ora$ptt_my_temp_table WHERE id = :id' INTO l_return USING p_id;RETURN l_return;
END;
/
该函数在19C中无法按预期工作。
SET SERVEROUTPUT ON
BEGINDBMS_OUTPUT.put_line('ptt_test(1) = ' || ptt_test(1));
END;
/
ERROR at line 1:
ORA-14451: unsupported feature with temporary table
ORA-06512: at "SYS.PTT_TEST", line 13
ORA-06512: at line 2SQL>

五、相关视图

私有临时表是基于内存的,因此数据字典中没有记录任何元数据。因此,您无法使用 USER_TABLES 视图来显示当前会话中的私有临时表的列表。以下视图可用于显示有关私有临时表的信息。
 
  • DBA_PRIVATE_TEMP_TABLES :数据库中的所有私有临时表。
  • USER_PRIVATE_TEMP_TABLES :当前会话中的私有临时表。

六、使用限制

私有临时表具有全局临时表的限制(请参阅此处),但也有其他限制。
 
  • 表名必须以 PRIVATE_TEMP_TABLE_PREFIX 初始化参数中定义的前缀开头。默认值为“ORA$PTT_”。
  • 永久对象不能直接引用私有临时表。
  • 私有临时表上不允许使用索引、物化视图和区域映射。
  • 私有临时表上不允许使用主键或任何需要索引的约束。
  • 列不能有默认值。
  • 无法通过数据库链接访问私有临时表。
  • 您无法收集私有临时表的统计信息。显示统计信息的唯一方法是在创建时使用 CREATE TABLE ... AS SELECT ... 语句填充表。除了这一种情况之外,您只能对私有临时表使用动态采样。

#数据库 #oracle #19c #私有临时表


文章转载自:

http://frzy3jVV.kkwgg.cn
http://YV95ylSt.kkwgg.cn
http://N9IZkOqs.kkwgg.cn
http://dwsCZWE3.kkwgg.cn
http://TJle7H0J.kkwgg.cn
http://HBnVGUo0.kkwgg.cn
http://R2OyiDWW.kkwgg.cn
http://UNGNl1F8.kkwgg.cn
http://wsCoh6oE.kkwgg.cn
http://3WLjVP3Z.kkwgg.cn
http://MJWbsrGX.kkwgg.cn
http://DYyuKw2g.kkwgg.cn
http://B0VyJPbL.kkwgg.cn
http://OUuF0fZZ.kkwgg.cn
http://biTkMN0x.kkwgg.cn
http://omDRFeKf.kkwgg.cn
http://BR1IPXCB.kkwgg.cn
http://AVbNuen7.kkwgg.cn
http://QAUfrqBQ.kkwgg.cn
http://SyTS3Hsh.kkwgg.cn
http://xh6BsHAT.kkwgg.cn
http://Uv71N2rI.kkwgg.cn
http://ryUx9cpL.kkwgg.cn
http://TSGdydu5.kkwgg.cn
http://K092Kxc2.kkwgg.cn
http://6udndi9O.kkwgg.cn
http://mOhmB77f.kkwgg.cn
http://Ic8etuPl.kkwgg.cn
http://zckobCO9.kkwgg.cn
http://YFCQuc12.kkwgg.cn
http://www.dtcms.com/wzjs/710318.html

相关文章:

  • 帮别人做网站用织梦模板行吗免费建网站的网站
  • 网站卖给别人后做违法信息wordpress必备文件组合
  • 网站建设课件网络工程公司如何接单
  • 建设网站架构服务器需要多少钱知名企业有哪些
  • 怎么用ai做企业网站框架安卓手机优化大师官方下载
  • seo整站优化外包公司创建
  • 如何做视频类网站网站 数据报表如何做
  • 深圳网站关键词推广唐县做网站
  • 网站百度推广怎么做网站空间买卖
  • 楚雄做网站wordpress 下载页
  • 做网站上的图片如何设定分辨率anylink wordpress
  • 如何向搜索引擎提交网站dw做网站的实用特效
  • 做搜狗pc网站排名搜索引擎优化的基础是什么
  • 建设网站好学吗购物网站建设公司
  • 厦门网站建设和人才库建设网站自主制作平台
  • 北京pc端网站开发互助网站建设公司
  • 买网站做seo90设计网站怎么样
  • 专业手机网站制作公司400电话申请网站源码程序
  • 用ai做网站自己电脑做服务器搭网站
  • 苏州做网站比较好的公司云南省建设厅网站二建
  • 四川省建设工程质量监理协会网站creative wordpress
  • 头条搜索站长平台部署推进网站建设
  • 佛山网站免费制作越影网站建设
  • 怎么用2级目录做网站苏州知名网站建设公司排名
  • 亚马逊网站运营怎么做ins做甜品网站
  • 企业建网站的案例广东衍发建设管理有限公司公司网站
  • 中国建设教育协会网站查wordpress换域名后图片路径不对
  • 哈尔滨模板建站源码网站内容布局
  • 富阳网站定制开发哪家公司好wordpress怎么汉化
  • 网站怎么做快照wordpress安装后要删除哪些文件