热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

SQLSERVER一些公用DLL的作用解释

SQLSERVER一些公用DLL的作用解释如果你的SQLSERVER安装在C盘的话,下面的路径就是相应SQLSERVER版本的公用DLL的存放路径SQL2005C:ProgramFilesMicrosoftSQLServer90SDKAssembliesSQL2008C:ProgramFilesMicrosoftSQLServer100SDKAssemb

SQLSERVER一些公用DLL的作用解释 如果你的SQLSERVER安装在C盘的话,下面的路径就是相应SQLSERVER版本的公用DLL的存放路径 SQL2005 C:\Program Files\Microsoft SQL Server\90\SDK\Assemblies\ SQL2008 C:\Program Files\Microsoft SQL Server\100\SDK\Assemb

SQLSERVER一些公用DLL的作用解释

如果你的SQLSERVER安装在C盘的话,下面的路径就是相应SQLSERVER版本的公用DLL的存放路径

SQL2005

C:\Program Files\Microsoft SQL Server\90\SDK\Assemblies\

SQL2008

C:\Program Files\Microsoft SQL Server\100\SDK\Assemblies\

SQL2012

C:\Program Files\Microsoft SQL Server\110\SDK\Assemblies\

可以看到随着SQLSERVER版本的升级,这些公用DLL变得越来越多了,因为SQLSERVER的功能越来越多了

这些DLL有什么用??

这些DLL是供SQLSERVER调用的,,因为这些公用DLL在SQLSERVER的很多组件中都有用到,所以SQLSERVER就把这些

DLL放到X:\Program Files\Microsoft SQL Server\X\SDK\Assemblies\文件夹下以供其他SQLSERVER组件调用

例如SSIS、SSAS、数据库引擎还有其他的工具

其实从文件夹路径名我们就可以知道这些DLL的作用:SDK\Assemblies\

大家不知道SDK的含义可以百度一下,不过可能大家比较赖,我就贴出来吧

SDK(Software Development Kit, 即软件开发工具包 )一般是一些被软件工程师用于为特定的软件包、软件框架、硬件平台、操作系统等

建立应用软件的开发工具的集合。

资深程序员一定知道SDK的作用,他就是某个软件提供给我们程序员用来开发的一些接口或者API

本人觉得X:\Program Files\Microsoft SQL Server\X\SDK\Assemblies\文件夹下面的这些DLL不只是提供给SQLSERVER调用的

我们也可以调用这些DLL来开发SQLSERVER数据库的一些相关软件和工具

例子一:

园子里的胡勇大侠就用了下面的两个DLL来做出了: (喷血分享)利用.NET生成数据库表的创建脚本,类似SqlServer编写表的CREATE语句

Microsoft.SqlServer.ConnectionInfo.dll

Microsoft.SqlServer.Management.Sdk.Sfc.dll

例子二:

又例如这个帖子:用c#做了个,sqlServer2005里面那个事件监控器一样的程序,启动问题请帮看看

用Microsoft.SqlServer.ConnectionInfo.dll这个DLL做一个类似于SQL TRACE的工具出来,用来实时查看执行的脚本以及其他信息

例子三:

SQLDoc Sharp(SQLSERVER数据库文档生成工具)

这个工具在codeproject上可以下载:

用到了下面的DLL

Microsoft.SqlServer.ConnectionInfo.dll

Microsoft.SqlServer.Management.Sdk.Sfc.dll

Microsoft.SqlServer.Smo.dll

Microsoft.SqlServer.SmoExtended.dll

Microsoft.SqlServer.SqlEnum.dll

公用DLL用什么语言编写?

我们可以发现上面的三个例子中的工具都是用.NET编写的工具,包括SQLDoc Sharp都是用.NET编写的winfrom软件

我们用ILSpy这个软件反编译一下各个SQLSERVER版本的下DLL

将DLL全部拖入去ILSpy里面

SQL2005

SQL2008

SQL2012

SQL2008里面有两个DLL是不能够反编译的,分别是Redist_TSqlLanguageService.dll和Redist_DACFramework.dll

SQL2012里面只有一个DLL是不能够反编译的,是Redist_TSqlLanguageService.dll

不能被反编译的DLL有可能是用C或者C++编写的

我估计这些不能反编译的dll不会提供API功能给用户,只是给SQLSERVER调用的,而且这些DLL对于SQLSERVER的性能有至关重要的作用

所以用C或者C++编写

从上面反编译这些DLL的情况来看,SQLSERVER里面有很大一部分组件或者代码都是用.NET来编写的

除了一些关键功能或者涉及到性能相关的功能组件用C或者C++编写

这里从另一个侧面也可以看出微软对.NET的重用,从SQLSERVER2005开始大量用.NET来编写一些组件代码

