约束和数据库对象的区别在哪里

       约束(如外键约束、主键约束)这种东西在user_objects中是查不到的,因为约束(如外键约束、主键约束)这种东西不属于数据库对象(object这一范围。那么属于数据库对象(object这一范围又是哪些种东西呢?这个可以查看如视图ALL_OBJECTS等里的OBJECT_TYPE字段,它表示为  Type of the object (such as TABLE, INDEX)。

       那约束和数据库对象的区别在哪里?

       约束只有定义该约束的(数据库)元数据,约束这种东西里面没有存放信息数据(表存放的是业务数据,索引存放的是与表相关的数据)。而数据库对象,比如表,除了有定义该表的(数据库)元数据外,表这种东西里面还存放了业务数据,就是数据行。正因为数据库对象里面存放了数据,所以可以对数据库对象进行插入或是删除、修改数据的这些操作(DML)。故而可以用能否对其进行插入或是删除、修改数据的这些操作(DML),来区别是否是数据库对象。

    例如,

create table  lesson (lesson_name varchar2(20),classroom varchar2(10),constraint pk_lessonprimary key(lesson_name);

表已创建。

create table teacher(namevarchar2(20),lesson_name varchar2(20),constraintfk_lessonname foreign key(lesson_name)  references lesson(lesson_name);

表已创建。

insert into lessonvalues(’english’,’class 1’);
已创建 1 行。

   其中,

constraint pk_lessonprimary key(lesson_name 是主键pk_lesson的元数据(即定义);

constraintfk_lessonname foreign key(lesson_name)  references lesson(lesson_name是主键fk_lessonname的元数据(即定义);

 

create table lesson(lesson_namevarchar2(20), classroom varchar2(10))是表lesson的元数据(即定义);

create tableteacher(name varchar2(20),lesson_name varchar2(20))是表 teacher的元数据(即定义)。

 

insert into lessonvalues(’english’,’class 1’);里的’english’和’class 1’是插入表lesson里的数据。

 

     类似约束这样只有定义没有数据的东西,还有比如存储过程、函数等。

 

参考:

在Oracle数据字典中查看约束信息

 

ALL_OBJECTS

 

OBJECT_ID

NUMBER

NOT NULL

Dictionary object number of the object

DATA_OBJECT_ID

NUMBER

 

Dictionary object number of the segment that contains the object

 

 

 

Note: OBJECT_ID and DATA_OBJECT_ID display data dictionary metadata. Do not confuse these numbers with the unique 16-byte object identifier (object ID) that Oracle Database assigns to row objects in object tables in the system.

 

附加:

查看如视图ALL_OBJECTS等里的OBJECT_TYPE字段后,发现存储过程、函数也是OBJECT_TYPE字段的值,即存储过程、函数也是数据库对象,这样的话,只能说有些数据库对象(比如表可以存放数据,有些不可以,如存储过程、函数等。

那约束和数据库对象的区别在于什么?应该说,约束是以索引等数据库对象为实现手段的一种(概念)对象【比如,主键的本质是一个索引】,故而在逻辑上,是位于数据库对象上一层的对象。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值