SQL Server元数据的管理与应用

作者:佚名 来源:IT专家网 时间:2009-03-16 14:24:00 

大部分数据库管理员拥有某种形式的数据库元数据库,他们依赖其来跟踪范围很广的Microsoft SQL Server环境。我利用连接的服务器和分布式数据库访问来建立一个已经在我的环境中使用了七年的元数据库。它不是漂亮的,但它是功能性很强的。跟很多IT开发者和数据库管理员一样,即使它有自身的不足我还是为自己的创造感到骄傲。它很慢,不像它可以的那样最新型,也不像它应该的那样安全。

自从读了2007年5月和6月Rodney Landrum在SQL Server杂志上发表的关于SQL Server集成服务(SSIS)和数据库管理员知识库(DBA Repositories)的文章,我知道是时候采取别人的解决方法了。这对于我的环境来说是完美的,而一些改动也是容易采纳的。2008年2月,一篇后续文章在SQL Server杂志上发表,在这篇文章里,Rodney更新了他的解决方法。我下载了代码,在我的测试环境里审核,并迅速把它纳入产品中。当大家普遍地为这个解决方法所提供的而感到高兴时,在它包中缺少的一方面是把数据库关联到应用程序的能力。通过在他的解决方法中增加两张额外的表,我可以在我的“土生土长”元数据库中增加应用程序元数据到我现在使用的SQL Server杂志的方法中。

增加到我数据库中的应用元数据包括创建两张表:dbo.Applications,专为存储所有程序的应用名称,而这些程序在我的环境中依赖于SQL Server数据库,还有

dbo.Database_Applications,它保存SQL 实例、数据库和应用程序之间的关系。


以下为引用的内容:

Applications Table 
CREATE TABLE [dbo].[Applications]
(
[AppID] [int] IDENTITY(154,1) NOT NULL,
[ApplicationName] [varchar](100) NOT NULL,
)
Database_Applications Table 
CREATE TABLE [dbo].[Database_Applications]
(
[DB_AppID] [int] IDENTITY(1,1) NOT NULL,
[ServerName] [varchar](50) NOT NULL,
[DatabaseName] [varchar](100) NOT NULL,
[ApplicationName] [varchar](100) NULL
)            
你可能注意到,我没有规范化dbo.Database_Applications表。如果我规范化,我会只存储两个区域:一个与存储我的应用元数据的表有关的外键,和一个与我的元数据库相对应的外键。我有自己的原因:

我没有处理大量的数据:我有大概800个数据库,这些数据库在我的环境里发布80个实例。虽然这对于一个数据库管理员来说是个很大的环境,但是它既不转变成在我的元数据表里的大量纪录,也不转变成数据库的巨大字节。

不是通过dbo.Applications表的主键,而是包含表中的应用程序名,我可以通过只访问dbo.Database_Applications表产生我的主要应用程序元数据报告(key Application Metadata report)。

我的环境中的SQL元数据库使用“焦土政策”人口处理方法,除了SQL Agent Job History和Backup History,其他的表都被每天删除和重新载入。我发现在dbo.Database_Applications表中保存信息可以使我的生活变得很容易。每日从我的环境中载入数据后,我可以通过以下脚本得到在我的环境中产生的任何新的数据库的良好的陈述。


以下为引用的内容:

SELECT D.[Server], D.DatabaseName
FROM dbo.Databases D LEFT JOIN dbo.Database_Applications DA
ON D.DatabaseName = DA.DatabaseName AND D.[Server] = DA.[ServerName]
WHERE DA.DB_AppID IS NULL
ORDER BY D.[Server], D.DatabaseName            
这个查询的结果提供任何数据库的清单,这些数据库产生于上次我更新应用元数据和服务器时,它不仅是跨域的数据库创建活动的通知,也是致力于更新两个数据库来符合应用程序信息的数据清单。这个查询也适合SQL Server Reporting Services报告的数据表,而当我不在办公室时,SQL Server Reporting Services报告也为我提供了一个新的数据库到我的黑莓(BlackBerry)的日常通知。