从上面三个例子中也可以看出为什麽他们首选.NET来编写这些工具,因为这些公用DLL本来就是.NET DLL(可托管代码)

简单介绍DLL

限于本人的能力有限,本人就只简单介绍比较熟悉的DLL,其他不熟悉的大家可以查MSDN或者百度

我这里会给出一些DLL的资料和查百度、MSDN时候的结果

我这里只介绍SQLSERVER2012的,因为SQLSERVER2012比较齐全,但是某些功能在不同的SQLSERVER版本里会有变化

例如上面第二个例子里:用c#做了个,sqlServer2005里面那个事件监控器一样的程序,启动问题请帮看看

里面说到了TMO这个类在SQL2005版本的SDK里面和SQL2008版本的SDK里面有变化,导致运行时出错

使用Trace Management Object监测和诊断SQL Server(一)

在SQL Server 2005里TMO对象被实现在了Microsoft.SqlServer.ConnectionInfo.dll里,

在SQL Server 2008里TMO对象则被移到了Microsoft.SqlServer.ConnectionInfoExtended.dll里,

但仍然在Microsoft.SqlServer.Management.Trace命名空间里。

类似上面的有变化的API我就不说了,大家开发的时候一定要查清楚MSDN和百度,不要搞错,因为这些SDK的文档比较少

大部分都是E文的,开发起来会比较头痛

废话不说了,开始~

Microsoft.AnalysisServices.DLL

Microsoft.DataWarehouse.Interfaces.DLL

SSAS,数据仓库相关的接口

Kpi 类:

Microsoft.ExceptionMessageBox.DLL

SQLSERVER中的各种异常对话框都调用这个DLL

?forum=sqltools

Microsoft.ReportingServices.Interfaces.DLL

SSRS的相关的接口

Microsoft.SqlServer.Smo.DLL

Microsoft.SqlServer.SmoExtended.DLL

Microsoft.SqlServer.Management.Sdk.Sfc.DLL

Microsoft.SqlServer.ConnectionInfo.DLL

Microsoft.SqlServer.ConnectionInfoExtended.DLL

SMO:SQLSERVER管理对象

监控SQLSERVER或者连接SQLSERVER用到

提供SMO对象功能,是SqlServer Management Ojbects的简称,由SQL2005提供的管理对象

只要SQL Server Management Studio能实现的东西,用smo都能实现,因为SQL Server Management Studio就是用smo开发的。

如果你有足够的实力,完全可以开发一个可以藐视SQL Server Management Studio的工具,比如加入智能感知的功能

为了支持 SQL Server 的管理,Integration Services 提供了可以遍历 SQL 管理对象 (SMO) 的对象的枚举器。

例如,包可使用 SMO 枚举器对某个 SQL Server 安装中的 Jobs 集合中的每个作业执行相同的管理功能。

Microsoft.SqlServer.Dts.Design.DLL

Microsoft.SqlServer.DTSPipelineWrap.DLL

Microsoft.SQLServer.DTSRuntimeWrap.DLL

Microsoft.SQLServer.ManagedDTS.DLL

Data Transformation Services (DTS) 数据传输服务相关的DLL

?forum=sqlintegrationservices

?forum=sqlintegrationservices

Microsoft.SqlServer.Management.RegisteredServers.DLL

注册服务器需要用到的DLL

?forum=sqlsmoanddmo

Microsoft.SqlServer.Management.Utility.DLL

Microsoft.SqlServer.Management.UtilityEnum.DLL

Utility:实用工具类代表一个控制点(UCP)定义的SQL服务器来管理一个或多个的远程SQLSERVER实例的方法和属性

UtilityEnum:该microsoft.sqlserver.management.utility命名空间包含展现SQLSERVER实用工具对象的类

(v=sql.110).aspx

(SQL.105).aspx

Microsoft.SqlServer.Management.XEvent.DLL

Microsoft.SqlServer.Management.XEventEnum.DLL

扩展事件相关的DLL

XEvent:在SQLSERVER客户端组件和服务器端组件里创建和使用SQLSERVER扩展事件通过通用对象模型

扩展事件基础设施支持SQL服务器事件数据的相关性

在某些情况下,基础设施也可以用于从数据看应用程序和操作系统里获取相关数据

Microsoft.SqlServer.OlapEnum.DLL

olap系统相关的DLL

Microsoft.SqlServer.Rmo.DLL

Microsoft.SqlServer.Replication.DLL

与复制相关的DLL

RMO:复制管理对象

?forum=sqlreplication

?forum=sqlreplication

Microsoft.SqlServer.Replication.dll 引发的IIS异常

?forum=sqlreplication

Microsoft.SqlServer.ServiceBrokerEnum.DLL

ServiceBroker相关技术的DLL

Microsoft.SqlServer.SqlWmiManagement.DLL

