统计一个数据库中,无记录的表的sql语句
SQL Server数据库中统计无记录数的表
大家使用的时候,将sql脚本中的红色[TestDB] 换成你的目标数据库名称。
1 /************************************************************ 2 * Code formatted by SoftTree SQL Assistant ?v7.0.158 3 * Time: 2016/5/19 18:47:02 4 * Author:zhangcn 5 ************************************************************/ 6 7 -- 指定一个数据库名称 8 USE [TestDB]; 9 10 DECLARE @tableCount INT = 0; -- 定义变量,统计一个数据库中有多少张表 11 DECLARE @rowCount INT = 0; -- 定义变量,记录单个表中的记录数 12 DECLARE @i INT = 1; -- 定义变量, 用于循环计数 13 DECLARE @tableNamesWithoutData NVARCHAR(4000) = ''; -- 定义变量,用于记录数据库中哪些表没有数据 14 DECLARE @tableNamesWithoutDataCount INT = 0; -- 定义变量,统计数据库中无无记录表的数量 15 DECLARE @tableName NVARCHAR(2000) = ''; -- 定义变量,记录单个表的名字(该表没有记录) 16 DECLARE @sql NVARCHAR(2000) = ''; -- 定义sql,接收查询语句 17 18 -- 统计指定的数据库中有多少张表 19 SELECT @tableCount = COUNT([name]) 20 FROM sys.objects -- 系统基础对象所在的视图 21 WHERE [type] = 'U' 22 23 -- 判断临时表是否已经存在 24 IF OBJECT_ID('tempdb..#TempTable') IS NOT NULL 25 BEGIN 26 DROP TABLE #TempTable;-- 删除临时表 27 END 28 29 -- 将指定数据库中的表名称与排序号,装入临时表中(效率很高) 30 SELECT ROW_NUMBER() OVER(ORDER BY NAME) AS rowNumber, [name] 31 INTO #TempTable 32 FROM sys.objects 33 WHERE [type] = 'U' 34 35 WHILE @i <= @tableCount 36 BEGIN 37 -- 循环计算每个表的名称 38 SELECT @tableName = [name] 39 FROM #TempTable 40 WHERE rowNumber = @i; 41 42 -- 拼接sql语句,用于统计表中的记录数 43 SET @sql = ' SELECT @num = COUNT(*) FROM [' + @tableName + ']'; 44 EXEC sp_executesql @sql,N'@num int output',@rowCount OUTPUT -- 执行查询 45 46 -- select @rowCount 47 48 IF @rowCount = 0 49 BEGIN 50 SET @tableNamesWithoutDataCount = @tableNamesWithoutDataCount + 1; -- 无记录表计数器 + 1 51 IF @tableNamesWithoutData = '' 52 BEGIN 53 SET @tableNamesWithoutData = @tableName 54 END 55 ELSE 56 BEGIN 57 SET @tableNamesWithoutData = @tableNamesWithoutData + '、' + @tableName 58 END 59 END 60 61 SET @i = @i + 1; -- 计数加1 62 SET @rowCount = 0; -- 设置为0,下次重新计算 63 SET @tableName = ''; -- 清空,下次重新计算 64 SET @sql = ''; -- 清空,下次重新计算 65 END 66 67 SELECT @tableNamesWithoutDataCount; -- 输出无记录表的总数量 68 SELECT @tableNamesWithoutData; -- 输出无记录表的名称
打开SQL 查询分析器,将上述脚本拷贝后运行,结果如下:
第一个查询结果,代表无记录数的表的总数量为652个;
第二个查询结果,代表无记录数的表的名称的字符串,中间用分号分割。
成在管理,败在经验;嬴在选择,输在不学! 贵在坚持!
个人作品
BIMFace.SDK.NET
开源地址:https://gitee.com/NAlps/BIMFace.SDK
系列博客:https://www.cnblogs.com/SavionZhang/p/11424431.html
系列视频:https://www.cnblogs.com/SavionZhang/p/14258393.html
技术栈
1、AI、DeepSeek、MiniMax、通义千问
2、Visual Studio、.NET Core/.NET、MVC、Web API、RESTful API、gRPC、SignalR、Java、Python
3、jQuery、Vue.js、Bootstrap、ElementUI
4、数据库:分库分表、读写分离、SQLServer、MySQL、PostgreSQL、Redis、MongoDB、ElasticSearch、达梦DM、GaussDB、OpenGauss
5、架构:DDD、ABP、SpringBoot、jFinal
6、环境:跨平台、Windows、Linux
7、移动App:Android、IOS、HarmonyOS、微信小程序、钉钉、uni-app、MAUI
8、分布式、高并发、云原生、微服务、Docker、CI/CD、DevOps、K8S;Dapr、RabbitMQ、Kafka、RPC、Elasticsearch
欢迎关注作者头条号 张传宁IT讲堂,获取更多IT文章、视频等优质内容。
出处:www.cnblogs.com/SavionZhang
作者:张传宁 技术顾问、培训讲师、微软MCP、系统架构设计师、系统集成项目管理工程师、科技部创新工程师。
专注于企业级通用开发平台、工作流引擎、自动化项目(代码)生成器、SOA 、DDD、 云原生(Docker、微服务、DevOps、CI/CD);PDF、CAD、BIM 审图等研究与应用。
多次参与电子政务、图书教育、生产制造等企业级大型项目研发与管理工作。
熟悉中小企业软件开发过程:可行调研、需求分析、架构设计、编码测试、实施部署、项目管理。通过技术与管理帮助中小企业实现互联网转型升级全流程解决方案。
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
如有问题,可以通过邮件905442693@qq.com联系。共同交流、互相学习。
如果您觉得文章对您有帮助,请点击文章右下角【推荐】。您的鼓励是作者持续创作的最大动力!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?