设为首页 收藏本站
查看: 860|回复: 0

[经验分享] db2 系统表

[复制链接]

尚未签到

发表于 2016-11-13 02:50:59 | 显示全部楼层 |阅读模式
db2 系统表信息
|
字号

 订阅


 
 
[size=0.76em] 
[size=0.76em] 
[size=0.76em][size=1.2em]DB2 CLP 简介
[size=0.76em]DB2 Command Line Processor(DB2 CLP)是所有 DB2 产品中都有的,可以使用这个应用程序运行 DB2 命令、操作系统命令或 SQL 语句。DB2 CLP 可以成为强大的工具,因为它能够将经常使用的命令或语句序列存储在批处理文件中,可以在必要的时候运行这些批处理文件。在 Windows 系统中,必须先(从普通命令窗口)运行 db2cmd 命令来启动 DB2 命令行环境。
[size=0.76em][size=1.2em]在什么时候使用本文介绍的脚本?
[size=0.76em]脚本的优势在于可以重复执行。如果一个任务会被执行多次,或者被多人执行。那么将该任务编写成脚本会提高任务的执行效率和准确性。本文介绍的脚本都是一些在我们进行存储过程开发和调试中经常用到的。读者在后面会渐渐体会到脚本给我们带来的便利。
[size=0.76em][size=1.2em]DB2 系统表的功能
[size=0.76em]编写针对 DB2 的脚本,我们需要首先了解 DB2 为我们提供了哪些命令和信息。DB2 为我们提供了大量的命令例如连接数据库,执行一个 SQL 文件,获得表结构的信息等等。我们会在下面解释具体的脚本的同时对一些简单的 DB2 命令进行解释说明。同时,DB2 把数据库对象的很多信息都存储到了系统表中。熟悉这些系统表就能够通过 SQL 语句获得我们需要的信息。下面我们先来学习一下 DB2 系统表。
[size=0.76em]在 DB2 数据库被创建的时候,DB2 会创建一些系统表。这些系统表中记录了所有数据库对象的信息,表或视图的列的数据类型,约束的定义,对象的权限和对象之间的依赖关系等。这些系统表的模式为 SYSIBM,其表名以 SYS 作为前缀。例如: SYSTABLES、SYSVIEWS 等等。DB2 为这些系统表建立了相对应的只读视图。这些视图的模式是 SYSCAT,它们的内容是其相对应的系统表的全部或者部分内容。这些视图的名字没有 SYS 的前缀。例如:SYSCAT.TABLES 是 SYSIBM.SYSTABLES 的视图。
[size=0.76em]我们可以通过 LIST TABLES FOR SYSTEM 或 LIST TABLES FOR SCHEMA schemaname 命令查看所有的系统表和相关的视图信息。下面我们会介绍一些本文用到的系统表和视图。
[size=0.76em]SYSCAT.TABLES:数据库中对象的信息,包括 table,view,nickname 和 alias 的一些定义。详细说明见表 1。

表 1. SYSCAT.TABLES 视图的说明
列名数据类型描述TABSCHEMAVARCHAR(128)记录 schema 的名字TABNAMEVARCHAR(128)记录数据库对象的名称。包括表、视图、别名等TYPECHAR(1)表示该数据库对象是表,视图还是别名 ('T'表示table; 'V'表示 view; 'N' 表示nickname; 'A' 表示 alias。)COLCOUNTSMALLINT表或视图中列的个数……  
[size=0.76em]SYSCAT.VIEWS:视图的定义信息。详细说明见表 2。

表 2. SYSCAT.VIEWS 视图的说明
列名数据类型描述VIEWSCHEMAVARCHAR(128)视图的 SchemaVIEWNAMEVARCHAR(128)视图名称READONLYCHAR(1)视图是否只读:

  • Y = 视图是只读
  • N = 视图不是只读
VALIDCHAR(1)视图状态是否合法:

  • Y = 视图状态合法(valid)
  • X = 视图状态不合法(invalid)
TEXTCLOB (64K)视图的源程序(DDL)……  
[size=0.76em]SYSCAT.ROUTINES:DB2 UDF,系统方法(system-generated method),用户定义方法(user-defined method)和存储过程(SP)的定义。我们可以认为该视图包含了数据库中程序的定义。见表 3。

表 3. SYSCAT.ROUTINES 视图的说明
列名数据类型描述ROUTINESCHEMAVARCHAR(128)记录程序的 schemaROUTINENAMEVARCHAR(128)记录程序名称ROUTINETYPECHAR(1)记录程序类型:

  • F = Function
  • M = Method
  • P = Procedure
SPECIFICNAMEVARCHAR(128)程序实例的名称(可以指定,也可以由系统自动生成)VALIDCHAR(1)如果存储过程依赖的一些对象被删除或修改了,该存储过程必须要被重建

  • Y = SQL 存储过程是合法的
  • N = SQL 存储过程是非法的
  • X = SQL 存储过程是不可操作的
TEXTCLOB(1M)如果是用 SQL 编写的程序,该字段记录了其创建的 DDL…  
[size=0.76em]表 4 所示的 SYSCAT.ROUTINEDEP 说明了 DB2 UDF与其他对象的依赖关系。

表 4. SYSCAT.ROUTINEDEP 视图的说明
列名数据类型描述ROUTINESCHEMAVARCHAR(128)依赖于其他对象的 DB2 程序的 schemaROUTINENAMEVARCHAR(128)依赖于其他对象的 DB2 程序的名称BTYPECHAR(1)依赖对象的类型:

  • A = Alias
  • S = Materialized query table
  • T = Table
  • V = View
BSCHEMAVARCHAR(128)被依赖的对象的 schemaBNAMEVARCHAR(128)被依赖的对象的名称
[size=0.76em]表 5 所示的 SYSCAT.COLUMNS 说明了表或视图的每一个列的信息。

表 5. SYSCAT.COLUMNS 视图的说明
列名数据类型描述TABSCHEMAVARCHAR(128)表或视图的 SchemaTABNAMEVARCHAR(128)表或视图名称COLNAMEVARCHAR(128)列名称KEYSEQSMALLINT记录列在其表的主键的位置
[size=0.76em]表 6 所示的 SYSCAT.PACKAGEDEP 说明了 Pachage 与其他数据库对象的依赖关系。

表 6. SYSCAT.PACKAGEDEP 视图的说明
列名数据类型描述PKGSCHEMAVARCHAR(128)Package 的 schemaPKGNAMEVARCHAR(18)Package 的名称BTYPECHAR(1)依赖对象的类型:

  • A = Alias
  • B = Trigger
  • I = Index
  • S = Materialized query table
  • T = Table
  • V = View
BSCHEMAVARCHAR(128)被依赖的对象的 schemaBNAMEVARCHAR(128)被依赖的对象的名称
[size=0.76em]表 7 所示的 SYSCAT.TABDEP 说明了视图或者固化视图和 DB2 对象之间的依赖关系。

表 7. SYSCAT.TABDEP 视图的说明
列名数据类型描述TABSCHEMAVARCHAR(128)视图或者固化视图的 schemaTABNAMEVARCHAR(128)视图或者固化视图的名称DTYPECHAR(1)视图的类型:

  • S = Materialized query table
  • V = View (untyped)
  • W = Typed view
BTYPECHAR(1)依赖对象的类型:

  • A = Alias
  • S = Materialized query table
  • T = Table
  • V = View
BS

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-299352-1-1.html 上篇帖子: DB2 Notes 下篇帖子: DB2 命令大全
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表