最后,我创建了以下存储程序,由此用任何新的数据库信息来合并dbo.Applications表和dbo.Database_Applications 表。它接受三个参数:服务器,数据库和应用程序。如果应用程序已经不存在于dbo.Applications表中,它就会被补充。然后一个记录 * 入到服务器/数据库/应用程序关系中的dbo.Applications表。


 



CREATE PROCEDURE [dbo].[pAdd_Application] @ServerName varchar(50),
@DatabaseName varchar(100), @ApplicationName varchar(100)
AS
--Add any new databases created, but not recorded in the repository, to the repository
UPDATE dbo.Database_Applications
SET ApplicationName = @ApplicationName
WHERE ServerName = @ServerName
AND DatabaseName = @DatabaseName
AND ApplicationName IS NULL
--Determine if there is already an application for this database in the repository,
if not, then add it
IF (SELECT COUNT(*) FROM dbo.Applications WHERE ApplicationName = @ApplicationName) = 0 
BEGIN 
INSERT INTO dbo.Applications (ApplicationName) 
VALUES (@ApplicationName) 
PRINT 'Added new Application: ' + @ApplicationName + ' to Applications table' 
SELECT * FROM dbo.Applications WHERE ApplicationName = @ApplicationName 
END 
--List the new record in the repository 
SELECT ServerName, DatabaseName, ApplicationName 
FROM dbo.Database_Applications 
WHERE ServerName = @ServerName 
AND DatabaseName = @DatabaseName 
AND ApplicationName = @ApplicationName

 


虽然我可以很容易地把这个存储程序的执行整合为SQL Server集成服务(SSIS)程序包中的最后一步,而这个程序包能够组装我的存储数据库,但我选择不这样做,这是为了在我的环境里,我能密切关注围绕新的数据库创造而展开的活动。

标签:SQL,Server,数据,管理,应用
0
投稿

猜你喜欢

  • pip install urllib2不能安装的解决方法

    2022-05-27 12:25:13
  • vue项目中将element-ui table表格写成组件的实现代码

    2024-05-28 15:55:31
  • Python爬取梨视频的示例

    2022-05-24 08:12:33
  • Python决策树分类算法学习

    2023-01-28 17:27:05
  • 详细解读Python的web.py框架下的application.py模块

    2021-06-24 22:28:47
  • 详解python 拆包可迭代数据如tuple, list

    2022-01-08 19:28:43
  • JS数组方法concat()用法实例分析

    2024-04-29 14:08:20
  • 如何使用Python处理HDF格式数据及可视化问题

    2023-11-21 00:17:01
  • 如何在MySQL查询结果集中得到记录行号

    2008-12-17 15:00:00
  • 日常整理python执行系统命令的常见方法(全)

    2022-07-30 10:39:45
  • Django实现发送邮件功能

    2021-05-13 10:25:44
  • 如何将Python列表转换为字符串

    2023-11-02 12:54:27
  • Access数据库的存储上限

    2024-01-17 19:40:18
  • JavaScript中windows.open()、windows.close()方法详解

    2024-04-18 09:30:57
  • 基于python的docx模块处理word和WPS的docx格式文件方式

    2021-11-13 12:07:55
  • 二十种Python代码游戏源代码分享

    2023-07-31 01:37:16
  • go语言Timer计时器的用法示例详解

    2024-04-27 15:39:38
  • 从0到1搭建后端架构的演进(MVC,服务拆分,微服务,领域驱动)

    2022-04-24 10:03:35
  • Flask框架使用DBUtils模块连接数据库操作示例

    2024-01-26 11:46:10
  • Go如何优雅的使用字节池示例详解

    2024-02-10 21:10:17
  • asp之家 网络编程 m.aspxhome.com