原文:SQL点滴17—使用数据库引擎存储过程,系统视图查询,DBA,BI开发人员必备基础知识

  

在开发过程中会遇到需要弄清楚这个数据库什么时候建的,这个数据库中有多少表,这个存储过程长的什么样子等等信息,今天把自己工作过程中经常用到的一些数据库引擎存储过程,系统视图等等总结一下以备不时之用。下面的知识多是自己总结,有一些参考了MSDN。

  

sp_help

有时候想尽快查出数据库对象的相关信息,这个存储过程就很有用了。使用它可以查询出整个数据库中所有对象的相关信息。直接运行sp_help结果如下图1,上面是数据库对象,包含系统自定义的表,视图等等,下面是自定义数据类型

图1

如果我只想找到某一中数据类型的长度,精度等信息可以运行sp_help datatypename,如下图2

图2

如果我想找出某一个表的相关信息可以运行sp_help tablename,如下图3

图3

如图运行结果的第一个查出表基本信息,第二个查出所有的列,第三个查出主键信息,第四个表查出列的标识,第五个返回所在的文件组信息。

如果我想查出一个存储过程的相关信息可以像上面一样直接使用sp_help procname,如下图4

图4

这里需要注意有时候需要使用单引号将数据库对象包含起来。第一个表查出存储过程的名称等信息,第二个查出参数信息。

  

sp_helptext

有时候我们需要查出存储过程长的什么样子的,虽然可以点击Script Stored Procedure as,CREATE To,New Query Editor Window找到,如图5

图5

但是这样显得有点罗嗦,如果有很多的存储过程我们不可能很快地点击选中我们想要查的哪一个。如果使用sp_helptext procname就可以很快地找到这些信息,如图6

图6

如图,默认是使用grid显示文本,也可以使用文本格式,只要点击 Result to text就可以显示文本格式。如果你还是觉得这样不爽,关键字没有颜色,你可以选中所有文本复制到SQL文本编辑器中。同样你也可以使用sp_helptext查出数据库中的视图,函数,自定义计算列等对象的文本内容。

  

sp_helpdb

一般我们拿到客户的数据库服务器端时候,我们首选要搞清楚这个服务器上有多少个数据库,分别是那些用户创建的等等信息,你也许会直接打开这个数据库用鼠标点击查看,但是如果有很多的数据库就不那么方便了,这个时候直接运行sp_helpdb就很容易查出来了。如下图7。

图7

如图查询出了我的数据库软件中所有的数据库信息。如果我想知道某一个数据库的详细信息,可以使用sp_helpdb dbname查询,如图8。

图8

如图第一个表查出这个数据库的基本信息,第二个表查询得到这个数据库的数据库文件信息等。其他还有很多的数据库引擎存储过程例如:

sp_helpconstraint可以查出当前数据库中所遇的约束信息。

sp_helpextendedproc可以查询所有的扩展存储过程,以及所属的dll的名称,这个在上一个随笔:SQL点滴15—在SQL Server 2008中调用C#程序中提到过。

sp_helpfile和sp_helpdb dbname的效果差不多,查询当前数据库的数据库文件信息。

sp_helpfilegroup返回当前数据库的数据库文件关联的文件组的信息。

Sp_helpindex tablename返回表或视图中的索引的信息。

Sp_helplanguage返回数据库中安装的语言信息。

Sp_helpserver显示当前已经连接的所有服务器的信息。

Sp_helpsort返回服务器默认的排序规则。

  

Sys.objects

数据库开发和application开发有些不同,没有一个像CC,VSS,SVN一样的管理工具来管理代码,因为所有的代码都存放在数据库中,不要跟踪。假设我们要等待数据库设计人员建好表或存储过程后导入数据,但是迟迟不见动静,这时候我们就可以看看数据库中所有的自定义对象,按照最后更新时间来排序。运行下面的语句:select * from sys.objects where type in('U','V','P') order by modify_date

这个语句查出数据库中的所有的用户表,视图,存储过程并按时间排序,这样就可以看到别人最近添加,修改了那些数据库对象。Sys.objects不包含触发器,触发器在sys.triggers中。类似的还有sys.tables,sys.views等等。

  

information_schema

如果我们想快速查询在这个数据库中是否包含address这样的字样的列,并查出它在那个数据库中,那个表中,它的数据类型信息等,这时候使用information_schema这个架构信息就很有用了,如下图9。

图9

相同的在information_schema这个架构中还有很多的信息例如:

information_schema.tables返回表信息,

information_schema.check_constraints返回check约束信息,

information_schema.views返回视图信息,

information_schema.routines返回存储过程信息,还有很多这里不再列举。

  

总之SQL Server数据库提供了丰富的对象统计信息供我们使用,上面只是我经常用到的一部分,在这里抛砖引玉了。

