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、真诚希望

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

mysql 字段判断是否存在_mysql 新增字段时判断字段是否存在相关推荐

  1. mysql创建表的时候日期给个默认值_mysql 创建表时 日期字段默认值为当前时间...

    mysql 创建表时 日期字段默认值为当前时间 mysql version 5.1 在mysql创建表的时候经常会遇到创建日期字段需要设置当前时间为默认值的时候,就如sqlserver2000一样,把 ...

  2. mysql日期条件如何应用_MySQL如何使用时间作为判断条件

    背景:在开发过程中,我们经常需要根据时间作为判断条件来查询数据,例如:当月,当日,当前小时,几天内...... 1. 当月 我们只需要使用一个mysql的month(date)函数即可实现.(注意判断 ...

  3. mysql联合索引顺序调整_MySQL 关于联合索引的字段顺序规则讨论

    联合索引的顺序,难道不是哪个查询条件最多用就放在前面的吗? 比如商品有三个分类A,B,C,类似「界门纲目科属种」那样,越左类别越大.还有一个是商品来源D,不一定会用于查询条件中. 举个例子,A代表衣服 ...

  4. mysql中数据发生变化时判断_MySql插入记录时判断

    我们在开发数据库相关的逻辑过程中, 经常检查表中是否已经存在这样的一条记录, 如果存在则更新或者不做操作, 如果没有存在记录,则需要插入一条新的记录. 这样的逻辑固然可以通过两条sql语句完成. SE ...

  5. mysql 判断 字母大写_MySQL中查询时对字母大小写的区分

    我相信很多人在mysql中查询时都遇到过mysql不区分字母大小写的情况:如以下例子: 1.SELECT * FROM `user` WHERE userpass = 'Z20'; 结果为: 2.SE ...

  6. mysql 5.6 删除用户_mysql 新增 删除用户和权限分配

    1. 新增用户 mysql>insert into mysql.user(Host,User,Password) values("localhost","lionb ...

  7. mysql 建表 日期格式_MySQL建表时,日期时间类型选择

    MySQL(5.5)所支持的日期时间类型有:DATETIME. TIMESTAMP.DATE.TIME.YEAR. 几种类型比较如下: 日期时间类型 占用空间 日期格式 最小值 最大值 零值表示 DA ...

  8. mysql通过参数文件启动_mysql启动的时参数文件中的[mysql]下的参数没有生效

    my.cnf下的参数如下 [mysqld] 此处省略..... [mysql] #no-auto-rehash prompt='\u@\h:\p\d mysql>' #max_allowed_p ...

  9. mysql主从同步 忽略表_mysql 主从同步时忽略指定的表

    生产环境中mysql主从库同步停止了,不能停服务,在重新开启同步的时候报了错误 Could not execute Update_rows event on table [db_name].[tabl ...

最新文章

  1. 20145231 《信息安全系统设计基础》第11周学习总结
  2. HttpWebRequest在GetResponse时总是超时
  3. 异常 java.lang.NumberFormatException: For input string:
  4. springMVC笔记day01
  5. ural1147 Shaping Regions
  6. 数据结构——二叉树的非递归算法
  7. bzoj 4009 接水果 整体二分
  8. Leetcode 771. Jewels and Stones
  9. 局域网在线监控设备扫描工具V1.0软件说明
  10. QLive EULA
  11. php下拉列表框 是隐藏变色的代码,jQuery设置下拉框显示与隐藏效果的方法分析...
  12. python蓝桥杯跑步训练
  13. java上下文_Java,gRPC和上下文传播(Java, gRPC and Context propagation)
  14. 君则A3服务器地址异常信息,a3服务器端操作指南.doc
  15. ExcelVBA之InputBox方法
  16. The YARN Timeline Service v.2
  17. 全球与中国大麻化妆品市场深度研究分析报告
  18. 【计科二班】编程测试题解
  19. 网易云音乐用户信息爬取以及可视化
  20. MySQL——————表的查询

热门文章

  1. Java注解之Retention、Documented、Target介绍
  2. 转: X-UA-Compatible content=IE=7 的意思
  3. 【小米澎湃 S1 芯片、小米5c 发布】
  4. 2020最后 6h 的年度总结
  5. shell字符串转数组
  6. 淘宝提高“猜你喜欢”的权重
  7. HTML img onerror的应用
  8. 关于子网掩码(Netmask)
  9. 人脸表情识别系统介绍——离线环境配置篇
  10. switch简易计算器