SQL server 判断表中是否有字段

由于不能保证所有环境中的 kuout 表都包含 [Mtype] 字段,我们需要动态判断该字段是否存在 ,如果存在就包含它,否则用 NULL 或默认值代替。


✅ 推荐解决方案:使用动态 SQL + 信息架构(INFORMATION_SCHEMA)

你可以修改你的 SQL 脚本,在构建 @Sql44 之前,先检查 @DatabaseName.dbo.kuout 是否包含 [Mtype] 字段,然后动态生成 SELECT 列表。

复制代码
BEGIN TRY

	    DECLARE @HasMtype BIT = 0
		DECLARE @CheckSql NVARCHAR(MAX)

		-- 构建动态 SQL 检查字段是否存在
		SET @CheckSql = N'
			IF EXISTS (
				SELECT 1 
				FROM ' + QUOTENAME(@DatabaseName) + N'.INFORMATION_SCHEMA.COLUMNS 
				WHERE TABLE_SCHEMA = N''dbo'' 
				  AND TABLE_NAME = N''kuout'' 
				  AND COLUMN_NAME = N''Mtype''
			)
			BEGIN
				SET @HasMtypeOUT = 1
			END
			ELSE
			BEGIN
				SET @HasMtypeOUT = 0
			END
		'

		-- 执行动态 SQL 并获取输出参数
		EXEC sp_executesql 
			@CheckSql, 
			N'@HasMtypeOUT BIT OUTPUT', 
			@HasMtypeOUT = @HasMtype OUTPUT  

        DECLARE @Sql44 NVARCHAR(MAX)
		IF @HasMtype = 1
			SET @Sql44 = N'
			INSERT INTO dbo.ods_kuout_ext ([ord],[title],[ckbh],[ck],[date3],[date5],[intro],[complete1],[fh1],[order1],[intro2],[cateid],[cateid2],[cateid3],[del],[cateout],[delcate],[deldate],[date7],[kg],[kgs],[sort1],[IsMinusKuout],[zdy1],[zdy2],[zdy3],[zdy4],[zdy5],[zdy6],[source],[fromid],[status],[QualityType],[QualityUsers],[FactQualityUsers],[QualityResult],[QualityDate],[AddQualityDate],[AddQualityUser],[QualityRemark],[ModifyStamp],[alt],[receiver],[phone],[mobile],[address],[zip],[areaId],[kuout],[IsHC],[IsWeight],[CarNum],[IsTempSave],[Mtype],[dt])
            SELECT [ord]
			,[title]
			,[ckbh]
			,[ck]
			,[date3]
			,[date5]
			,[intro]
			,[complete1]
			,[fh1]
			,[order1]
			,[intro2]
			,[cateid]
			,[cateid2]
			,[cateid3]
			,[del]
			,[cateout]
			,[delcate]
			,[deldate]
			,[date7]
			,[kg]
			,[kgs]
			,[sort1]
			,[IsMinusKuout]
			,[zdy1]
			,[zdy2]
			,[zdy3]
			,[zdy4]
			,[zdy5]
			,[zdy6]
			,[source]
			,[fromid]
			,[status]
			,[QualityType]
			,[QualityUsers]
			,[FactQualityUsers]
			,[QualityResult]
			,[QualityDate]
			,[AddQualityDate]
			,[AddQualityUser]
			,[QualityRemark]
			,[ModifyStamp]
			,[alt]
			,[receiver]
			,[phone]
			,[mobile]
			,[address]
			,[zip]
			,[areaId]
			,[kuout]
			,[IsHC]
			,[IsWeight]
			,[CarNum]
			,[IsTempSave]
			,[Mtype]
			,' + QUOTENAME(CONVERT(NVARCHAR(10), @DateThreshold, 120), '''') + N'as dt FROM' + QUOTENAME(@DatabaseName) + N'.[dbo].[kuout]'
		ELSE
			SET @Sql44 = N'
			INSERT INTO dbo.ods_kuout_ext ([ord],[title],[ckbh],[ck],[date3],[date5],[intro],[complete1],[fh1],[order1],[intro2],[cateid],[cateid2],[cateid3],[del],[cateout],[delcate],[deldate],[date7],[kg],[kgs],[sort1],[IsMinusKuout],[zdy1],[zdy2],[zdy3],[zdy4],[zdy5],[zdy6],[source],[fromid],[status],[QualityType],[QualityUsers],[FactQualityUsers],[QualityResult],[QualityDate],[AddQualityDate],[AddQualityUser],[QualityRemark],[ModifyStamp],[alt],[receiver],[phone],[mobile],[address],[zip],[areaId],[kuout],[IsHC],[IsWeight],[CarNum],[IsTempSave],[dt])
            SELECT [ord]
			,[title]
			,[ckbh]
			,[ck]
			,[date3]
			,[date5]
			,[intro]
			,[complete1]
			,[fh1]
			,[order1]
			,[intro2]
			,[cateid]
			,[cateid2]
			,[cateid3]
			,[del]
			,[cateout]
			,[delcate]
			,[deldate]
			,[date7]
			,[kg]
			,[kgs]
			,[sort1]
			,[IsMinusKuout]
			,[zdy1]
			,[zdy2]
			,[zdy3]
			,[zdy4]
			,[zdy5]
			,[zdy6]
			,[source]
			,[fromid]
			,[status]
			,[QualityType]
			,[QualityUsers]
			,[FactQualityUsers]
			,[QualityResult]
			,[QualityDate]
			,[AddQualityDate]
			,[AddQualityUser]
			,[QualityRemark]
			,[ModifyStamp]
			,[alt]
			,[receiver]
			,[phone]
			,[mobile]
			,[address]
			,[zip]
			,[areaId]
			,[kuout]
			,[IsHC]
			,[IsWeight]
			,[CarNum]
			,[IsTempSave]
			,' + QUOTENAME(CONVERT(NVARCHAR(10), @DateThreshold, 120), '''') + N'as dt FROM' + QUOTENAME(@DatabaseName) + N'.[dbo].[kuout]'
        

		SET @Sql44 = REPLACE(@Sql44, '@DateThreshold', @DateThreshold)
		EXEC sp_executesql @Sql44

    END TRY


    BEGIN CATCH

        DECLARE @ErrorMessage44 NVARCHAR(4000)
        SET @ErrorMessage44 = ERROR_MESSAGE()

        RAISERROR (@ErrorMessage44, 16, 1)

    END CATCH
