Sql Server中判断表或者数据库是否存在

本文介绍如何在SQL Server中检查数据库、表、字段、存储过程及视图等对象是否存在,并提供了具体的T-SQL代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

法(一):

 

    select * From master.dbo.sysdatabases where name='数据库名'

  法(二):
    if db_id('数据库名') is not null

      drop database 。。。
      go

    create 。。。

 SQL Server中判断表对象是否存在:
  select count(*) from sysobjects where id = object_id('数据库名.Owner.表名')

  if exists 

      (select count(*) from sysobjects where id = object_id('数据库名.Owner.表名'))
    print '存在'
  else
    print '不存在'

SQL Server中判断表中字段是否存在:
  if exists

      (select * from syscolumns where name='colname1' and id=object_id('数据库名.Owner.表名'))
    print '存在'
  else
    print '不存在'
 (代表表tablename1中存在colname1字段 )
例:
  select * from syscolumns where name='Test' and id=object_id('dbo.test')

 

SQL Server中判断存储过程或视图是否存在:

   if object_id('视图或存储过程名')  is not null
     drop proc/view 。。。
   go

   create proc/view  。。。

 

  或

 

  if Exists(select * from sysobjects where name='视图或存储过程名'  AND  type  =  'P/V')
     drop proc/view  。。。
  go  

  create proc/view  。。。 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值