帮我看看如何实现这个需求

Airroll 2008-08-22 09:56:21
求助一个存储过程的写法


我有个需求
就是首先要
遍历所有实例拥有的database
执行select count(1) from sysobjects where xtype='U'
如果返回值大于0就把dbname显示出来


简单说就是判断当前实例是否存在空库


以下是我写的procedure

create procedure IF_NULL_DATABASE
as
declare @db_name varchar(20)
declare @sql_body varchar(200)
declare @cnt int
set @cnt=0
declare cur_name cursor for select name from sys.sysdatabases for read only
open cur_name ;
fetch next from cur_name into @db_name ;
while @@FETCH_STATUS = 0
begin
exec('use ' + @db_name) exec ('select count(1) from sysobjects where xtype ='U'')
print @db_name
print @cnt
Fetch From cur_name into @db_name;
if @cnt = 0
begin
insert into tmp_db_name(name) values (@db_name)
end
end
close cur_name
deallocate cur_name

但是抛出
Msg 102, Level 15, State 1, Procedure IF_NULL_DATABASE, Line 13
Incorrect syntax near 'U'.

大家给点意见吧
...全文
120 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
Airroll 2008-08-22
  • 打赏
  • 举报
回复
谢谢
我已解决~
netcup 2008-08-22
  • 打赏
  • 举报
回复
有个存储过程好像可以遍历数据库,好像是sp_geteachdb,还有个遍历数据库中的所有表的过程,和这个有点像。这个在联机帮助中没有。记不太清了,你可以试下或者BAIDU下。
cqq 2008-08-22
  • 打赏
  • 举报
回复
这个只能在 master库执行吧, 也就是说只能 use master吧
Airroll 2008-08-22
  • 打赏
  • 举报
回复
这个转义字符的问题我晓得了

谢谢


但是select @cnt=count(1) from sysobjects where xtype ='U'的结果每次都一样,我想是因为前面use ***这条的缘故
大家给点意见吧
cqq 2008-08-22
  • 打赏
  • 举报
回复
exec ('select count(1) from sysobjects where xtype ='U'')
一个单引号用两个单引号替换

exec ('select count(1) from sysobjects where xtype =''U''')
内容概要:本文档介绍了一个基于MATLAB/Simulink平台的综合性科研资源共享项目,核心内容为四旋翼无人机俯仰姿态保持的模糊自整定PID控制系统设计与仿真,提供完整的Matlab代码和Simulink仿真实现资源。项目进一步拓展至无人机轨迹跟踪、多控制策略对比(如线性MPC、非线性NMPC、强化学习RL及混合MPC-RL)、储能优化、电力系统调度、路径规划、神经网络预测等多个前沿科研方向。文档强调科研不仅需要严谨思维与勤奋,更要善于“借力”,通过成熟案例启发创新思路,助研究者避免误区,利用高质量资源激发科研灵感,加速高水平成果的复现与产出。; 适合人群:具备一定MATLAB编程基础,从事自动化、控制工程、电力系统、机器人或人工智能等相关领域的科研人员、研究生及工程师,尤其适合希望快速复现高水平论文成果的研究者。; 使用场景及目标:① 实现模糊PID控制在无人机姿态控制中的应用与仿真;② 对比分析不同先进控制策略(如MPC、RL)在轨迹跟踪中的性能表现;③ 借助提供的代码与模型,完成科研项目中的仿真验证、论文复现或算法优化任务。; 阅读建议:建议读者按照资源目录顺序逐步学习,优先掌握核心控制方法(如模糊PID、MPC)的实现逻辑,结合代码与仿真模型进行调试与改进,从而深化对控制理论的理解并推动自身科研工作的创新。
内容概要:本文档围绕“2023年IEEE ICMA顶刊复现多欠驱动水面无人艇误差约束协同路径跟踪控制(Matlab代码实现)”展开,详细介绍了一项针对多欠驱动水面无人艇的协同路径跟踪控制技术的研究与实现。该研究通过引入误差约束机制,旨在提升无人艇在复杂海洋环境下的路径跟踪精度与系统稳定性。文档不仅提供了完整的Matlab代码实现,还涵盖了控制算法的设计原理、数学建模过程以及仿真实验结果分析。此外,文档还列举了多个相关科研方向,如智能优化算法、机器学习、路径规划、无人机控制、电力系统优化等,展示了其在多学科交叉领域的广泛应用前景,并倡导科研工作者善用工具资源,提升研究效率。; 适合人群:具备一定编程基础,尤其是熟练掌握Matlab/Simulink环境的科研人员、工程师,以及对无人艇控制、路径跟踪、协同控制、非线性系统控制等领域感兴趣的研究生和高校学者。; 使用场景及目标:① 开展多欠驱动水面无人艇的协同路径跟踪控制研究;② 设计与实现具有误差约束的先进控制算法;③ 利用Matlab进行控制系统建模、仿真与性能验证;④ 探索将智能优化算法与现代控制理论相结合,解决复杂工程系统中的实际控制问题。; 阅读建议:建议读者按照文档的逻辑顺序系统学习,重点理解控制算法的设计思路与数学推导过程,并结合所提供的Matlab代码进行动手实践与仿真调试,以深化对理论知识的掌握。同时,鼓励读者积极查阅相关领域的最新文献,紧跟学术前沿,不断拓展研究视野,激发创新灵感。

34,876

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