Oracle数据库管理:经典查询语句与操作示例

需积分: 20 11 下载量 172 浏览量 更新于2024-07-30 收藏 179KB PDF 举报
本文主要介绍了Oracle数据库中的一些经典查询语句和操作,包括创建不同类型的索引、约束条件以及常见的SQL查询示例,用于管理数据库的表空间、数据文件、回滚段、控制文件和日志文件等。 在Oracle数据库中,索引是提升查询性能的关键元素。创建索引的基本语法是`CREATE INDEX index_name ON table_name (column_name) TABLESPACE tablespace_name;`。这里,`index_name`是索引的名称,`table_name`是表的名称,`column_name`是索引的列名,`tablespace_name`是用于存储索引的表空间名。此外,还有不同类型的索引,如位图索引、反转索引和函数索引。位图索引适用于非唯一性数据或低选择度的列,反转索引则可以优化对长字符串的排序,而函数索引允许在索引中使用自定义函数。 创建约束条件可以在建表时一同完成,例如`CREATE TABLE user.table_name (column_name NUMBER(7) CONSTRAINT constraint_name PRIMARY KEY DEFERRABLE USING INDEX storage(INITIAL 100k NEXT 100k) TABLESPACE tablespace_name, column_name2 VARCHAR2(25) CONSTRAINT constraint_name NOT NULL, column_name3 NUMBER(7)) TABLESPACE tablespace_name;` 这条语句创建了一个包含主键约束和非空约束的表,并指定了索引的存储参数。 关于SQL查询,以下是一些常用的示例: 1. 查看表空间名称及大小:`SELECT tablespace_name, round(sum(bytes/(1024*1024)),0) ts_size FROM dba_tablespaces t, dba_data_files d WHERE t.tablespace_name = d.tablespace_name GROUP BY t.tablespace_name;` 这个查询可以帮助我们了解每个表空间的总大小。 2. 查看表空间物理文件的名称及大小:`SELECT tablespace_name, file_id, file_name, round(bytes/(1024*1024),0) total_space FROM dba_data_files ORDER BY tablespace_name;` 通过这个查询,我们可以获取表空间中每个数据文件的信息。 3. 查看回滚段名称及大小:`SELECT segment_name, tablespace_name, r.status, (initial_extent/1024) InitialExtent, (next_extent/1024) NextExtent, max_extents, v.curext CurExtent FROM dba_rollback_segs r, v$rollstat v WHERE r.segment_id = v.usn(+);` 这个查询显示了回滚段的状态和大小信息。 4. 查看控制文件:`SELECT name FROM v$controlfile;` 控制文件记录了数据库的结构信息,这个查询列出所有控制文件的位置。 5. 查看日志文件:`SELECT member FROM v$logfile;` 该查询用于查看数据库的日志文件成员。 6. 表空间的使用情况:查询分为两部分,一个是查看空闲空间:`SELECT sum(bytes)/(1024*1024) AS free_space, tablespace_name FROM dba_free_space GROUP BY tablespace_name;`,另一个是查看表空间的使用率:`SELECT A.TABLESPACE_NAME, A.BYTES TOTAL, B.BYTES USED, C.BYTES FREE, (B.BYTES*100)/A.BYTES "%USED", (C.BYTES*100)/A.BYTES "%FREE" FROM SYS.SM$TS_AVAILA, SYS.SM$TS_USEDB, SYS.SM$TS_FREEC WHERE A.TABLESPACE_NAME = B.TABLESPACE_NAME AND A.TABLESPACE_NAME = C.TABLESPACE_NAME;` 这些查询有助于监控数据库的存储利用率。 这些查询语句和操作对于数据库管理员来说非常实用,能帮助他们有效地管理和优化Oracle数据库。