相关推荐
青槿吖3 天前
第二篇:Spring Boot进阶:整合异常处理、测试、多环境与日志,开发稳得一批!
java·spring boot·后端·spring·面试·sqlserver·状态模式
mr_LuoWei20094 天前
《电子档案编制系统》软件开源
sqlserver·工具·dll·文档·exe·多媒体处理
woshilys6 天前
sql server 修改字段not null到null
数据库·sqlserver
小李来了!9 天前
Oracle、MySQL、SQL server介绍及有何区别
数据库·mysql·oracle·sqlserver
Leon-Ning Liu11 天前
SQL Server在ldf文件误删的情况下恢复数据库
数据库·sqlserver
姜太小白12 天前
【SQLServer】SQL Server 2022 连接证书错误解决
网络·数据库·sqlserver
gaozhiyong081313 天前
SpringBoot连接多数据源MySQL、SqlServer等(MyBatisPlus测试)
spring boot·mysql·sqlserver
源远流长jerry16 天前
dpdk19.08编译问题解决方案
数据库·postgresql·sqlserver
全栈小516 天前
【数据库】Sql Server 安装教程,一键到底,沉浸式下载安装MSSQL和SSMS
数据库·sqlserver
Msshu12319 天前
多协议快充取电芯片 支持与主板MCU共用D+D-网络可取电可与电脑传输数据
elasticsearch·sqlserver·flink·rabbitmq·storm