3、oracle表空间及索引操作
3.1、创建表空间和用户授权:
1、创建表空间:
CREATE TABLESPACE <表空间名> LOGGING DATAFILE '<存放路径>' SIZE 50M AUTOEXTEND ON NEXT 50M MAXSIZE 31768M EXTENT MANAGEMENT LOCAL;
#windows存放路径:D:\app\Administrator\oradata\orcl\lc_data.dbf
#linux存放路径:/application/oracle/oradata/orcl/lc_data.dbf
2、创建用户并指定表空间:
CREATE USER <用户名> IDENTIFIED BY <密码> DEFAULT TABLESPACE <表空间名>;
#一个用户只有一个表空间,而表空间可以有多个用户;
3、给用户授予权限:
grant connect,resource,dba to <用户名>;
3.2、删除表空间:
1、删除用户:
drop user <用户名> cascade;
2、删除表空间:
drop tablespace <表空间名> including contents and datafiles cascade constraints;
#including contents:删除表空间中的内容,如果删除表空间之前表空间中有内容,而未加此参数,表空间无法删除;
#including datafiles:删除表空间中的数据文件;
#cascade constraints:删除表空间中表的外键参照;
3.3、表空间查询操作:
1、查询所有表空间及对应的路径:
select tablespace_name,file_name from dba_data_files;
2、查询所有表空间的状态信息;
select tablespace_name,status from dba_tablespaces;
3、增加表空间大小:
ALTER TABLESPACE <表空间名> ADD DATAFILE '<存放路径>' SIZE 50M AUTOEXTEND ON NEXT 50M MAXSIZE UNLIMITED;
4、查看所有用户以及对应的表空间:
select username,default_tablespace from dba_users;
5、查看当前用户的缺省表空间:
select username,default_tablespace from user_users;
6、表空间之间的链接:
(1)创建表空间之间的链接:
create database link TO_<表空间名>_LINK connect to <用户名> identified by <密码> using '<数据库实例名>';
(2)查询表空间之间的链接:
select * from <当前表空间名>@TO_<表空间名>_LINK;
(3)删除表空间之间的链接:
drop database link TO_<表空间名>_LINK;
7、查询所有表空间的用量:
select tablespace_name,count(*) AS extends,round(sum(bytes)/1024/1024,2) AS MB,sum(blocks) AS blocks from dba_free_space group BY tablespace_name;
8、查看序列号,last_number是当前值:
select * from user_sequences;
9、修改表空间属性(离线):
alter tablespace <表空间名> offline;
10、修改表空间属性(在线):
alter tablespace <表空间名> online;
11、修改表空间属性(只读):
alter tablespace <表空间名> read only;
12、修改表空间属性(读写)
alter tablespace <表空间名> read write;
13、修改session的时间格式:
alter session set nls_date_format='yyyy-mm-dd';
3.4、索引操作:
1、创建单一索引:
create index <索引名> on <表名>(<列名1>);
2、创建组合索引:
create index <索引名> on <表名>(<列名1>,<列名2>);
select * from <表名> where <列名1>='<字符>'
#走索引
select * from <表名> where <列名2>='<字符>'
#不走索引
select * from <表名> where <列名1> like '%<字符>%'
#不走索引
select * from <表名> where <列名1>='<字符>' and <列名2>='<字符2>'
#走索引
select * from <表名> where <列名1>='<字符>' or <列名2>='<字符2>'
#不走索引
drop index <索引名称>;
#删除索引
3、查看索引的方法:
(1)在当前用户中查找表名:
select * from user_tables where table_name like '<表名>%';
(2)查询该表的所有索引:
select * from user_indexes where table_name='<表名>';
(3)查询该表的所有索引列:
select * from user_ind_columns where table_name='<表名>';
(4)查询当前用户所有表的索引和索引类别:
select table_name,index_name,index_type from user_indexes order by index_name;
(5)查看当前用户下指定索引的信息:
select * from user_indexes where index_name=upper('&index_name');
(6)查看当前用户下指定的索引的索引列:
select * from user_ind_columns where index_name=upper('&index_name');
(7)查看当前用户下指定索引的大小:
select sum(bytes)/(1024*1024) as "size(M)" from user_segments where segment_name=upper('&index_name');
(8)补充:
user_indexes #存放着当前用户所有表的索引信息;
user_segments #存放着当前用户所有表的索引大小;
user_ind_columns #存放着当前用户所有表的索引列信息;
4、索引补充:
(1)哪些列适合建索引:
1)经常出现在where子句的列;
2)经常用于表连接的列,在匹配表上进行建索引;
3)该列是高基数数据列,高基数数据列是指有很多不同的值;
4)索引里面不计null值;
5)表很大,查询结果集小;
6)在pk、uk、fk键上建立索引;
7)经常需要排序"order by"和分组"group by"的列;
(2)索引用不了的写法:
1)函数导致索引用不了 where upper(colname)= 'char';
2)可以对函数建索引:
create index <索引名> on <表名>(round(<列名1>));
3)表达式导致索引用不了 where colname*12=1200;
4)索引不是万能的;
(3)索引结构:
1)分析索引结构有效性:
analyze index <索引> validate structure;
一般来讲默认的方式是offline;
当以offline的模式analyze索引时,会对table加一个表级共享锁,对目前table的一些实时DMl操作会产生一定的影响;
而以online模式分析时候,则不会加任何lock,但在index_stats中是看不到任何信息的;
2)查看索引结构:
select NAME,HEIGHT,BLOCKS,BR_BLKS,BR_ROWS,LF_BLKS,LF_ROWS from index_stats;
3)合并索引叶级块碎片:
alter index <索引名> coalesce;
4)重建索引:
alter index <索引名> rebuild;
3、oracle表空间及索引操作的更多相关文章
- Linux服务器磁盘扩展和oracle表空间文件迁移操作记录
1.环境介绍 服务器硬件:Dell R710 服务器OS:红帽子Linux RHEL4.8 数据库:Oracle 10g 2.出现的问题 因为数据表每天有上百万的数据写入表,加上建立索引,导致表空 ...
- 转 关于oracle 分区表 表空间以及索引的总结
关于oracle的表空间,分区表,以及索引的总结关键字: oracle, 表空间, 分区表, 索引 上周第一次做数据库测试碰到了很多问题特此总结: 表空间: Oracle的UNDOTBS01.DBF文 ...
- ORACLE表空间操作实例
本文主要介绍oracle表空间常见的操作实例,包括创建.查询.增加.删除.修改.表空间和数据文件常用的数据字典和动态性能视图包括v$dbfile.v$datafile.v$tempfile.dba_s ...
- Oracle 表空间常用操作
aliases: [Oracle表空间] tags: [数据库,Oracle,Blog] summary: [Oracle表空间常用操作,包括查询.分析.扩容.删除.优化等] date: ...
- Oracle表空间管理
oracle表空间相关常用命令小结: 1.ALTER DATABASE SET DEFAULT BIGFILE TABLESPACE; //修改表空间数据文件类型 2.ALT ...
- 【转】Oracle 表空间与数据文件
--============================== --Oracle 表空间与数据文件 --============================== /* 一.概念 表空间:是一个或 ...
- Oracle表空间详解
Oracle表空间详解 1.表空间的分类 Oracle数据库把表空间分为两类:系统表空间和非系统表空间. 1.1系统表空间指的是数据库系统创建时需要的表空间,这些表空间在数据库创建时自动创建,是每个数 ...
- Oracle表空间迁移Move Tablespace
move一个表到另外一个表空间时,索引不会跟着一起move,而且会失效.(LOB类型例外) move分为: *普通表move *分区表move *LONG,LOB大字段类型move来进行测试和说明. ...
- Oracle 表空间与数据文件
-============================== --Oracle 表空间与数据文件 --============================== /* 一.概念 表空间:是一个或多 ...
随机推荐
- megacli修复raid1硬盘
megacli修复raid1硬盘 By HKL, Tuesday 27 August 2019, 评论 [ Hardware Operating ] 使用megaraid修复raid1掉线硬盘 使用说 ...
- mysql如何设置一个字段,里面是自增的序号(1,2,3,..........)。
[遇到问题] [可忽略] 想把以前写的留言板搬到我的网站上去,所以要在Mysql上创建一个一mu一样的数据库,表单,字段..................... userid这个字段忘记了如何添加, ...
- Java 单例模式:懒加载(延迟加载)和即时加载
引言 在开发中,如果某个实例的创建需要消耗很多系统资源,那么我们通常会使用惰性加载机制(或懒加载.延时加载),也就是说只有当使用到这个实例的时候才会创建这个实例,这个好处在单例模式中得到了广泛应用.这 ...
- 3.20 tr:替换或删除字符
tr命令 从标准输入中替换.缩减或删除字符,并将结果写到标准输出. tr [option] [SET1] [SET2] tr [选项] [字符1] [字符2] -d 删除字符 -s ...
- 5分钟安装docker教程
Centos安装docker需要操作系统是 CentOS 7 or 8,必须启用centos extras存储库.默认情况下,此存储库处于启用状态,但如果已禁用它,则需要重新启用它. 卸载旧版本 老版 ...
- 路由信息相关 route 网卡
目录 route命令 1.查看路由表 2.管理路由 基本网络配置 添加网卡地址 修改网卡UUID route命令 路由表管理命令,路由表主要构成: Destination: 目标网络ID,表示可以到达 ...
- Django(46)drf序列化类的使用(ModelSerializer)
前言 我们上篇文章使用到了Serializer类,可能有小伙伴说太过复杂,那么本篇就为大家带来更加简便的序列化类ModelSerializer ModelSerializer 先来看下ModelSer ...
- 201871030136-颜静 实验三 结对项目—《D{0-1}KP 实例数据集算法实验平台》项目报告
项目 内容 课程班级博客链接 https://edu.cnblogs.com/campus/xbsf/2018CST/ 这个作业要求链接 https://www.cnblogs.com/nwnu- ...
- 前端基础——js数据类型及判断方法
一.数据类型 我们通常熟知的数据类型有六种,包括5种基本数据类型(Number, String, Boolean, Undefined, Null)和一种引用数据类型(Object).ES6又新增了一 ...
- 旷视MegEngine核心技术升级
旷视MegEngine核心技术升级 7 月 11 日,旷视研究院在 2020 WAIC · 开发者日「深度学习框架与技术生态论坛」上围绕 6 月底发布的天元深度学习框架(MegEngine)Beta ...