SQL Server判断对象是否存在   
1 判断数据库是否存在 Sql代码  
if exists (select * from sys.databases where name = '数据库名')     drop database [数据库名]   
2 判断表是否存在 Sql代码  
if exists (select * from sysobjects where id = object_id('表名') and objectproperty(id,'IsUserTable') = 1) drop table [表名]  
if exists (select * from sysobjects where name = '表名' and xtype = 'U') drop table [表名]   
3 判断存储过程是否存在 Sql代码  
if exists (select * from sysobjects where id = object_id('[存储过程名]') and objectproperty(id, 'IsProcedure') = 1) drop procedure [存储过程名]   
if exists (select 1 from sysobjects where name = '存储过程名' and xtype = 'P')  drop procedure [存储过程名]  
4 判断临时表是否存在 Sql代码  
if object_id('tempdb..#临时表名') is not null       drop table #临时表名   
5 判断视图是否存在 Sql代码  
--SQL Server 2000    
IF EXISTS (SELECT * FROM sysviews WHERE object_id = '[dbo].[视图名]')    
--SQL Server 2005    
IF EXISTS (SELECT * FROM sys.views WHERE object_id = '[dbo].[视图名]')   
6 判断函数是否存在 Sql代码  
--  判断要创建的函数名是否存在   
  if exists (select * from dbo.sysobjects where id = object_id('[dbo].[函数名]') and xtype in ('FN', 'IF', 'TF'))

wk_ad_begin({pid : 21});wk_ad_after(21, function(){$('.ad-hidden').hide();}, function(){$('.ad-hidden').show();});

drop function [dbo].[函数名]  
  if exists (select 1 from sysobjects where name = '函数名' and xtype in('FN','IF','TF'))   drop function [函数名]    
7 获取用户创建的对象信息  Sql代码  
SELECT 1 FROM sysobjects where name = [对象名] and xtype=''   /*   
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 = 扩展存储过程   */   
8 判断列是否存在 Sql代码  
if exists(select * from syscolumns where id=object_id('表名') and name='列名')     alter table 表名 drop column 列名     
9 判断列是否自增列 Sql代码  
if columnproperty(object_id('table'),'col','IsIdentity')=1     print '自增列'   else   
  print '不是自增列'    
SELECT * FROM syscolumns WHERE object_id=OBJECT_ID('表名')   AND is_identity=1

10 判断表中是否存在索引 Sql代码  
if exists(select * from sysindexes where id=object_id('表名') and name='索引名')       print  '存在'     else     
  print  '不存在'    
11 查看数据库中对象 Sql代码  
SELECT * FROM sys.sysobjects WHERE name='对象名'  
12 查看表中主键是否存在,如存在则将其drop掉 declare @pk varchar(100) 
select @pk=name from sysobjects where parent_obj=object_id('表名') and xtype='PK' if @pk is not null 
exec('alter table 表名 drop '+ @pk)

