摘要:
下文讲述sqlserver中,更新脚本中常用if exists关键字的用法说明,如下所示:
实验环境:sql server 2008 R2


一、检测数据库是否存在于当前数据库引擎下

if exists (select * from sys.databases where name = ’数据库名称’)
begin
print '数据库名称--存在'
end

二、检测数据表是否存在于指定数据库下

 if exists (select * from sysobjects where id = object_id(N’[数据表名称]’) and OBJECTPROPERTY(id, N’IsUserTable’) = 1)
begin
print '数据表名称---存在'
end

三、检测存储过程是否存在的方法

 

if exists (select * from sysobjects where id = object_id(N’[存储过程名称]’) and OBJECTPROPERTY(id, N’IsProcedure’) = 1)
begin
print '存储过程名称-存在'
end

四、临时表是否存在的方法

if object_id(’tempdb..#临时表名’) is not null
begin
print '临时表名--存在'
end

五、视图是否存在的方法

 IF EXISTS (SELECT * FROM sys.views WHERE object_id = ’[dbo].[视图名称]’
begin
print '视图名称存在'
end

六、函数是否存在的检测方法

if exists (select * from dbo.sysobjects where id = object_id(N’[dbo].[函数名称]’) and xtype in (N’FN’, N’IF’, N’TF’))
begin
print '函数名称--存在'
end

七、获取用户自定义对象信息

 

SELECT [name] as [对象名称],
[id] as [对象编号],
crdate as [对象创建时间]
FROM sysobjects
where xtype=’U’
/*
xtype 参数类型,可输以下值
C = CHECK 约束
D = 默认值或 DEFAULT 约束
F = FOREIGN KEY 约束
L = 日志
FN = 标量函数
IF = 内嵌表函数
P = 存储过程
PK = PRIMARY KEY 约束(类型是 K)
RF = 复制筛选存储过程
S = 系统表
TF = 表函数
TR = 触发器
U = 用户表
UQ = UNIQUE 约束(类型是 K)
V = 视图
X = 扩展存储过程
*/

八、检测数据列是否存在的方法

if exists(select * from syscolumns where id=object_id(’数据表名称’) and name=’数据列’)
begin
print '数据列---存在'
end

九、是否为自增列检测

if columnproperty(object_id(’table’),’列名’,’IsIdentity’)=1
begin
print 'table下“列名”为自增列'
end

十、检测数据表中是否存在索引

if columnproperty(object_id(’table’),’列名’,’IsIdentity’)=1
begin
print 'table下“列名”为自增列'
end

 转自:http://www.maomao365.com/?p=9094

最新文章

  1. 一个js简单的日历显示效果的函数
  2. 《C++primer》v5 第7章 类 读书笔记 习题答案
  3. 浅谈JavaScript中的变量、参数、作用域和作用域链
  4. gspx请求周期(备忘)
  5. app设计需注意的
  6. Scrum项目1.0
  7. Linux 下,mysql数据库报无法登陆错误:ERROR 1045 (28000): Access denied for use
  8. java面试每日一题11
  9. MapHttpRoute
  10. POJ1008Maya Calendar
  11. nutch 1.7 导入 eclipse
  12. DB2错误代码
  13. Java基本数据类型的长度范围
  14. myeclipse中修改maven的默认仓库位置
  15. 【转】Android开发:Service和Thread的关系
  16. [Linux.NET]Nginx 泛解析配置请求映射到多端口实现二级域名访问
  17. 绝对精品推荐做前端的看下:Web前端开发体会十日谈
  18. iOS系统及客户端软件测试的基础介绍
  19. gcc/g++多版本切换 (ubuntu18.04)
  20. 60.自己定义View练习(五)高仿小米时钟 - 使用Camera和Matrix实现3D效果

热门文章

  1. 网络编程~~~ socket(套字节)
  2. 201871010116-祁英红《面向对象程序设计(java)》第一周学习总结
  3. python第二次作业-titanic数据库练习
  4. python logging模块“另一个程序正在使用此文件,进程无法访问。”问题解决办法
  5. linux编程fcntl获取和设置文件状态
  6. angular6 multipart/form-data Post
  7. Java连载52-单例模式的缺点以及抽象类
  8. DFS(四):剪枝策略
  9. 融云技术分享:解密融云IM产品的聊天消息ID生成策略
  10. Flink JobManager 和 TaskManager 原理