SQL Server中元数据函数的用法
作者:springsnow 发布时间:2024-01-20 16:26:54
1、获取数据库标识符:DB_ID
DB_ID函数用于获取当前数据库的唯一ID(int数据类型),数据库ID用于服务器上唯一区分书库。
语法格式:
DB_ID (['database_name'])
参数中的database_name是sysname类型的数据库名称,为可选参数。如果没有指定则返回当前工作数据库的ID。
返回值:
int数据类型的数据库标识符。
示例:
select DB_ID() --输出 8
2、获取数据库名称:DB_NAME
DB_NAME函数用于红区当前数据库的名称(nvarchar数据类型)
语法格式:
DB_NAME(['database_id'])
参数中的database是int数据类型的数据库标识符,为可选参数。如果没有指定则返回当前工作数据库的名称。
示例:
select DB_NAME() --输出 NHibernate
3、获取数据库属性:DATABASEPROPERTYEX
databasepropertyex函数用于获得指定的某个数据库的某个属性的当前设置。执行一次返回一个属性值,若要返回多个属性值,可以查询master系统数据库的sys.database系统视图。
语法格式:
databasepropertyex(database,property)
参数说明:
database:表示要为其返回命名属性的信息的数据库名称,nvarchar(128)数据类型
property:表示要返回的数据库属性,数据类型为Varchar(128)
示例:
select databasepropertyex('NHibernate','recovery') --输出 SIMPLE 这是数据库的恢复模式
Property属性的取值以及说明如下:
属性值 | 说明 | 返回值 |
---|---|---|
Collation | 排序规则名称 | nvarchar(128)、null |
IsAutoClose | 数据库的自动关闭功能是否启用 | Int、null |
IsAutoCreateStatistics | 是否自动创建统计信息 | Int、null |
IsAutoShrink | 是否定期收缩 | Int、null |
IsAutoUpdateStatistics | 是否自动能够更新统计信息 | Int、null |
Recovery | 数据库的恢复模式 | nvarchar(128) |
Status | 数据库的状态 | nvarchar(128) |
Updateability | 是否可以修改数据 | nvarchar(128) |
UserAccess | 哪些用户可以访问数据库 | nvarchar(128) |
Version | 数据库内部版本号 | Int |
4、获取数据库对象标识符:OBJECT_ID
object_id函数用于获取特定数据库、特定架构下特定数据对象的唯一ID(int数据类型),对象的ID用于在数据库内区分唯一。
语法格式:
object_id( '[database_name . [schema_name] . | schema_name . ]object_name'
[,'object_type']
')
参数说明:
database_name
database_name | 数据库名称 |
schema_name | 架构名称 |
object_name | 对象名称 |
object_type | 对象类型 |
返回值:
Int数据类型的对象标识符。
5、获取数据库对象名称:OBJECT_NAME
object_name函数用于获取指定数据库、指定架构下的数据对象的逻辑名称。该名称可以通过查询sys.objects系统视图的name列得到。
语法格式:
object_name(object_id)
参数中的object_id是int数据类型的对象标识符
返回值:
sysname数据类型的逻辑对象名称。
示例:
select OBJECT_NAME(OBJECT_ID('dbo.Account')) --输出Account
6、获取数据库对象属性值:OBJECTPROPERTY
objectproperty函数用于获得指定数据库、指定架构下的指定对象的指定属性的值。
语法格式:
objectproperty(id,property)
参数说明:
id:表示要为其返回命名属性信息的对象的ID,int数据类型。
property:表示要返回的属性,数据类型为sql_variant,即变体。
常见的property属性值
属性值 | 说明 | 返回值 |
---|---|---|
TableHasTextImage | 表中是否含有text、image列 | Int1代表True0代表False |
TableHasPrimaryKey | 表中是否含有主键 | Int1代表True0代表False |
TableHasIndex | 表中是否含有索引 | Int1代表True0代表False |
TableHasForeignKey | 表中是否含有外键 | Int1代表True0代表False |
SchemaId | 对象的架构ID | Int |
OwnerId | 对象的所有者 | Int |
IsView | 是否视图 | Int1代表True0代表False |
IsUserTable | 是否用户创建表 | Int1代表True0代表False |
IsTable | 是否是表 | Int1代表True0代表False |
IsSystemTable | 是否系统表 | Int1代表True0代表False |
IsPrimaryKey | 是否主键 | Int1代表True0代表False |
7、获取文件组标识符:FILEGROUP_ID
filegropy_id函数用于获取文件组的唯一标识符(int数据类型)
语法格式:
FILEGROUP_ID( 'filegropy_name' )
参数中的filegropy_name是sysname类型的数据库名称,可以从sys.filegroups系统视图中查询得到。
返回值:
Int数据类型的文件组标识符。
示例:
select filegroup_id('NHiberna') --输出 null
select filegroup_id('PRIMARY') --输出 1
8、获取文件组名称:FILEGROUP_NAME
filegroup_name函数用于获取文件组的名称(nvarchar数据类型)。
语法格式:
filegroup_name(filegroup_id)
参数中的filegroup_id是int数据类型的文件组标识符,要获得该标识符,可以查询sys.filegroups系统视图
返回值:
nvarchar(128)数据类型的文件组名称
示例:
select filegroup_name(1) --输出 PRIMARY
9、获取文件组属性值:FILEGROUPPROPERTY
filegroupproperty函数用于获得指定文件组的指定属性值。
语法格式:
filegroupproperty(filegroupname,property)
参数说明:
filegroup_name:表示要为其返回属性信息的文件组名称,nvarchar(128)数据类型,可以通过sys.filegroups列获得。
property:表示要返回的属性,数据类型为varchar(128)。
常见的property属性值列表
属性值
属性值 | 说明 | 返回值 |
---|---|---|
IsReadOnly | 文件组是否只读 | Int、Null |
IsUserDefinedEG | 是否为用户定义的文件组 | Int、Null |
IsDefault | 是否默认的文件组 | Int、Null |
示例:
select filegroupproperty('PRIMARY','isreadonly') --输出 0
10、获得文件标识符:FILE_ID
file_id函数用于获取数据库的文件,包括日志文件和数据文件的标识符。文件标识符用于在数据库中唯一区分。
语法格式:
FILE_ID( file_name )
参数中的file_name是sysname类型的文件名称,可以通过查询系统视图sys.database_files中的name列来获得。
返回值:
smallint数据类型的文件标识符。
示例:
select * from sys.database_files --查出有哪些数据库文件
select file_id('NHibernate') --输出 1 查出NHibernate数据库文件对应的fileid
11、获取文件名称:FILE_NAME
file_name函数用于获取当前数据库的逻辑名称(nvarchar数据类型),这里是逻辑名称而不是包含路径的物理名称。
语法格式:
file_name(file_id)
参数中的file_id是int数据类型的数据库标识符。可以查询master数据库的sys.master_files系统视图的file_id列获得服务器上所有数据库的文件ID,也可以查询某个数据库的sys.database_files系统视图的file_id列获得该数据库的文件的ID。
返回值:
nvarchar(128)数据类型的逻辑文件名称。
示例:
select * from sys.database_files --查出有哪些数据库文件
select file_id('NHibernate') --输出 1 查出NHibernate数据库文件对应的fileid
select file_name(1) -- 输出 NHibernate
12、获取文件属性值:FILEPROPERTY
fileproperty函数用于获得指定文件的指定属性值。
语法格式:
fileproperty (file_name ,property )
参数说明:
file_name:表示要为其返回属性信息的文件的逻辑名称,nvarchar(128)数据类型,可以通过sys.database_files系统视图查询name列获得。
property:表示要返回的属性,数据类型为varchar(128)。
常见的property属性值的取值如下:
属性值
属性值 | 说明 | 返回值 |
---|---|---|
IsReadOnly | 文件是否只读 | Int 1代表True,0代表False |
IsPrimaryFile | 是否为主要数据文件 | Int 1代表True,0代表False |
IsLogFile | 是否为日志文件 | Int 1代表True,0代表False |
SpaceUsed | 文件空间的使用量 | Int |
示例:
select fileproperty('nhibernate','isreadonly') --输出 0
select fileproperty('nhibernate','isprimaryfile')--输出1
select fileproperty('nhibernate','islogfile') --输出0
select fileproperty('nhibernate','spaceused') --输出184
来源:https://www.cnblogs.com/springsnow/p/9881229.html
猜你喜欢
- 下面是Sql Server 和 Access 操作数据库结构的常用Sql,如如何新建一个表,如何删除表,如何删除数据,插入数据等等..希望对
- 本文实例为大家分享了python实现两张图片拼接为一张图片并保存的具体代码,供大家参考,具体内容如下这里主要用Python扩展库pillow
- 最近刚学习数据库,首先是了解数据库是什么,数据库、数据表的基本操作,这就面临了一个问题,mysql的安装,我这里下载的是64位的,基于Win
- 1.os 库基本介绍os库提供通用的、基本的操作系统交互功能。三大操作系统:windowsMac OSLinuxos 库是python标准库
- 1.get_dummies()pandas.get_dummies(data, prefix=None, prefix_sep='_
- 前言在学习python的过程中,我们会使用到各种各样的第三方库,但是如何pip有n种方法,如系统提示 如在terminal中pip
- \\create by ahuinan 2009-6-22 \\up by ahuian 2009-6-23 \\up by ahuinan
- Python对于json数据键值对遍历Python中可以使用json模块来解析JSON格式的数据,将其转换成Python中的字典或者列表对象
- 下面一段代码给大家介绍python 脚本生成随机 字母 + 数字密码功能,具体代码如下所述:#coding:utf-8import rand
- 可以使用 Python 的 NumPy 和 OpenCV 库来实现这个任务。提前准备一张图片作为素材。什么是峰值信噪比峰值信噪比(Peak
- asp代理采集代码如下:<%Function ProxyPage(url) Set Retrieval&
- mark标记在实际工作中,我们要写的自动化用例会比较多,也不会都放在一个py文件中,如果有几十个py文件,上百个方法,而我们只想运行当中部分
- 前言如果大家在网上搜索Python 正则表达式,你将会看到大量的垃圾文章会这样写代码:import repattern = re.compi
- 这篇文章主要介绍了python垃圾回收机制(GC)原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要
- 可视性的问题几乎在每次不同产品的用户测试中都会出现:用户总是对页面的某些元素、功能视若无睹,或根本无视。基于此,对这个问题进行了一番小小的研
- 示意图:html:(模态框等 html和js代码,参考:Django 创建/删除用户){# 权限管理 #} <div id
- 对于xml2ddl项目,Freshmeat.org提供了一整套基于GNU或者GPL通用公共许可证下的Python程序。在一个运行的Pytho
- 本文记录了笔者用 Python 爬取淘宝某商品的全过程,并对商品数据进行了挖掘与分析,最终得出结论。项目内容本案例选择>> 商品
- requests接口测试的介绍requests是一个很实用的Python HTTP客户端库,编写爬虫和测试服务器响应数据时经常会用到,Req
- 本文实例分析了Python字符串格式化输出方法。分享给大家供大家参考,具体如下:我们格式化构建字符串可以有3种方法:1 元组占位符m = &