SQL点滴17—使用数据库引擎存储过程,系统视图查询,DBA,BI开发人员必备基础知识的更多相关文章

  1. SQL使用数据库引擎存储过程,系统视图查询,DBA,BI开发人员必备基础知识

    在开发过程中会遇到需要弄清楚这个数据库什么时候建的,这个数据库中有多少表,这个存储过程长的什么样子等等信息,今天把自己工作过程中经常用到的一些数据库引擎存储过程,系统视图等等总结一下以备不时之用.下面 ...

  2. SQL点滴28—一个简单的存储过程

    原文:SQL点滴28-一个简单的存储过程 在表中写入一条数据同事要向另外一个表中写入信息,所以会使用到事务.实际使用的时候还会一次向一个表中吸入多条数据,下面的存储过程,将字符串拆分成数组然后写入到表 ...

  3. SQL优化工具 - SQL Server Profiler与数据库引擎优化顾问

    最近项目做到几千个学生分别去人脸识别记录(目前约630000行)中查询最后一次记录,可想而知性能这块是个麻烦.于是乎,GET到了SQL Server Profiler和数据库引擎优化顾问这俩工SHEN ...

  4. 降龙十八掌之一:(亢龙有悔)SQL Server Profiler和数据库引擎优化顾问

    简介 说到Sql的[性能工具]真是强大,SQL Server Profiler的中文意思是SQL Server事件探查,这个到底是做什么用的呢?我们都知道探查的意思大多是和监视有关,其实这个SQL S ...

  5. Sql Server系列:数据库组成及系统数据库

    1. 数据库组成 数据库的存储结构分为逻辑存储结构和物理存储结构. ◊ 逻辑存储结构:说明数据库是由哪些性质的信息所组成.SQL Server的数据库不仅仅只是数据的存储,所有与数据处理操作相关的信息 ...

  6. SQL Server Profiler和数据库引擎优化顾问

    原文:SQL Server Profiler和数据库引擎优化顾问  简介 说到Sql的[性能工具]真是强大,SQL Server Profiler的中文意思是SQL Server事件探查,这个到底 ...

  7. SQL Server 索引优化-----数据库引擎优化顾问

    本文将根据“数据库引擎优化顾问”(DTA)来发现无用或缺失的索引. 要使用“数据库引擎优化顾问”,首先需要对数据库负载进行监控,为数据库负载分析准备数据.从SSMS的工具中,打开SQL Server  ...

  8. vs2015中SQLSERVER数据库项目引用系统视图

    近期使用VS中的SQLSERVER数据库项目进行项目开发,由于有很多自动化脚本会访问系统视图,例如sysobjects之类的,在项目中的脚本总是提示无法解析的引用,解决办法如下: 添加数据库引用 添加 ...

  9. sql点滴39—解决数据库日志文件过大的问题

    随着数据库使用时间增长,日志文件也在不停的增大,这里介绍几种方法减小这个文件的方法. 1.直接删除log文件(一般不建议) 分离数据库.分离数据库之前一定要做好数据库的全备份,选择数据库——右键——任 ...

随机推荐

  1. Linux以下银行乱码

    更改 /etc/sysconfig/i18n 档,例如 LANG="en_US.UTF-8",xwindow它会显示英文界面. LANG="zh_CN.GB18030&q ...

  2. WPF学习(2)XAML

    XAML(eXtensible Application Markup Language,可扩展应用程序标记语言)是一种声明式的编程语言,遵循XML的语法.WPF使用XAML来设计UI具有易用性.高效性 ...

  3. 【Linux命令】--(9)其他常用命令

    其他常用命令+++++++++++++++++++++++++++++++lndiffdatecal grep wcpswatchatcrontab++++++++++++++++++++++++++ ...

  4. SQL SERVER 内存分配及常见内存问题(2)——DMV查询

    原文:SQL SERVER 内存分配及常见内存问题(2)--DMV查询 内存动态管理视图(DMV): 从sys.dm_os_memory_clerks开始. SELECT [type] , SUM(v ...

  5. msys2 安装注意事项

    它一直在使用 msys.有一个最近发现 msys2.而且msys2 配套的编译器是MinGW-w64. 就试着用了用,感觉还不错,这里把安装过程记录一下. 简单的说,MSYS2 是MSYS的一个升级版 ...

  6. IP地址解析

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.N ...

  7. Java批处理操作

    批量,可以大大提高众多增加.删除.变化的步伐,它是有一个非常大的数据处理效率大收益. 的"连接池"相似.事实上就是先将多次操作(增删改)打包.然后再一次发送运行 主要用到两个方法: ...

  8. Android变化如何破解几场金

    我们在玩游戏的总会遇到一些东西需要购买,但是,我们可能要花钱,那么我们应该怎么办呢?这与游戏的插.我们在这里谈论的Android游戏,搜索互联网上的移动端游戏插件,您可能会发现一个叫段:八门神器.ap ...

  9. IT互联网行业中相关职能的缩写

    RD – Research & Develop 研发FE – Front End 前端QA – Quality Assurance 测试DBA – Database Administrator ...

  10. springMVC注解优化

    本文是本人在学习网络视频的过程中的一些总结. 本文是对关于一些springMVC在使用注解的优化. 使用以下的标签,会自己主动引入Annotation的配置 <mvc:annotation-dr ...