在开发过程中会遇到需要弄清楚这个数据库什么时候建的,这个数据库中有多少表,这个存储过程长的什么样子等等信息,今天把自己工作过程中经常用到的一些数据库引擎存储过程,系统视图等等总结一下以备不时之用。下面的知识多是自己总结,有一些参考了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使用数据库引擎存储过程,系统视图查询,DBA,BI开发人员必备基础知识的更多相关文章
-
SQL点滴17—使用数据库引擎存储过程,系统视图查询,DBA,BI开发人员必备基础知识
原文:SQL点滴17-使用数据库引擎存储过程,系统视图查询,DBA,BI开发人员必备基础知识 在开发过程中会遇到需要弄清楚这个数据库什么时候建的,这个数据库中有多少表,这个存储过程长的什么样子等等信息 ...
-
Oracle数据库自动备份SQL文本:Procedure存储过程,View视图,Function函数,Trigger触发器,Sequence序列号等
功能:备份存储过程,视图,函数触发器,Sequence序列号等准备工作:--1.创建文件夹 :'E:/OracleBackUp/ProcBack';--文本存放的路径--2.执行:create or ...
-
SQL Server数据库的存储过程中定义的临时表,真的有必要显式删除临时表(drop table #tableName)吗?
本文出处:http://www.cnblogs.com/wy123/p/6704619.html 问题背景 在写SQL Server存储过程中,如果存储过程中定义了临时表,有些人习惯在存储过程结束的时 ...
-
Sql Server数据库之存储过程
阅读目录 一:存储过程概述 二:存储过程分类 三:创建存储过程 1.创建无参存储过程 2.修改存储过程 3.删除存储过程 4.重命名存储过程 5.创建带参数的存储过程 简单来说,存储过程就是一条或 ...
-
SQL Server数据库中的系统数据库?
SQL Server的系统数据库分为:master,model,msdb和tempdb 1.Master数据库 Master数据库记录SQL Server系统的所有系统级别信息(表sysobjects ...
-
基于Spring Boot,使用JPA调用Sql Server数据库的存储过程并返回记录集合
在上一篇<基于Spring Boot,使用JPA操作Sql Server数据库完成CRUD>中完成了使用JPA对实体数据的CRUD操作. 那么,有些情况,会把一些查询语句写在存储过程中,由 ...
-
vs2015中SQLSERVER数据库项目引用系统视图
近期使用VS中的SQLSERVER数据库项目进行项目开发,由于有很多自动化脚本会访问系统视图,例如sysobjects之类的,在项目中的脚本总是提示无法解析的引用,解决办法如下: 添加数据库引用 添加 ...
-
SQL server 数据库的索引和视图、存储过程和触发器
1.索引:数据排序的方法,快速查询数据 分类: 唯一索引:不允许有相同值 主键索引:自动创建的主键对应的索引,命令方式不可删 聚集索引:物理顺序与索引顺序一致,只能创建一个 非聚集索引:物理顺序与索引 ...
-
SQL SERVER 查看所有存储过程或视图里 包含某个关键字的查询语句
SELECT name, type_desc FROM sys.all_sql_modules s INNER JOIN sys.all_objects o ON s.object_id = o.ob ...
随机推荐
-
C# 集合扩展快速排序算法
/// <summary> /// 对集合进行排序,如 /// List<Person> users=new List<Person>(){.......} /// ...
-
Java _ JDK _ Arrays, LinkedList, ArrayList, Vector 及Stack
(最近在看JDK源码,只是拿着它的继承图在看,但很多东西不记录仍然印象不深,所以开始记录JDK阅读系列.) (一)Arrays Arrays比较特殊,直接继承自Arrays ->List(Int ...
-
ubuntu下使用codeblocks
集成开发环境搭建 1. 安装build-essential 方法: sudo apt-get install build-essential 作用:提供编译程序必须软件包的列表信息,编译程序有了这个软 ...
-
Windows环境下使用python 3.x自带的CGI服务器测试cgi脚本--Python
1.在桌面上新建一个文件夹作为服务器目录文件夹(文件夹名称自定义,文件夹位置自定义),在www文件下再建一个文件夹,文件夹名为“cgi-bin”,须是这个文件名,其他试过不行(原因暂时未知)
-
多IP加强SSH的安全性
本文针对一台服务器有多个网卡及IP地址的情况,可以限制某些IP不监听SSH,只允许通过某些IP来登陆 以下配置项在/etc/ssh/sshd_config文件中修改 比如你有4个网卡: eth0 – ...
-
CodeChef题目选讲
https://wenku.baidu.com/view/2445a0322f60ddccda38a023.html 关键点:不超过7条 根据咕咕原理,所以答案最少是N/7;(N小于49就暴力) 随机 ...
-
每天CSS学习之text-shadow
今天学习的是CSS3的一个属性text-shadow.该属性能映射出文字的阴影. text-shadow一共就四个属性: text-shadow: h-shadow v-shadow [blur] ...
-
Oracle EBS 启动调试日志
SELECT * FROM dba_source t WHERE t.TEXT LIKE '%PO_PDOI_TAX_CALCULATION_ERR%' FND:启用调试日志 FND:调试日志级别 ...
-
MySQL:PyMySQL&;ORM
一.PyMySQL介绍 PyMySQL 是在 Python3.x 版本中用于连接 MySQL 服务器的一个库,Python2中则使用mysqldb. Django中也可以使用PyMySQL连接MySQ ...
-
Retain NULL values vs Keep NULLs in SSIS Dataflows - Which To Use? (转载)
There is some confusion as to what the various NULL settings all do in SSIS. In fact in one team whe ...