失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > mysql判断字段是否存在不存在添加字段_mysql 新增字段时判断字段是否存在

mysql判断字段是否存在不存在添加字段_mysql 新增字段时判断字段是否存在

时间:2021-02-15 13:48:02

相关推荐

mysql判断字段是否存在不存在添加字段_mysql 新增字段时判断字段是否存在

1、问题引出

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

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

IFNOTEXISTS(

SELECT1FROMINFORMATION_SCHEMA.COLUMNS

WHERETABLE_NAME='t_subject'

ANDCOLUMN_NAME='subject_status'

)THEN

ALTERTABLEt_subjectADDCOLUMN`subject_status`int(1)DEFAULT'0'COMMENT'0:未被引用;1:已被用';

ENDIF;

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

2、问题分析

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

3、问题解决

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

CREATEPROCEDURETemp_Alter_Table_T_Subject_0411()

BEGIN

IFNOTEXISTS(SELECT1

FROMINFORMATION_SCHEMA.COLUMNS

WHERETABLE_NAME='t_subject'

ANDCOLUMN_NAME='subject_status')

THEN

ALTERTABLEt_subjectADDCOLUMN`subject_status`int(1)DEFAULT'0'COMMENT'0:未引用;1:已被用';

ENDIF;

END

// 调用存储过程

CALLTemp_Alter_Table_T_Subject_0411()

// 删除存储过程

DROPPROCEDURETemp_Alter_Table_T_Subject_0411;

4、真诚希望

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

如果觉得《mysql判断字段是否存在不存在添加字段_mysql 新增字段时判断字段是否存在》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。