天使羊波波闪耀光芒 软件及互联网爱好者

246月/150

oracle数据库对象-jobs

jobs是oracle数据库对象之一,定时任务。通过调用存储过程dbms_job.submit将任务加入到任务队列中。

查看dbms_job包,它有两个存储过程:

PROCEDURE isubmit ( job IN BINARY_INTEGER,
                    what IN VARCHAR2,
                    next_date IN DATE,
                    interval IN VARCHAR2 DEFAULT 'null',
                    no_parse IN BOOLEAN DEFAULT FALSE);
-- Submit a new job with a given job number.

PROCEDURE submit ( job OUT BINARY_INTEGER,
                   what IN VARCHAR2,
                   next_date IN DATE DEFAULT sysdate,
                   interval IN VARCHAR2 DEFAULT 'null',
                   no_parse IN BOOLEAN DEFAULT FALSE,

-- Bug 1346620: replace pkg vars with constants.
-- Default for instance = dbms_job.any_instance.
                  instance IN  BINARY_INTEGER DEFAULT 0,
                  force IN  BOOLEAN DEFAULT FALSE );
-- Submit a new job.  Chooses JOB from the sequence sys.jobseq.
-- instance and force are added for jobq queue affinity
-- If FORCE is TRUE, then any positive  integer is acceptable as the job
-- instance. If FORCE is FALSE, then the specified instance must be running;
-- otherwise the routine raises an exception.
-- For example,
--   variable x number;
--   execute dbms_job.submit(:x,'pack.proc(''arg1'');',sysdate,'sysdate+1');


注意我们用的是PROCEDURE submit这个存储过程。

1、基本语法

submit ( job OUT BINARY_INTEGER,
         what IN VARCHAR2,
         next_date IN DATE DEFAULT sysdate,
         interval IN VARCHAR2 DEFAULT 'null',
          no_parse IN BOOLEAN DEFAULT FALSE,
);


说明:
job:输出变量,是此任务在任务队列中的编号
what:执行的存储过程或sql语句
next_date:任务第一次执行的时间
interval:注意不是每次执行的间隔时间,而是下一次的执行时间,在本次执行之前对这个表达式求值算出下一次执行时间,所以一般都是sysdate加多少算出来的。

一般我们只要改前4个参数就可以了,任务下一次执行时间是在,本次任务开始时计算出来的。

246月/150

oracle数据库对象-datebase link

database link是oracle的数据库对象之一,用于跨数据库访问。它定义了一个数据库到另一个数据库的路径的对象,database link允许你查询远程表及执行远程程序。database link是A到B单向的连接。

1、准备工作
1)在tnsnames.ora中做好名字解析的配置。

vim $ORACLE_HOME/network/admin/tnsnames.ora

例如:

TESTDB52 =
(DESCRIPTION =
   (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.12.52)(PORT = 1521))
     (CONNECT_DATA =
       (SERVER = DEDICATED)
       (SERVICE_NAME = testdb)
     )
)


2)检查tnsping能否成功

tnsping testdb52

2、基本语法

CREATE [PUBLIC] DATABASE LINK link_name
CONNECT TO username IDENTIFIED BY password
USING 'connect_string';

说明:
link_name:database link的名称
username:对端数据库的用户名
password:对端数据库的密码
connect_string:连接字符串

226月/150

学而不思则罔 思而不学则殆

《鸿观》节目推荐的几本好书:

1、《全球通史》 历史学
2、《自私的基因》 生物学
3、《枪炮、病菌和钢铁》 人类学
4、《失控》 互联网方面
5、《时间简史》 宇宙方面
6、《从黎明到衰落》 西方文化史
7、《艺术的故事》 艺术方面

烧脑神书:
《尤利西斯》
《周易》
《梦的解析》
《看不见的城市》
《微积分》

226月/150

工作体会2

分析系统的方法:
1、功能点
2、信息流、数据流
3、系统边界

做事有把握!

285月/150

oracle数据库对象-同义词

同义词(synonym)是数据库对象,相当于给表起一个别名。

通过创建同义词可以简化对象的访问,使用同义词可以:
1)更方便的引用其他用户拥有的表
2)缩短冗长的对象名

例子:

SQL> select object_name, object_type, owner from dba_objects where object_name='DUAL';

OBJECT_NAME   OBJECT_TYPE   OWNER
------------- ------------- -------------
DUAL          TABLE         SYS
DUAL          SYNONYM       PUBLIC


