`

对SQL数据表和数据库进行迭代操作

 
阅读更多
本文介绍了master数据库中两个非常有用但在SQL Server在线教科书中没有提到的存储过程。
  这些系统过程对于处理以下任务非常方便,如判断使用的存储空间大小、行数、用户表索引
  等等。第一个过程sp_MSForEachDB对于感兴趣的服务器上的每个数据库执行三条命令。
  @command1:第一个执行的命令
  @replacechar:用另一个占位赋替换“?”
  @command2:第二个执行的命令
  @command3:第三个执行的命令
  @precommand:进入循环前执行的命令
  @postcommand:循环结束后执行的命令
  每个命令集(即使该集合只含有一条命令)作为一个批处理对每个数据库执行,
  所以当我们要将捕获的结果输出到文本而不是标准结果集表时,这将非常有用。
  为了实现这一要求,选择菜单中的查询按钮|输出结果|输出到文本或者按快捷键[Ctrl]T。
  下面的代码返回服务器上每个数据库中用户数据表的数目:
exec sp_MSForEachDB@command1 = "use ? exec sp_SpaceUsed"
  The abbreviated output looks like this:简短输出可能如下:
  数据库名数据库大小未分配空间大小
  --------------------- ------------------
  master 5.25 MB1.26 MB
  reserved data index_size unused
  ------------------ ------------------
  2808 KB 1144 KB 1080 KB 584 KB
  第二个过程sp_MSForEachTable接受7个参数:
  @command1:第一个执行的命令
  @replacechar:用另一个占位符替换“?”
  @command2:第二个执行的命令
  @command3:第三个执行的命令
  @whereand:Where条件语句 (或 Order By 语句)
  @precommand:进入循环前执行的命令
  @postcommand:循环结束后执行的命令
  通过对要传递的参数命名,可以跳过传递空值的要求。当要执行的命令中含有一个问号时,参数@replacechar十分有用。@whereand参数的实现可以根据过滤器缩小输出的范围。
  你还可以加入一个ORDER BY语句。下面的例子返回AdventureWorks数据库中每个数据表的行数,并按照数据表明对它们排序:
exec sp_MSForEachTable@command1 = "Print '?'",
@command2 = "select count(*) from ?", @whereand = "ORDER BY 1"
  下面是输出结果:
[HumanResources].[Department]-----------
16[HumanResources].[Employee]-----------290[HumanResources].
[EmployeeAddress]-----------290[HumanResources].
[EmployeeDepartmentHistory]-----------296
分享到:
评论

相关推荐

    如何对SQL数据表和数据库进行迭代操作

    本文介绍了master数据库中两个非常有用但在SQL Server在线教科书中没有提到的存储过程:sp_MSForEachDB、sp_MSForEachTable。这些系统过程对于处理以下任务非常方便,如判断使用的存储空间大小、行数、用户表索引...

    Microsoft SQL Server 2008技术内幕:T-SQL查询(第二卷)

    主要内容包括SQL的基础理论、查询优化、查询算法及复杂度,以及在使用子查询、表表达式、排名函数、数据聚合和透视转换、TOP和APPLY、数据修改、分区表、特殊数据结构等实际应用时会遇到的各种高级查询问题和解决...

    数据库和ado知识

    使用SQL语句来创建数据库和表 约束分类 top的使用 Distinct的使用(去除重复数) 聚合函数 聚合函数注意事项 between and 和 in 的使用 like, not like 通配符(%,_,[],^) 空值处理:null 是什么? 排序(order by id ...

    NET房地产评估系统VB+SQL-数据库.zip

    MICROSOFT公司的 VISUAL BASIC.NET开发工具,利用其提供的各种面向对象的开发工具,尤其是数据窗口这一能方便而简洁操纵数据库的智能化对象,首先在短时间内建立系统应用原型,然后,对初始原型系统进行需求迭代,...

    Oracle PL SQL程序设计 上 第五版(代码示例)

    第3部分 pl/sql数据 第7章 使用数据 159 第8章 字符串 182 第9章 数字 221 第10章 日期和时间戳 255 第11章 记录类型 297 第12章 集合 313 第13章 其他数据类型 381 第4部分 pl/sql...

    第5章-NoSQL数据库(详细介绍了SQL语句)

    NoSQL数据库是一种非关系型数据库,它提供了一种存储和检索数据的机制,这种数据...NoSQL数据库的优势在于能够处理结构化、半结构化和非结构化数据,支持快速迭代和灵活的数据模型,适用于高扩展性和高可用性的场景。

    基于SQL的企业网站管理系统毕业设计论文

    表,当完成对数据的操作时系统会自动地完成数据库的修改。 经过分析,我们使用 MICROSOFT 公司的 Microsoft Visual Studio 2005 开发 工具及 SQL server 2005 数据库、Adobe 公司的 Macromedia Dreamweaver MX, ...

    Oracle PL/SQL程序设计(第5版)(下册)第二部分

    第3部分 PL/SQL数据 第7章 使用数据 159 第8章 字符串 182 第9章 数字 221 第10章 日期和时间戳 255 第11章 记录类型 297 第12章 集合 313 第13章 其他数据类型 381 第4部分 PL/SQL中的SQL 第14章 DML和事务管理 423...

    Oracle PL SQL程序设计 上 第五版part1

    第3部分 pl/sql数据 第7章 使用数据 159 第8章 字符串 182 第9章 数字 221 第10章 日期和时间戳 255 第11章 记录类型 297 第12章 集合 313 第13章 其他数据类型 381 第4部分 pl/sql...

    SQLServer2008技术内幕T-SQL查询包含源代码及附录A

    主要内容包括SQL的基础理论、查询优化、查询算法及复杂度,以及在使用子查询、表表达式、排名函数、数据聚合和透视转换、TOP和APPLY、数据修改、分区表、特殊数据结构等实际应用时会遇到的各种高级查询问题和解决...

    Oracle PL SQL程序设计 上 第五版part2

    第3部分 pl/sql数据 第7章 使用数据 159 第8章 字符串 182 第9章 数字 221 第10章 日期和时间戳 255 第11章 记录类型 297 第12章 集合 313 第13章 其他数据类型 381 第4部分 pl/sql...

    oracle数据库dba管理手册

    1.4.1 表、列和数据类型 4 1.4.2 约束条件 5 1.4.3 抽象数据类型 6 1.4.4 分区和子分区 7 1.4.5 用户 7 1.4.6 模式 8 1.4.7 索引 8 1.4.8 簇 9 1.4.9 散列簇 9 1.4.10 视图 9 1.4.11 序列 10 1.4.12 过程 10 1.4.13 ...

    医院管理系统是典型的管理信息系统(MIS),其开发主要包括后台数据库的建立和维护以及前端应用程序的开发两个方面.

    医院管理系统是典型的管理信息系统(MIS)... 我们使用Hibernate+struts的结合及SQL Server2000等开发工具 ,首先在短时间内建立系统应用原型,然后对初始原型系统进行需求迭代,不断修正和改进,直到形成用户满意的可行系统.

    数据库系统实现

    书中对数据库系统实现原理进行了深入阐述,并具体讨论了数据库管理系统的三个主要成分—存储管理器、查询处理器和事务管理器的实现技术。书中还对信息集成的最新技术,例如数据仓库、OLAP、数据挖掘、Mediator、数据...

    SSM框架的学习与应用-Java EE企业级应用开发学习记录(第三天)Mybatis的深入学习(动态sql的操作)

    3.项目的数据库文件SQL包含数据结构和数据 4.包含所有的mapper,已经各个SQL映射语句的测试类,可以帮助快速理解! 详细解释了什么是动态SQL,可以根据不同条件动态构建SQL语句,避免大量重复代码。 介绍了动态SQL常用...

    Microsoft+SQL+Server+2008技术内幕:T-SQL查询_源代码及附录 中文版

    主要内容包括SQL的基础理论、查询优化、查询算法及复杂度,以及在使用子查询、表表达式、排名函数、数据聚合和透视转换、TOP和APPLY、数据修改、分区表、特殊数据结构等实际应用时会遇到的各种高级查询问题和解决...

    SQLServer2008查询性能优化 2/2

    《SQL Server 2008查询性能优化》指出的性能要点之一是数据库随着用户和数据的日益增多而进行扩展的必要性。你需要理解性能低下的起因。以及识别并修复它们的方法。《SQL Server 2008查询性能优化》将帮助你: 使用...

    SQLServer2008查询性能优化 1/2

    《SQL Server 2008查询性能优化》指出的性能要点之一是数据库随着用户和数据的日益增多而进行扩展的必要性。你需要理解性能低下的起因。以及识别并修复它们的方法。《SQL Server 2008查询性能优化》将帮助你: 使用...

Global site tag (gtag.js) - Google Analytics