IF NOT EXISTS和 IF EXISTS的区别

1.介绍
if not exists 即如果不存在,if exists 即如果存在

2.使用
a.判断数据库不存在时
if not exists(select * from sys.databases where name = ‘database_name’)

b.判断表不存在时
if not exists (select * from sysobjects where id = object_id(‘table_name’) and OBJECTPROPERTY(id, ’IsUserTable’) = 1)

c.判断列不存在

if not exists (select * from syscolumns where id=object_id(’table_name’) and name=’column_name’)
当判断的表不存时,我可以执行创建数据库,创建表,增加列,可以执行相应的SQL语句;

而if exists同理判断,首先判断查询结果是否存在,如果存在执行判断后面的语句,查询的数据库,表,列的方法相同由此可见,“IF EXISTS“可以避免删除不存在的数据库出现的MySQL错误信息。另外需要注意的是:使用DROP DATABASE 或DROP SCHEMA 语句会删除指定的整个数据库,该数据库中的所有表(包含其中的数据)也将永远删除。因此使用时需谨慎,以免错误删除。

猜你喜欢

转载自blog.csdn.net/yyp0304Devin/article/details/81429382
今日推荐