--20170322

--1.0

--更新表的统计信息
begin
dbms_stats.set_table_stats(user,'EMP',numrows => 10000);
end;

begin
dbms_stats.set_table_stats(user,'DEPT',numrows => 10000);
end;

--重新查看表的统计信息
select t.table_name,t.num_rows,t.blocks from user_tables t where t.table_name in ('EMP','DEPT');
/*
DEPT    10000    100
EMP    10000    100
*/

--2.0

--查看索引占用的数据块数、聚簇因子
select t1.index_name,t2.num_rows,t2.blocks ,t1.clustering_factor  from user_indexes  t1  inner  join user_tables t2  on t1.table_name=t2.table_name

/*
PK_YW_ZJFPJL    97    35    85
PK_YW_ZJFPDQ    3    5    1
PK_YW_YJFPLS_9    57    5    11
PK_YW_YJFPLS_8    35    5    1
PK_YW_YJFPLS_7    15    5    1
PK_YW_YJFPLS_6    19    5    1
*/

如果聚簇因子与块数接近,则说明表相当有序,得到了很好的组织。即 一个叶子块中的索引条目指向了同一个数据块中的行;

如果聚簇因子与行数接近,表的次序可能就是非常随机的。即 同一个叶子块上的索引条目不太可能指向同一个数据块中的行
--3.0

--type 使用细则,注意标红地方哦
create or replace type emp_type
as object(
  EMPNO    NUMBER(4),
  ENAME    VARCHAR2(10),
  JOB      VARCHAR2(9),
  MGR      NUMBER(4),
  HIREDATE DATE,
  SAL      NUMBER(7,2),
  COMM     NUMBER(7,2)
);

create or replace type emp_tab_type as table of emp_type;

--20170324

表12.-3   向日期增加时间

时间单位               操作                                                                  描述

DATE + n/24/60/60                     一天有86,400秒。由于加1就是增加1天,所以加12.86400就是向一个日期增

N秒         DATE + n/86400                          加1秒。我更喜欢用n/24/60/60技术而不是12.86400技术。它们是等价的。

DATE+NUMTODSINTERVAL       更可读的一种方法是使用NUMTODSINTERVAL(日/秒数间隔)

(n,'second')                                  函数来增加N秒

DATE + n/24/60                          一天有12.440分钟,因此加12.1440就是向一个DATE增加1分钟。更可读的

N分钟      DATE + n/1440                            一种方法是使用NUMTODSINTERVAL函数

DATE+NUMTODSINTERVAL

(n,'minute')

DATE + n/24

N小时      DATE+NUMTODSINTERVAL       一天有24个小时,因此增加12.24就是向一个DATE增加1小时。更可读的

(n,'hour')                                      一种方法是使用NUMTODSINTERVAL函数

N天         DATE + n                                     向DATE直接加N,就是增加或减去N天

N周         DATE + 7*n                                 一周有7天,所以只需将周数乘以7就是要增加或减去的天数

N月         ADD_MONTHS(DATE,n)              可以使用ADD_MONTHS内置函数或者向DATE增加一个N个月的间隔。

DATE+NUMTOYMINTERVAL      请参考稍后有关DATE使用月间隔做出的重要警告

(n,'month')

N年         ADD_MONTHS(DATE,12.*n)        可以使用ADD_MONTHS内置函数,增加或减去N年时将参数指定为12.*n。

DATE+NUMTOYMINTERVAL      利用年间隔可以达到类似的目标,不过请参考稍后有关日期使用年间隔做出的

(n,'year')                                      重要警告

--201703301429

--lob
--对象有自己的专门存储空间  实际上一个lob对象 都会在原表中保留一个指针,而该指针指向了实际的存储位置

--对表启用并行

alter table test0328 parallel;

--批量移动分区表的各个分区
begin
           for x in ( select partition_name
                  from user_tab_partitions
                  where table_name = 'BIG_TABLE2' )
           loop
                  execute immediate   'alter table big_table2 move partition ' ||x.partition_name;
           end loop;
 end;

nologging 操作
create index fy_2006_idx on fy_2006(id) nologging;

