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

1、问题引出

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

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

 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执行时总出现错误,纳闷啊............................


2、问题分析

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


3、问题解决

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

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

// 调用存储过程

CALL Temp_Alter_Table_T_Subject_20160411()

// 删除存储过程

DROP PROCEDURE Temp_Alter_Table_T_Subject_20160411;


4、真诚希望

希望有更好的方式,否则这个太变态了,我是不是还要写一个函数,来判断这个存储过程是否已经存在了,我去太复杂了,真诚希望有更好的方式,可以留言!



你可能感兴趣的:(新增字段时判断字段是否存在)