表名为Scores。
执行以下操作是否正确?
IF EXISTS(SELECT *
FROM dbo.Scores)
DROP TABLE dbo.Scores
表名为Scores。
执行以下操作是否正确?
IF EXISTS(SELECT *
FROM dbo.Scores)
DROP TABLE dbo.Scores
当前回答
Or:
if exists (select * from sys.objects where name = 'Scores' and type = 'u')
drop table Scores
其他回答
SQL Server 2016及以上版本最好、最简单的版本是删除表(如果存在)[表名称]
Ex:
DROP TABLE IF EXISTS dbo.Scores
如果假设上面的方法不起作用,那么可以使用下面的方法
IF OBJECT_ID('dbo.Scores', 'u') IS NOT NULL
DROP TABLE dbo.Scores;
在SQL Server 2016(13.x)及更高版本中
DROP TABLE IF EXISTS dbo.Scores
在早期版本中
IF OBJECT_ID('dbo.Scores', 'U') IS NOT NULL
DROP TABLE dbo.Scores;
U是您的桌子类型
从SQL Server 2016,您可以使用
DROP TABLE IF EXISTS dbo.Scores
参考:DROP IF EXISTS-SQL Server 2016中的新事物
它将很快出现在SQL Azure数据库中。
我编写了一个小UDF,如果其参数是现有表的名称,则返回1,否则返回0:
CREATE FUNCTION [dbo].[Table_exists]
(
@TableName VARCHAR(200)
)
RETURNS BIT
AS
BEGIN
If Exists(select * from INFORMATION_SCHEMA.TABLES where TABLE_NAME = @TableName)
RETURN 1;
RETURN 0;
END
GO
要删除表User(如果存在),请按如下方式调用它:
IF [dbo].[Table_exists]('User') = 1 Drop table [User]
Or:
if exists (select * from sys.objects where name = 'Scores' and type = 'u')
drop table Scores