sql-server – 如何从不同的sql db检查表的存在?
发布时间:2020-12-12 08:55:27 所属栏目:MsSql教程 来源:网络整理
导读:我有db A和db B.在存储过程的开头我想备份从B.mytable到B.mytablebackup的所有行.存储过程的其余部分针对db A上的表运行(它收集数据并将其写入B.mytable). 所以我检查一下B.mytablebackup是否存在 IF EXISTS(SELECT 1 FROM B.dbo.mytablebackup) 如果是,则存
我有db A和db B.在存储过程的开头我想备份从B.mytable到B.mytablebackup的所有行.存储过程的其余部分针对db A上的表运行(它收集数据并将其写入B.mytable).
所以我检查一下B.mytablebackup是否存在 IF EXISTS(SELECT 1 FROM B.dbo.mytablebackup) 如果是,则存储过程执行 INSERT INTO B..mytablebackup SELECT * FROM B..mytable 如果它不存在它会做 SELECT * INTO B..mytablebackup from B..mytable 但是当我执行存储过程时,我得到了错误
我添加了一个Print语句,执行正在采用IF的“不存在”分支. 我究竟做错了什么? 解决方法对于SQL Server,您应该使用系统视图sys.tables来检查表是否存在.IF EXISTS(SELECT 1 FROM B.sys.tables WHERE name = 'mytablebackup') (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
推荐文章
站长推荐
- sql – 不明白错误信息:必须声明标量变量“@Use
- sql – 如何获取一个WPF DataGrid保存更改回到数
- tsql – 将表变量传递给动态SQL 2008
- SQL Server 高性能写入的一些经验总结
- SQLServer2005中实现分页查询数据
- The service did not start due to a logon fail
- sql-server – 在使用带有pandas和sqlalchemy的p
- 隐藏在SQL Server字段中的超诡异字符解决过程
- 数据库 – migrator.net vs fluentmigrator vs m
- 关于SQLServer2000中触发器的使用——多行数据提
热点阅读