检查sql对象是否存在的更多相关文章

  1. 解决 U2000 R017 安装报错: 检查SQL server数据库环境变量信息 ( 异常 ) [ 详细信息 ] PATH环境变量中缺少数据库路径的信息

    U2000 R017 安装报错: 检查SQL server数据库环境变量信息 ( 异常 ) [ 详细信息 ] PATH环境变量中缺少数据库路径的信息 管理员模式打开注册表位置: HKEY_LOCAL_ ...

  2. JavaScript检查Date对象是否为Invalid Date

    使用Date()构造日期对象,如果传入非日期格式的字符串,仍然能构造出Date对象. 在chrome控制台 >var date = new Date("hello"); &g ...

  3. jQuery:使用$获取对象后检查该对象是否存在

    注意: 1)即使jQ获取到网页中不存在的元素也不会报错 2)使用$("#tt")形式获取到的永远是对象,即使网页上没有此元素 jQuery检查某个元素在网页上是否存在时,不能使用以 ...

  4. 使用MySQL中的EXPLAIN解释命令来检查SQL

    我们看到许多客户的系统因为SQL及数据库设计的很差所以导致许多性能上的问题,这些问题不好解决,但是可以采用一套简单的策略来检查生产系统,发现并纠正一些共性问题. 很显然,您应该尽最大努力设计出最好的数 ...

  5. 检查SQL语句是否合法

    昨天又有一个新的需求:验证文本框输入的SQL语法是否正确. 于是就开始百度,其实也挺简单的. 首先需要知道“SET PARSEONLY { ON | OFF }”. 当 SET PARSEONLY 为 ...

  6. inspect模块---检查活动对象

    inspect模块提供了一些有用的函数来帮助获取有关活动对象(如模块,类,方法,函数,跟踪,框架对象和代码对象)的信息.例如,它可以帮助您检查类的内容,检索方法的源代码,提取和格式化函数的参数列表,或 ...

  7. Mybatis检查SQL注入

    Mybatis 的 Mapper.xml 语句中 parameterType 向SQL语句传参有两种方式:#{ } 和 ${ }. 使用#{ }是来防止SQL注入,使用${ }是用来动态拼接参数. 如 ...

  8. 检查sql执行效率

    SELECT  SUBSTRING(ST.text, ( QS.statement_start_offset / 2 ) + 1,                    ( ( CASE statem ...

  9. 快速检查SQL两表数据是否一致

    1前话 项目内实现了一新功能:克隆数据库. 2目标 克隆并非用SQLSERVER克隆,故完毕后需要检查各表内一些数据与原表一致性.一些表中的某一些列容许不一致. 3实现 将两表的需要检查的几列取出,相 ...

随机推荐

  1. Overview of MIDI

    东拼西凑的介绍 MIDI which means Musical Instrument Digital Interface, introduced in 1980's provided a inter ...

  2. WordPress xmlrpc.php flaw exploited to install a WSO 2.1 Web Shell by oRb

    WordPress xmlrpc.php flaw exploited to install a “WSO 2.1 Web Shell by oRb” Below you can see in the ...

  3. window切换Java版本原因

    查找Path环境变量的变量指向的目录,有一个Oracle目录存放着几个 java,javac等可执行文件,删除这个路径或文件就可以执行你指定的JavaHome目录拉 详情参考: https://blo ...

  4. 软件项目功能测试框架(转载自51Testing软件测试)

    测试用例的编写需要按照一定的思路进行,而不是想到哪写到哪,一般测试机制成熟的公司都会有公司自己自定义的测试用例模板,以及一整套的测试流程关注点,当然我们自己在测试生涯中也应当积累一套自己的测试框架,所 ...

  5. zoj 2760 How Many Shortest Path【最大流】

    不重叠最短路计数. 先弗洛伊德求一遍两两距离(其实spfa或者迪杰斯特拉会更快但是没必要懒得写),然后设dis为st最短距离,把满足a[s][u]+b[u][v]+a[v][t]==dis的边(u,v ...

  6. [App Store Connect帮助]八、维护您的 App(1)App 维护概述

    您在 App Store 上发行 App 后,需要执行一些任务来回复顾客反馈并在整个产品周期内维护您的 App.您可以按任何顺序执行这些任务. 监控顾客评论.销售情况和分析 您可以在 App 页面的“ ...

  7. Word Cloud (词云) - Matlab

    今天要总结的是 Word Cloud 最后一个部分了,用 Matlab 来创建 word cloud.Matlab R2018b 已经提供 wordcloud 函数可以直接生成词云了. >> ...

  8. 校赛F 比比谁更快(线段树)

    http://acm.cug.edu.cn/JudgeOnline/problem.php?cid=1153&pid=5 题意:给你一个字符串,各两个操作: ch=0,[l,r]降序 ch=1 ...

  9. Tree Recovery POJ - 2255

    Tree Recovery POJ - 2255 根据树的前序遍历和中序遍历还原后序遍历. (偷懒用了stl的find) #include<iostream> #include<st ...

  10. 字符串处理 Codeforces Round #285 (Div. 2) B. Misha and Changing Handles

    题目传送门 /* 题意:给出一系列名字变化,问最后初始的名字变成了什么 字符串处理:每一次输入到之前的找相印的名字,若没有,则是初始的,pos[m] 数组记录初始位置 在每一次更新时都把初始pos加上 ...