位置: 编程技术 - 正文

获取SQL Server数据库元数据的几种方法(sql server获取字段长度)

编辑:rootadmin

推荐整理分享获取SQL Server数据库元数据的几种方法(sql server获取字段长度),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:sqlserver 获取表字段,sqlserver 获取表字段,获取sqlsession,怎么获取sql_id,sql server获取字段长度,sqlserver获取uuid,怎么获取sql_id,sql获取guid,内容如对您有帮助,希望把文章链接给更多的朋友!

元数据简介

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

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

下面我们将介绍几种获取元数据的方法。

获取元数据

使用系统存储过程与系统函数访问元数据

获取元数据最常用的方法是使用 SQL Server 提供的系统存储过程与系统函数。

系统存储过程与系统函数在系统表和元数据之间提供了一个抽象层,使得我们不用直接查询系统表就能获得当前数据库对象的元数据。

常用的与元数据有关的系统存储过程有以下一些:

系统存储过程

◆sp_columns 返回指定表或视图的列的详细信息。◆sp_databases 返回当前服务器上的所有数据库的基本信息。◆sp_fkeys 若参数为带有主键的表,则返回包含指向该表的外键的所有表;若参数为带有外键的表名,则返回所有同过主键/外键关系与该外键相关联的所有表。◆sp_pkeys 返回指定表的主键信息。◆sp_server_info 返回当前服务器的各种特性及其对应取值。◆sp_sproc_columns 返回指定存储过程的的输入、输出参数的信息。◆sp_statistics 返回指定的表或索引视图上的所有索引以及统计的信息。◆sp_stored_procedures 返回当前数据库的存储过程列表,包含系统存储过程。◆sp_tables 返回当前数据库的所有表和视图,包含系统表。

常用的与元数据有关的系统函数有以下一些:

系统函数

◆COLUMNPROPERTY 返回有关列或过程参数的信息,如是否允许空值,是否为计算列等。◆COL_LENGTH 返回指定数据库的指定属性值,如是否处于只读模式等。◆DATABASEPROPERTYEX 返回指定数据库的指定选项或属性的当前设置,如数据库的状态、恢复模型等。◆OBJECT_ID 返回指定数据库对象名的标识号◆OBJECT_NAME 返回指定数据库对象标识号的对象名。◆OBJECTPROPERTY 返回指定数据库对象标识号的有关信息,如是否为表,是否为约束等。◆fn_listextendedproperty 返回数据库对象的扩展属性值,如对象描述、格式规则、输入掩码等。

由于我们无法直接利用到存储过程与函数的返回结果,因此只有在我们关心的只是查询的结果,而不需要进一步利用这些结果的时候,我们会使用系统存储过程与系统函数来查询元数据。

例如,如果要获得当前服务器上所有数据库的基本信息,我们可以在查询分析器里面运行:

EXEC sp_databasesGO

在返回结果中我们可以看到数据库的名称、大小及备注等信息。

但是如果要引用这部分信息,或者存储这部分信息以供后面使用,那么我们必须借助中间表来完成这个操作:

获取SQL Server数据库元数据的几种方法(sql server获取字段长度)

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

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

信息架构视图

◆INFORMATION_SCHEMA.CHECK_CONSTRAINTS:返回有关列或过程参数的信息,如是否允许空值,是否为计算列等。◆INFORMATION_SCHEMA.COLUMNS:返回当前数据库中当前用户可以访问的所有列及其基本信息。◆INFORMATION_SCHEMA.CONSTRAINT_COLUMN_USAGE:返回当前数据库中定义了约束的所有列及其约束名。◆INFORMATION_SCHEMA.CONSTRAINT_TABLE_USAGE:返回当前数据库中定义了约束的所有表及其约束名。◆INFORMATION_SCHEMA.KEY_COLUMN_USAGE:返回当前数据库中作为主键/外键约束的所有列。◆INFORMATION_SCHEMA.SCHEMATA:返回当前用户具有权限的所有数据库及其基本信息。◆INFORMATION_SCHEMA.TABLES:返回当前用户具有权限的当前数据库中的所有表或者视图及其基本信息。◆INFORMATION_SCHEMA.VIEWS:返回当前数据库中的当前用户可以访问的视图及其所有者、定义等信息。

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

例如,我们要得到某个表有多少列,可以使用以下语句:

SELECT COUNT(*) FROM INFORMATION_SCHEMA.COLUMNS

WHERE TABLE_NAME='mytable'

使用系统表访问元数据

虽然使用系统存储过程、系统函数与信息架构视图已经可以为我们提供了相当丰富的元数据信息,但是对于某些特殊的元数据信息,我们仍然需要直接对系统表进行查询。因为SQL Server 将所有数据库对象的信息均存放在系统表中,作为 SQL Server 的管理、开发人员,了解各个系统表的作用将有助于我们了解 SQL Server 的内在工作原理。

SQL Server 的系统表非常多,其中最常用的与元数据查询有关的表有如下一些:syscolumns 存储每个表和视图中的每一列的信息以及存储过程中的每个参数的信息。syscomments 存储包含每个视图、规则、默认值、触发器、CHECK 约束、DEFAULT 约束和存储过程的原始 SQL 文本语句。sysconstraints 存储当前数据库中每一个约束的基本信息。sysdatabases 存储当前服务器上每一个数据库的基本信息。sysindexes 存储当前数据库中的每个索引的信息。sysobjects 存储数据库内的每个对象(约束、默认值、日志、规则、存储过程等)的基本信息。sysreferences 存储所有包括 FOREIGN KEY 约束的列。systypes 存储系统提供的每种数据类型和用户定义数据类型的详细信息。