Microsoft.SqlServer.WmiEnum.DLL

与WMI(Windows Management Instrumentation,Windows 管理规范)相关的DLL

打开【SQL Server 配置管理器】提示:无法连接到 WMI 提供程序。您没有权限或者该服务器无法访问。

请注意,您只能使用 SQL Server 配置管理器来管理 SQL Server 2005 服务器。

如何在SQL Server 中添加WMI alert

Microsoft.SqlServer.SString.DLL

SecureString这个类里面有很多字符串相关的C#函数

这个类里面的代码

类:SqlSecureString

推荐阅读
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • 本文是一位90后程序员分享的职业发展经验,从年薪3w到30w的薪资增长过程。文章回顾了自己的青春时光,包括与朋友一起玩DOTA的回忆,并附上了一段纪念DOTA青春的视频链接。作者还提到了一些与程序员相关的名词和团队,如Pis、蛛丝马迹、B神、LGD、EHOME等。通过分享自己的经验,作者希望能够给其他程序员提供一些职业发展的思路和启示。 ... [详细]
  • Oracle优化新常态的五大禁止及其性能隐患
    本文介绍了Oracle优化新常态中的五大禁止措施,包括禁止外键、禁止视图、禁止触发器、禁止存储过程和禁止JOB,并分析了这些禁止措施可能带来的性能隐患。文章还讨论了这些禁止措施在C/S架构和B/S架构中的不同应用情况,并提出了解决方案。 ... [详细]
  • 如何提高PHP编程技能及推荐高级教程
    本文介绍了如何提高PHP编程技能的方法,推荐了一些高级教程。学习任何一种编程语言都需要长期的坚持和不懈的努力,本文提醒读者要有足够的耐心和时间投入。通过实践操作学习,可以更好地理解和掌握PHP语言的特异性,特别是单引号和双引号的用法。同时,本文也指出了只走马观花看整体而不深入学习的学习方式无法真正掌握这门语言,建议读者要从整体来考虑局部,培养大局观。最后,本文提醒读者完成一个像模像样的网站需要付出更多的努力和实践。 ... [详细]
  • 分享css中提升优先级属性!important的用法总结
    web前端|css教程css!importantweb前端-css教程本文分享css中提升优先级属性!important的用法总结微信门店展示源码,vscode如何管理站点,ubu ... [详细]
  • svnWebUI:一款现代化的svn服务端管理软件
    svnWebUI是一款图形化管理服务端Subversion的配置工具,适用于非程序员使用。它解决了svn用户和权限配置繁琐且不便的问题,提供了现代化的web界面,让svn服务端管理变得轻松。演示地址:http://svn.nginxwebui.cn:6060。 ... [详细]
  • 篇首语:本文由编程笔记#小编为大家整理,主要介绍了软件测试知识点之数据库压力测试方法小结相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • 本文介绍了在Hibernate配置lazy=false时无法加载数据的问题,通过采用OpenSessionInView模式和修改数据库服务器版本解决了该问题。详细描述了问题的出现和解决过程,包括运行环境和数据库的配置信息。 ... [详细]
  • 本文详细介绍了云服务器API接口的概念和作用,以及如何使用API接口管理云上资源和开发应用程序。通过创建实例API、调整实例配置API、关闭实例API和退还实例API等功能,可以实现云服务器的创建、配置修改和销毁等操作。对于想要学习云服务器API接口的人来说,本文提供了详细的入门指南和使用方法。如果想进一步了解相关知识或阅读更多相关文章,请关注编程笔记行业资讯频道。 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • 如何用UE4制作2D游戏文档——计算篇
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了如何用UE4制作2D游戏文档——计算篇相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 闭包一直是Java社区中争论不断的话题,很多语言都支持闭包这个语言特性,闭包定义了一个依赖于外部环境的自由变量的函数,这个函数能够访问外部环境的变量。本文以JavaScript的一个闭包为例,介绍了闭包的定义和特性。 ... [详细]
  • Android源码深入理解JNI技术的概述和应用
    本文介绍了Android源码中的JNI技术,包括概述和应用。JNI是Java Native Interface的缩写,是一种技术,可以实现Java程序调用Native语言写的函数,以及Native程序调用Java层的函数。在Android平台上,JNI充当了连接Java世界和Native世界的桥梁。本文通过分析Android源码中的相关文件和位置,深入探讨了JNI技术在Android开发中的重要性和应用场景。 ... [详细]
  • 本文介绍了在Mac上安装Xamarin并使用Windows上的VS开发iOS app的方法,包括所需的安装环境和软件,以及使用Xamarin.iOS进行开发的步骤。通过这种方法,即使没有Mac或者安装苹果系统,程序员们也能轻松开发iOS app。 ... [详细]
author-avatar
D萳飝赝_870
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有