怎么判断列在表中是否存在啊 

解决方案 »

  1.   

    --判断数据库是否存在
    if exists(select * from master..sysdatabases where name=N'库名')
      print 'exists'
    else
      print 'not exists'---------------
    -- 判断要创建的表名是否存在
    if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[表名]') and OBJECTPROPERTY(id, N'IsUserTable') = 1)
    -- 删除表
    drop table [dbo].[表名]
    GO---------------
    --判断要创建临时表是否存在
    If Object_Id('Tempdb.dbo.#Test') Is Not Null
        Begin
          print '存在'
        End
    Else
        Begin
          print '不存在'
        End---------------
    -- 判断要创建的存储过程名是否存在
    if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[存储过程名]') and OBJECTPROPERTY(id, N'IsProcedure') = 1)
    -- 删除存储过程
    drop procedure [dbo].[存储过程名]
    GO---------------
    -- 判断要创建的视图名是否存在
    if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[视图名]') and OBJECTPROPERTY(id, N'IsView') = 1)
    -- 删除视图
    drop view [dbo].[视图名]
    GO---------------
    -- 判断要创建的函数名是否存在
    if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[函数名]') and xtype in (N'FN', N'IF', N'TF'))
    -- 删除函数
    drop function [dbo].[函数名]
    GO
      

  2.   

    select o.name as 表名,c.name as 列名
    from sysobjects o inner join syscolumns c on o.id=c.id
    where o.name='表名'  and c.name ='列名'
      

  3.   

    if col_length('表名', '列名') is null
      print '不存在'
      

  4.   


    if col_length('部门', '级别') is null
        print '不存在'
    ------------------
    简洁!!!
      

  5.   

    select 1 from sysobjects where id in (select id from syscolumns where name='列名') and name='表名'
      

  6.   

    可以访问syscolumns系统表,不过用col_length函数也可以解决//