将系统存储过程、系统函数、信息架构视图与系统表结合使用,可以方便地让我们获得所有需要的元数据信息。

示例:

1、 获得当前数据库所有用户表的名称。

其中主要用到了系统表 sysobjects以及其属性 xtype,还有就是用到了 OBJECTPROPERTY 系统函数来判断是不是安装 SQL Server 的过程中创建的对象。

2、获得指定表上所有的索引名称。

SELECT name FROM sysindexesWHERE id = OBJECT_ID ('mytable') AND indid > 0

综合实例

下面给出了一个存储过程,它的作用是自动将当前数据库的用户存储过程加密。

该存储过程利用了 sysobjects 和 syscomments 表,并巧妙地修改了原存储过程的 SQL 定义语句,将 AS 修改为了 WITH ENCRYPTION AS,从而达到了加密存储过程的目的。本存储过程在 SQL Server 上通过。

SQL优化经验总结 一.优化SQL步骤1.通过showstatus和应用特点了解各种SQL的执行频率通过SHOWSTATUS可以提供服务器状态信息,也可以使用mysqladminextended-status命令获得。SHOWSTATUS

如何调优SQL Server查询 在今天的文章里,我想给你展示下,当你想对特定查询创建索引设计时,如何把你的工作和思考过程传达给查询优化器。下面就一起来探讨一下吧!有

解决SQL SERVER数据库备份时出现“操作系统错误5(拒绝访问)。BACKUP DATABASE 正在异常终止。”错误的解决办法 SQLSERVER数据库进行备份时出现操作系统错误5(拒绝访问)。BACKUPDATABASE正在异常终止。错误。我们应该如何解决这个问题?小编今天为大家推荐一个解

标签: sql server获取字段长度

本文链接地址:https://www.jiuchutong.com/biancheng/347700.html 转载请保留说明!

上一篇:使用mysqladmin检测MySQL运行状态的教程(mysqladmin ping)

下一篇:SQL优化经验总结(sql语句优化总结)

  • 财务报表中的应交税费包括什么
  • 汇算清缴涉及哪些调整
  • 视同销售行为的涉税处理?
  • 购买固定资产的进项税可以抵扣吗
  • 培训个人所得税计算
  • 增值税是价内税,消费者是税款的最终负担者( ) A对 B错
  • 小规模纳税人分红税率
  • 形式发票需要签字盖章吗
  • 应付账款暂估余额
  • 发票号码代码不合法
  • 个人所得税核定征收税率表
  • 打折销售商品会计分录
  • 摊销土地使用权和专利权会计分录怎么写
  • 预付款发票未到如何入成本
  • 生物资产出售的账务处理
  • 企业增加实收资本
  • 固定基金怎么算
  • 员工领取产假工资怎么算
  • 货物运输代理服务税率
  • 免税销售额是否计入成本
  • 算项目人工成本的公式
  • 我公司只开了普票未开专票是否需要发票认证?
  • 银行卡刷卡消费限额
  • 高温气温
  • 待认证发票后面需要做附件吗
  • 研发费用没做账怎么调账
  • 应付职工薪酬借方和贷方
  • window10拖动窗口的手势
  • 如何关闭开始菜单快捷键
  • linux系统安装谷歌浏览器教程
  • win10更新错误0x8000402
  • 工业企业会计核算的特点
  • 为什么无线网密码对了就是连不上网
  • 强烈的建议
  • Laravel中七个非常有用但很少人知道的Carbon方法
  • 什么是国家秘密
  • 珠宝行业会计核算内容
  • js数组方法大全
  • elasticsearch基本概念
  • 未实现汇兑损益如何计算
  • 企业增值税的税收优惠有哪些
  • 固定资产投资额怎么计算
  • 研发费用如何进账
  • 建筑行业会计做账流程及会计分录
  • 存货和总账不平如何调整
  • 增值税税收滞纳金比例
  • 购买的车位如何做账
  • 运费会计科目怎么做
  • 产品的包装费属于什么科目?
  • 快捷酒店财务一般几个人
  • 投资款如何界定
  • 享受所得税减免优惠的生产性外商投资企业包括
  • 委托加工业务经常出现的涉税错误有哪些
  • 技术服务费发票样本
  • 会计账簿按用途分类分为
  • mysql5.x升级到mysql5.7后导入之前数据库date出错的快速解决方法
  • windowsxp删除所有内容
  • win7 64位系统无法使用银行网银怎么办? IE9浏览器无法使用农业银行网银的解决方法
  • win7系统安装无法继续怎么办
  • win7搜索无法使用
  • win10系统自带
  • 苹果MAC电脑怎么玩圣安地列斯
  • 剑网端游吃电脑配置
  • 网站遇到错误号怎么办
  • win7怎么删除右键菜单
  • win7的记事本在哪里打开
  • 如何让w10系统运行更快
  • js隐写
  • jquery 字符串以什么开头
  • python3安装pygame
  • python标准库os中的方法
  • jquery unload
  • python的爬虫技术
  • 自定义圆角控件
  • python按行写入txt
  • UnityException: Launching iOS project via Xcode4 failed
  • Javascript Objects详解
  • asoul抽象
  • 收到农产品普通发票怎么抵扣
  • 铜进口量2019
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设