mysql 新增字段时判断字段是否存在

一、问题引出

为了保证数据的正确性,代码的健壮性,咱们必须对一些边界条件作一个判断,因此才会把修改表结构搞得如此复杂。mysql

mysql 新增字段时判断字段是否存在,原本是一个很小的问题,由于之前都是使用 postgreSql、sqlserver ,上来就 if not exist ,结果mysql并不吃这一套,看看这段代码:sql

 IF NOT EXISTS (
 SELECT 1 FROM INFORMATION_SCHEMA.COLUMNS 
 WHERE TABLE_NAME = 't_subject' 
 AND COLUMN_NAME = 'subject_status'
 )THEN 
 ALTER TABLE t_subject ADD COLUMN `subject_status` int(1) DEFAULT '0' COMMENT '0:未被引用;1:已被用';
 END IF;

在 navicat执行时总出现错误,纳闷啊............................函数


二、问题分析

网上查了不少,发现不能这样直接执行脚本,那就没办法了,变态的写法就是直接定义存储过程,而后执行存储过程,最后删除存储过程,看到这你是否是想呵呵了,不管怎样,这最终是一种解决方法sqlserver


三、问题解决

// 建立存储过程 名称定义 以temp开头意为临时的,Alter_Table_T_Subject 意为修改T_Subject,20160411 意为存储过程建立的日期post

CREATE PROCEDURE Temp_Alter_Table_T_Subject_20160411()
    BEGIN
        IF NOT EXISTS (SELECT 1 
                FROM INFORMATION_SCHEMA.COLUMNS 
                WHERE TABLE_NAME = 't_subject' 
                AND COLUMN_NAME = 'subject_status')
         THEN 
 ALTER TABLE t_subject ADD COLUMN `subject_status` int(1) DEFAULT '0' COMMENT '0:未引用;1:已被用';
         END IF;
    END

// 调用存储过程spa

CALL Temp_Alter_Table_T_Subject_20160411()

// 删除存储过程code

DROP PROCEDURE Temp_Alter_Table_T_Subject_20160411;


四、真诚但愿

但愿有更好的方式,不然这个太变态了,我是否是还要写一个函数,来判断这个存储过程是否已经存在了,我去太复杂了,真诚但愿有更好的方式,能够留言!server

相关文章
相关标签/搜索