Oracle 9i & 10g编程艺术-深入数据库体系结构-学习笔记(持续更新中)的更多相关文章

  1. [读书]10g/11g编程艺术深入体现结构学习笔记(持续更新...)

    持续更新...) 第8章 1.在过程性循环中提交更新容易产生ora-01555:snapshot too old错误.P257 (这种情况我觉得应该是在高并发的情况下才会产生) 假设的一个场景是系统一 ...

  2. Oracle数据库常用函数使用--持续更新中

    NVL函数.NVL( string1, replace_with).如果string1为NULL,则NVL函数返回replace_with的值,否则返回原来的值. INSTR函数.用于查找指定字符串是 ...

  3. MySQL数据库知识点整理 (持续更新中)

    一.修改用户密码 格式(在命令行下输入):mysqladmin -u 用户名 -p旧密码 password 新密码 1. 给root添加密码ab12:  mysqladmin -uroot -pass ...

  4. Go学习笔记(持续更中,参考go编程基础,go边看边练)

    使用关键字 var 定义变量,自动初始化为零值.如果提供初始化值,可省略变量类型. 在函数内部,可用更简略的 := 方式定义变量.空白符号_ package main import "fmt ...

  5. 【oracle笔记1】基础知识大集锦:增删改,数据类型,用户操作,持续更新中···

    什么是数据库?数据库就是用来存储和管理数据的仓库.首先我来简单介绍一下各数据库的背景,常见的数据库如下,oracle:甲骨文公司(市场占用率最高),oracle也是一个公司名,翻译过来就是甲骨文的意思 ...

  6. 数据库MySQL学习笔记高级篇

    数据库MySQL学习笔记高级篇 写在前面 学习链接:数据库 MySQL 视频教程全集 1. mysql的架构介绍 mysql简介 概述 高级Mysql 完整的mysql优化需要很深的功底,大公司甚至有 ...

  7. mySQl数据库的学习笔记

    mySQl数据库的学习笔记... ------------------ Dos命令--先在记事本中写.然后再粘贴到Dos中去 -------------------------------- mySQ ...

  8. Mysql数据库基础学习笔记

    Mysql数据库基础学习笔记 1.mysql查看当前登录的账户名以及数据库 一.单表查询 1.创建数据库yuzly,创建表fruits 创建表 ) ) ,) NOT NULL,PRIMARY KEY( ...

  9. 《Linux命令、编辑器与shell编程》第三版 学习笔记---002

    <Linux命令.编辑器与shell编程>第三版 学习笔记---001 Linux命令.编辑器与shell编程 Shell准备 1.识别Shell类型 echo  $0 echo $BAS ...

随机推荐

  1. Day05 xml详解

    day05总结 今日内容 XML语法 XML约束之DTD XML解析器介绍 XML解析之JAXP( DOM.SAX ) DOM4J Schema   一.XML语法 XML概述   1 什么是XML ...

  2. cocos2d-x-3.0 window+eclipse Android Project 环境与开发新手教程

    今天闲来没事,听说最新cocos2d-x 出新版3.0.所以来学习一下. 大致參考官方教程:http://www.cocos2d-x.org/wiki/How_to_Build_an_Android_ ...

  3. 模仿Masonary写一个计算器

    1.CaculatorMaker @interface CaculatorMaker : NSObject @property(nonatomic,assign)int result; -(Cacul ...

  4. android showDialog用法

    protected Dialog onCreateDialog(int id) { // TODO Auto-generated method stub switch(id){ case 10: re ...

  5. centos 目录结构 快捷键 ls命令,alias别名,so:动态库 a:静态库,环境变量PATH,Ctrl+z 暂停命令,Ctrl+a 光标到行首,Ctrl+e 光标到行尾,Ctrl+u 删除光标前所有字符 Ctrl+r 搜索命 hash命令 Ctrl+左箭头/右箭头 cd命令 第三节课

    centos 目录结构 快捷键 ls命令,alias别名,so:动态库 a:静态库,环境变量PATH,Ctrl+z 暂停命令,Ctrl+a 光标到行首,Ctrl+e 光标到行尾,Ctrl+u 删除光标 ...

  6. 模块讲解----XML模块

    XML实现不同语言或者程序之间进行数据交换的协议XML文件格式如下: 1.浏览器返回的字符串格式类型有: a.HTML b.Json c.XML 2.XML格式如下: <data> #表示 ...

  7. Django小项目web聊天

    WEBQQ的实现的几种方式 1.HTTP协议特点 首先这里要知道HTTP协议的特点:短链接.无状态! 在不考虑本地缓存的情况举例来说:咱们在连接博客园的时候,当tcp连接后,我会把我自己的http头发 ...

  8. django-from

    构建一个表单 这是一个非常简单的表单.实际应用中,一个表单可能包含几十上百个字段,其中大部分需要预填充,而且我们预料到用户将来回编辑-提交几次才能完成操作. 我们可能需要在表单提交之前,在浏览器端作一 ...

  9. Redis 监控方案

    一.概述 近些天,遇到Redis监控的应用场景,从网上搜罗了一些文章,做了整理. 二.工具列表 2.1 redis-faina 见参考文章1 2.2 redis-live 见参考文章1 2.3 red ...

  10. poj1434 Fill the Cisterns!

    地址:http://poj.org/problem?id=1434 题目:Fill the Cisterns! Fill the Cisterns! Time Limit: 5000MS   Memo ...