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