服务器之家

服务器之家 > 正文

mssql和sqlite中关于if not exists 的写法

时间:2020-03-23 15:07     来源/作者:MSSQL教程网

在sql语名中,if not exists 即如果不存在,if exists 即如果存在。

下面学习下二者的用法。

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同理判断,首先判断查询结果是否存在,如果存在执行判断后面的语句,查询的数据库,表,列的方法相同;

mssql语法:

 

复制代码 代码如下:

if not exists (SELECT 1 FROM [t_Table] where [fName] = '张三')
insert into [t_Table] ([fName]) values ('张三');

 

sqlite语法:

 

复制代码 代码如下:

insert into [t_Table] ([fName]) select '张三'
where not exists (SELECT 1 FROM [t_Table] where [fName] = '张三');

 

标签:

相关文章

热门资讯

沙雕群名称大全2019精选 今年最火的微信群名沙雕有创意
沙雕群名称大全2019精选 今年最火的微信群名沙雕有创意 2019-07-07
玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分
玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分 2019-06-21
男生常说24816是什么意思?女生说13579是什么意思?
男生常说24816是什么意思?女生说13579是什么意思? 2019-09-17
超A是什么意思 你好a表达的是什么
超A是什么意思 你好a表达的是什么 2019-06-06
华为nova5pro和p30pro哪个好 华为nova5pro和华为p30pro对比详情
华为nova5pro和p30pro哪个好 华为nova5pro和华为p30pro对比详情 2019-06-22
返回顶部