使用信息架构视图访问数据库元数据

使用信息架构视图访问数据库元数据,第1张

概述元数据 (metadata) 最常见的定义为'有关数据的结构数据',或者再简单一点就是'关于数据的信息',日常生活中的图例、图书馆目录卡和名片等都可以看作是元数据。在关系型数据库管理系统 (DBMS)

元数据简介

元数据 (Metadata) 最常见的定义为"有关数据的结构数据",或者再简单一点就是"关于数据的信息",日常生活中的图例、图书馆目录卡和名片等都可以看作是元数据。在关系型数据库管理系统 (DBMS) 中,元数据描述了数据的结构和意义。比如在管理、维护 sql Server 或者是开发数据库应用程序的时候,我们经常要获取一些涉及到数据库架构的信息:

某个数据库中的表和视图的个数以及名称 ; 某个表或者视图中列的个数以及每一列的名称、数据类型、长度、精度、描述等; 某个表上定义的约束; 某个表上定义的索引以及主键/外键的信息。

信息架构视图基于 sql-92 标准中针对架构视图的定义,这些视图独立于系统表,提供了关于 sql Server 元数据的内部视图。信息架构视图的最大优点是,即使我们对系统表进行了重要的修改,应用程序也可以正常地使用这些视图进行访问。因此对于应用程序来说,只要是符合 sql-92 标准的数据库系统,使用信息架构视图总是可以正常工作的。

常用的信息架构视图有以下一些:

信息架构视图描述
informatION_SCHEMA .CHECK_CONSTRAINTS返回有关列或过程参数的信息,如是否允许空值,是否为计算列等。
informatION_SCHEMA .ColUMNS返回当前数据库中当前用户可以访问的所有列及其基本信息。
informatION_SCHEMA .CONSTRAINT_ColUMN_USAGE返回当前数据库中定义了约束的所有列及其约束名。
informatION_SCHEMA .CONSTRAINT_@R_403_5991@_USAGE返回当前数据库中定义了约束的所有表及其约束名。
informatION_SCHEMA .KEY_ColUMN_USAGE返回当前数据库中作为主键/外键约束的所有列。
informatION_SCHEMA .SCHEMATA返回当前用户具有权限的所有数据库及其基本信息。
informatION_SCHEMA .@R_403_5991@S返回当前用户具有权限的当前数据库中的所有表或者视图及其基本信息。
informatION_SCHEMA .VIEWS返回当前数据库中的当前用户可以访问的视图及其所有者、定义等信息。

由于这些信息架构都是以视图的方式存在的,因此我们可以很方便地获得并利用需要的信息。

所以很容易的利用数据库元数据信息实现ORM功能,下面是几个常用的sql

       //获取表的所有列
       public const string @R_403_5991@_ColUMN_sql = " SELECT     @R_403_5991@_CATALOG AS [Database],@R_403_5991@_SCHEMA AS Owner,@R_403_5991@_name AS @R_403_5991@name,ColUMN_name AS Columnname,  " +
                          "ORDINAL_position AS Ordinalposition,ColUMN_DEFAulT AS DefaultSetting,IS_NulLABLE AS IsNullable,DATA_TYPE AS DataType,  " +
                          "CHaraCTER_MAXIMUM_LENGTH AS MaxLength,NUMERIC_PRECISION AS Precision,DATETIME_PRECISION AS DatePrecision " +
                           "FROM         informatION_SCHEMA.ColUMNS " +
                           "WHERE     (@R_403_5991@_name = @tblname) ";

         //获取表的所有存储过程和参数
         public const string SP_ParaM_sql="SELECT     SPECIFIC_CATALOG AS [Database],SPECIFIC_SCHEMA AS Owner,SPECIFIC_name AS SPname,ORDINAL_position AS Ordinalposition,  " +
                       "ParaMETER_MODE AS ParamType,IS_RESulT AS IsResult,ParaMETER_name AS name,  " +
                       "CHaraCTER_MAXIMUM_LENGTH AS DataLength,REPLACE(ParaMETER_name,'@','') AS Cleanname " +
                       "FROM         informatION_SCHEMA.ParaMETERS " +
                       "WHERE SPECIFIC_NAME=@spName";

        //获取表的所有存储过程的sql
         public const string SP_sql = " SELECT     SPECIFIC_CATALOG AS [Database],SPECIFIC_name AS name,ROUTINE_DEFinitioN AS sql,CREATED AS CreatedOn," +
                          "LAST_ALTERED AS ModifIEdOn " +
                          "FROM         informatION_SCHEMA.ROUTInes " +
                           "WHERE     (SPECIFIC_name = @spname) ";

      //获取表的所有存储过程 
      public const string @R_403_5991@_sql = "SELECT     @R_403_5991@_CATALOG AS [Database],@R_403_5991@_name AS name,@R_403_5991@_TYPE "+
             "FROM         informatION_SCHEMA.@R_403_5991@S "+
                "WHERE     (@R_403_5991@_TYPE = 'BASE @R_403_5991@') AND (@R_403_5991@_name <> N'sysdiagrams') " +
             "AND TABLE_NAME=@tblName";

总结

以上是内存溢出为你收集整理的使用信息架构视图访问数据库元数据全部内容,希望文章能够帮你解决使用信息架构视图访问数据库元数据所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1151127.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-31
下一篇 2022-05-31

发表评论

登录后才能评论

评论列表(0条)

保存