从例子中看到SYS用户有DUAL表,为了让其它用户能引用DUAL表,建立了一个公共的同义词。

1、创建同义词

CREATE [PUBLIC] SYNONYM synonym_name FOR object_name;

2、删除同义词

DROP SYNONYM synonym_name;

3、查看所有同义词

select * from dba_synonyms;

4、权限
CREATE SYNONYM权限:创建自己私有同义词
CREATE ANY SYNONYM权限:创建其它用户的私有同义词
CREATE PUBLIC SYNONYM权限:创建自己公有同义词

285月/150

oracle数据库对象-序列

序列(sequence)是oracle数据库对象中的一个,每次使用时它会自动增加(或减少)。

1、创建序列
语法:

CREATE SEQUENCE sequence_name
  [INCREMENT BY n]
  [START WITH n]
  [{MAXVALUE n | NOMAXVALUE}] 10^27
  [{MINVALUE n | NOMINVALUE}] -10^27
  [{CYCLE | NOCYCLE }]
  [{CACHE n | NOCACHE}];


说明:
INCREMENT BY:每次加几个
START WITH:从几开始
MAXVALUE:最大值是多少,或NOMAXVALUE不设置最大值
MINVALUE:最小值是多少,或NOMINVALUE不设置最小值
CYCLE:累加到最大值之后循环,或NOCYCLE一直累加不循环
CACHE:设置内存里缓存多少个序列,如果系统down掉了内存中的序列会丢失,导致序列跳号,也可以设置为NOCACHE不缓存

创建语句:

create sequence seq1
increment by 1
start with 1
maxvalue 999999
minvalue 1
cycle
nocache;

这个序列的值从1到999999递增循环。

175月/150

ultraedit问题

ultraedit打开一个文档a里面中文乱码,但是记事本打开a中文正常。文档a是从ftp上拉下来的。

如果把a文档用记事本打开另存为UTF-8格式的b文档,用UE打开又可以显示中文。

如果把转换为UTF-8格式的b文档,UE另存为UTF8无BOM格式的c文档,c文档和a文档所占字节数是一样的,查看16进制也是一样的。UE打开c文档正常显示。

只是UE打开a文档右下角是DOS,c文档右下角是U8-DOS。

不知道为什么UE没有识别出a文档的UTF8格式?

只要用记事本另存为一下就好了。。。

294月/150

4月29日

  最近一段时间一直在写(其实是摘抄的笔记)oracle的文章,不能说精通,收获还是有的。基本可以告一段落了。花了两个月的时间。

294月/150

oracle数据类型简述

oracle提供了22种不同的数据类型。

一、数据类型

1、char
char是一个定长字符串,会用空格填充来达到其最大长度。如果该列没有插入数据为null,插入数据没有到定义的长度,用空格填充。

2、nchar
这是一个包含unicode格式数据的定长字符串。

3、varchar2
目前这也是varchar的同义词。这是一个变长字符串,与char类型不同,它不会用空格填充至最大长度。

4、nvarchar2
这是一个包含unicode格式数据的变长字符串。

5、raw
这是一种变长二进制数据类型,这说明采用这种数据类型存储的数据不会发生字符集转换。可以把它看作由数据库存储的信息的二进制字节串。

使用类似于char,存储的是char的二进制值。(我没用过)

284月/150

oracle数据库对象-索引

一、索引的概念

索引类似于查字典,通过拼音、笔画,只要几步就能查到所要的字。数据库里,通过索引,只要少量的读,就能找到所需的记录。

使用索引需要找到一个平衡点,索引太多会影响DML语句的速度,因为要写索引表。索引太少又不能提高查询速度。

二、B*树索引


1、B*树索引:我们所说的“传统”的索引。create index 创建的索引默认是B*索引。

B*数索引类似于一颗二叉树,但并不是二叉树。B*树中的“B”不代表二叉(binary),而代表平衡(balanced)。

B*树的特点之一是:所有叶子块都应该在树的同一层上。

这一层也称为索引的高度(height),这说明所有从索引的根块到叶子块的遍历都会访问同样数目的块。也就是说,对于形如“SELECT INDEXED_COL FROM T WHERE INDEXED_COL = :X”的索引,要到达叶子块来获取第一行,不论使用的:X值是什么,都会执行同样数目的I/O。

换句话说,索引是高度平衡的(height balanced)。大多数B*树索引的高度都是2或者3,即使索引中有数百万行记录也是如此。这说明,一般来讲,在索引中找到一个键只需要执行2或3次I/O。