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插入记录时判断

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

  3. oracle 新增自增字段,SQL server、Oracle中拿到新增列时的自增字段值

    #region 增删改数据访问 /// ///增删改数据访问/// /// 语句 /// 参数 /// public static int EditData(string CommandText, O ...

  4. mysql 表中添加数据类型_MySQL数据表添加字段(三种方式)

    MySQL 数据表是由行和列构成的,通常把表的"列"称为字段(Field),把表的"行"称为记录(Record).随着业务的变化,可能需要在已有的表中添加新的字 ...

  5. mysql 长度为1 的空字符串_MYSQL,如果定义了一个字符串的字段,长度为255,那么当我添加一个空字符串数据时占用空间吗?...

    你的位置: 问答吧 -> PHP -> 问题详情 MYSQL,如果定义了一个字符串的字段,长度为255,那么当我添加一个空字符串数据时占用空间吗? MYSQL,如果定义了一个字符串的字段, ...

  6. 怎么在Mysql中添加列_mysql如何给表中添加列(字段)?

    mysql给表中添加列的方法:1.使用"ALTER TABLE 表名 ADD 新字段名 数据类型 [约束条件];"在末尾添加列:2.使用"ALTER TABLE 表名 A ...

  7. 【无标题】mysql增加字段和备注_mysql 修改表名,修改字段类型,增加字段,删除字段,添加字段备注,添加索引...

    mysql语句: 1.修改表名: rename table 旧表名 to 新表名; 2.修改字段类型: alter table 表名 modify column 字段名 字段类型(长度) 3.修改字段 ...

  8. Mysql SQL语句执行更新或者插入添加条件判断

    Mysql SQL语句执行更新或者插入添加条件判断 – 更新操作 – INSERT INTO materials (ID,Name,Remaining,Total) VALUES (1,'SolidW ...

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

    1.问题引出 为了保证数据的正确性,代码的健壮性,我们必须对一些边界条件做一个判断,所以才会把修改表结构搞得如此复杂. mysql 新增字段时判断字段是否存在,本来是一个很小的问题,因为以前都是使用 ...

最新文章

  1. hihoCoder #1068 : RMQ-ST算法(模板)
  2. 9招!解决空调总是报低压报警的问题
  3. 动态规划/贪心总结(一)
  4. jquery.ui.draggable中文文档jquery 自由拖拽类~study~
  5. 抓包工具mitmproxy | mitmweb基本用法(二)
  6. CuteEditor 5.0 的使用
  7. 微控制器8位到32位变迁
  8. Java之JVM调优案例分析与实战(5) - 服务器JVM进程奔溃
  9. 1 MySQL的备份和还原常见命令
  10. 高效延时消息设计与实现的场景
  11. mysql配置命令大全_MySQL常用命令汇总
  12. [Swift]LeetCode528. 按权重随机选择 | Random Pick with Weight
  13. springboot 防止xss 和sql 注入 改写 http 请求 getParameter,getParameterValues,getHeader等方法 有点东西
  14. java 获取系统默认打印机状态
  15. 正则化和正则化的思想
  16. java字符串同构_Java同构代码
  17. 职业生涯阶段性回顾之第一个五年计划
  18. 用 python 绘制玫瑰花
  19. 销售数据分析软件——让你不做糊涂账
  20. grafana+alertmanager 微信报警发送给不同告警人

热门文章

  1. 常见的网络攻击手段有哪些?
  2. Android 中文API网址
  3. FreeNOS-kernel目录下boot.S、链接脚本kernel.ld文件分析(四)
  4. 流程配置中,什么是会签/或签(竞签)
  5. c语言oj猜灯谜,元宵节灯谜——文学典籍类
  6. Win10杀死进程方式
  7. 【杂耍】小米3刷MIUI7系统
  8. ios重签名shell脚本_03:双层签名和重签名流程以及shell脚本重签名
  9. 洲思zCloud公有云版发布
  10. 阅读笔记–Java 8函数式编程,建议看书,作者高屋建瓴