惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

Help Net Security
Help Net Security
G
Google Developers Blog
雷峰网
雷峰网
WordPress大学
WordPress大学
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
Engineering at Meta
Engineering at Meta
Security Latest
Security Latest
T
Threat Research - Cisco Blogs
AWS News Blog
AWS News Blog
F
Full Disclosure
C
Cybersecurity and Infrastructure Security Agency CISA
T
The Exploit Database - CXSecurity.com
J
Java Code Geeks
U
Unit 42
C
Cyber Attacks, Cyber Crime and Cyber Security
V
V2EX
C
Cisco Blogs
博客园 - 司徒正美
Project Zero
Project Zero
L
LINUX DO - 热门话题
阮一峰的网络日志
阮一峰的网络日志
Blog — PlanetScale
Blog — PlanetScale
Scott Helme
Scott Helme
A
About on SuperTechFans
Hugging Face - Blog
Hugging Face - Blog
S
Securelist
小众软件
小众软件
aimingoo的专栏
aimingoo的专栏
S
Schneier on Security
G
GRAHAM CLULEY
酷 壳 – CoolShell
酷 壳 – CoolShell
Cyberwarzone
Cyberwarzone
MongoDB | Blog
MongoDB | Blog
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
博客园 - 叶小钗
T
Threatpost
Recorded Future
Recorded Future
C
CXSECURITY Database RSS Feed - CXSecurity.com
宝玉的分享
宝玉的分享
N
News and Events Feed by Topic
人人都是产品经理
人人都是产品经理
The Register - Security
The Register - Security
S
Security Archives - TechRepublic
博客园 - Franky
N
News | PayPal Newsroom
Simon Willison's Weblog
Simon Willison's Weblog
S
SegmentFault 最新的问题
W
WeLiveSecurity
A
Arctic Wolf
B
Blog

博客园 - leup

一个硬盘的故事 SQL Server 与Oracle的不同点(从微观上) Oracle中Decode()函数使用技巧 oracle 日期函数介绍 Oracle SQLPLUS命令大全 Oracle 自动生成编号(实现sqlserver自增长字段) Oracle 函数介绍之 分析函数 Oracle 表内部字段产生树状结构的处理 oracle与sqlserver比较 Nhibernate开发资料收集 OWC winform Sample Demo 创建DataTable,并填充数据,模拟数据库中的表 GridView 使用技巧收集 【转】asp.net2.0学习历程 菜鸟到中级程序员的飞跃---30本好书点评 【转】ASP.NET2.0轻松搞定统计图表 【转】ASP.NET2.0 文件图片处理1 ASP.NET2.0 遍历文件夹下所有图片 ASP.NET2.0 ReportingServices 整理1 【转】C#优化字符串操作
Orcale 临时表
leup · 2007-11-18 · via 博客园 - leup

最近考虑到我们的数据库端写存储过程关于临时表使用的情况,由于我们

现在还不清楚数据库端到底是怎么处理的,是否和Sql Server的处理方式相

同,是否会存在隐患等等一些问题,为了避免将来不必要的麻烦我做了深

入的研究和查看了一些权威的资料,现在和大家共享,希望大家在处理

Oracle临时表是注意一下:

首先是创建临时表的语法:

CREATE GLOBAL TEMPORARY TABLE table

"(" column datatype [DEFAULT expr] [{ NULL | NOT NULL}]

[, column datatype [DEFAULT expr] [ {NULL | NOT NULL} ]... ")"

ON COMMIT {DELETE | PRESERVE } ROWS ;

Oracle中的临时表有两种一种是事务级别的临时表它在事务结束的时候自

动清空记录,另一种是会话级的它在我们访问数据库是的一个会话结束后

自动的清空。关于临时表多用户并行不是问题,一个会话从来不会阻止另

一个会话使用临时表。即使“锁定”临时表,一个会话也不会阻止其他会

话使用它们的临时表。

   如果有在SQL SERVER \sybase中使用临时表的经验,需要主要考

虑的不是执行select xy ,z into #temp from some_table 来创建和装载临时

表,而是:

1.            对于每一个数据库,创建所有的temp表作为全局临时表。这将作

      为应用程序安装的一部分完成,就像创建永久表一样。

2.            只要在过程中简单的insert into temp(x,y,z) selelct x,y,z from some_table

只是理解这点,这里的目的不是运行存储过程创建表。在Oracle中这样做

不是正确的方法。DDL是一种消耗资源非常大的操作,在运行时尽量不要

使用,应用程序需要的临时表应在应用程序安装时创建,而不是在运行时

创建。Oracle中的临时表和其他数据库的临时表是相似的,在每个数据库

中创建临时表一次,不必在数据库中的每个存储过程中创建一次。临时表

总是存在的,他们作为对象存在于数据字典中,并且总是保持为空,直到

有会话在其中放入数据。

所有我在这里说明如果我们在存储过程中建临时表,每次都建立一个那么

我的系统随着用户的操作调用此存储过程,每次多一个这样的表,我们在

不知不觉中数据库中的表的数量会越来越多,而我们还不知道会存在很大

的隐患的所有说这点不可小视,为了我们的系统能在客户那里平稳、安全

的运行我们一定要注意这样的问题。如果不手动Drop 表,临时表还是在数据字典中存在的。