Catalog & Schema
来源:互联网 发布:用java编登录界面 编辑:程序博客网 时间:2024/06/05 15:40
按照SQL标准的解释,在SQL环境下Catalog和Schema都属于抽象概念,可以把它们理解为一个容器或者数据库对象命名空间中的一个层次,主要用来解决命名冲突问题。从概念上说,一个数据库系统包含多个Catalog,每个Catalog又包含多个Schema,而每个Schema又包含多个数据库对象(表、视图、字段等),反过来讲一个数据库对象必然属于一个Schema,而该Schema又必然属于一个Catalog,这样我们就可以得到该数据库对象的完全限定名称从而解决命名冲突的问题了;例如数据库对象表的完全限定名称就可以表示为:Catalog名称.Schema名称.表名称。这里还有一点需要注意的是,SQL标准并不要求每个数据库对象的完全限定名称是唯一的,就象域名一样,如果喜欢的话,每个IP地址都可以拥有多个域名。
从实现的角度来看,各种数据库系统对Catalog和Schema的支持和实现方式千差万别,针对具体问题需要参考具体的产品说明书,比较简单而常用的实现方式是使用数据库名作为Catalog名,使用用户名作为Schema名,具体可参见下表:
最后一点需要注意的是Schema这个单词,它在SQL环境下的含义与其在数据建模领域中的含义是完全不同的。在SQL环境下,Schema是一组相关的数据库对象的集合,Schema的名字为该组对象定义了一个命名空间,而在数据建模领域,Schema(模式)表示的是用形式语言描述的数据库的结构;简单来说,可以这样理解,数据建模所讲的Schema<也就是元数据>保存在SQL环境下相应Catalog中一个Schema<名叫DEFINITION_SCHEMA>下的表中,同时可以通过查询该Catalog中的另一个Schema<名叫INFORMATION_SCHEMA>下的视图而获取,具体细节不再赘述。
参考资料:
1. ISO/IEC 9075-2:2003 - Database Language SQL (SQL-2003)
2. Database-specific Catalog and Schema Considerations
3. What is a Schema in SQL Server 2005?
- Schema Catalog
- Catalog & Schema
- Catalog与Schema
- 什么是schema和catalog
- 数据库schema与catalog
- 数据库schema、catalog
- Catalog和Schema
- Database catalog and schema
- Catalog与Schema
- 数据库 schema 与 catalog 简介
- 数据库schema与catalog简介
- Creating the Recovery Catalog Schema
- 数据库-----catalog与schema简介
- 数据库schema与catalog简介
- 数据库-----catalog与schema简介
- MySql中的schema和catalog
- 数据库schema与catalog的理解
- 数据库CATALOG跟SCHEMA的意思
- Oracle 分组函数用法示例详解
- Authentication token manipulation error
- hadoop1.1.1安装
- 32. Lotus Notes中的垃圾回收之LotusScript
- Dreamweaver FTP 功能详解
- Catalog & Schema
- JS捕获按键在IE,FF,CHROME中的应用
- android4.0 中设置网络出错com.android.settings.WirelessSettings没有在AndroidManifest.xml中声明
- mysql增加列修改列名列属性以及删除列
- codeiginter 路由功能
- [Data Structure Primary][stack and queue]Rujia Liu-6.1.1-卡片游戏-栈和队列应用1
- hdu1002 A + B Problem II
- 同步与异步
- 深入研究Servlet线程安全性问题