本文是针对MySql数据库创建的SQL脚本,别搞错咯。

判断表是否存在,不存在就可新增

CREATE TABLE IF NOT EXISTS `mem_cardtype_resource` (
...
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

判断表字段是否存在,不存在就可新增、修改、删除,移除修改列名

MySql中没有直接的语法可以在增加列前进行判断该列是否存在,解决方案是写一个存储过程来完成此任务。

参考:https://blog.csdn.net/huangjin0507/article/details/49330413

DROP PROCEDURE IF EXISTS Pro_Temp_ColumnWork;
DELIMITER$$
-- 1表示新增列,2表示修改列类型,3表示删除列
CREATE PROCEDURE Pro_Temp_ColumnWork(TableName VARCHAR(50),ColumnName VARCHAR(50),SqlStr VARCHAR(4000),CType INT)
BEGIN
DECLARE Rows1 INT;
SET Rows1=0;
SELECT COUNT(*) INTO Rows1 FROM INFORMATION_SCHEMA.Columns
WHERE table_schema= DATABASE() AND table_name=TableName AND column_name=ColumnName;
-- 新增列
IF (CType=1 AND Rows1<=0) THEN
SET SqlStr := CONCAT( 'ALTER TABLE ',TableName,' ADD COLUMN ',ColumnName,' ',SqlStr);
-- 修改列类型
ELSEIF (CType=2 AND Rows1>0) THEN
SET SqlStr := CONCAT('ALTER TABLE ',TableName,' MODIFY ',ColumnName,' ',SqlStr);
-- 删除列
ELSEIF (CType=3 AND Rows1>0) THEN
SET SqlStr := CONCAT('ALTER TABLE ',TableName,' DROP COLUMN ',ColumnName);
ELSE SET SqlStr :='';
END IF;
-- 执行命令
IF (SqlStr<>'') THEN
SET @SQL1 = SqlStr;
PREPARE stmt1 FROM @SQL1;
EXECUTE stmt1;
END IF;
END$$
DELIMITER ; -- 当前数据库 TableName表名 ColumnName列名
-- 新增列
-- CALL Pro_Temp_ColumnWork ('表名','字段名','字段参数 ', 1);
-- CALL Pro_Temp_ColumnWork ('表名','字段名','int(11) NULL DEFAULT NULL AFTER `xxxxxxxxxxx`; ', 1);
-- 删除列
-- CALL Pro_Temp_ColumnWork ('e_handcard_control','EntranceType','', 3); -- 最后再执行一遍删除存储过程
DROP PROCEDURE IF EXISTS Pro_Temp_ColumnWork;

最新文章

  1. test imetro
  2. Java链接MySQL练习题:格式化日期、性别;避免代码注入
  3. AQL 对象关系图
  4. DFTX 笔试
  5. Django1.9开发博客(11)- 富文本与代码高亮
  6. Android之XML序列化和解析
  7. mongodb 操作类
  8. Server.UrlEncode、HttpUtility.UrlDecode的区别
  9. jquery定义表格宽度
  10. 从零开始学android开发-通过WebService获取今日天气情况
  11. php等号(==)与全等(===)
  12. pig对null的处理(实际,对空文本处理为两种取值null或‘’)
  13. JavaScript的事件机制
  14. Jenkins中deploy插件的deploy war/ear to a container与deploy artifacts to maven reepository区别
  15. 【黑马18期Java毕业生】黑马程序员Java全套资料+视频+工具
  16. 学习customEvent
  17. vscode 停用插件自动更新
  18. [LeetCode] 830. Positions of Large Groups_Easy tag: Two Pointers
  19. node.js官方文档chm电子书的制作
  20. 【OCP 12c】最新CUUG OCP-071考试题库(62题)

热门文章

  1. python运算符——逻辑运算符
  2. aspnet core运行后台任务
  3. iOS12系统应用发送邮件中的附件
  4. VMware和Centos安装使用
  5. 省市区地址三级联动jQuery插件Distpicker使用
  6. BZOJ.4942.[NOI2017]整数(分块)
  7. python文本读写数据
  8. sql基本
  9. 如何彻底卸载Jenkins
  10. vue使用技巧(分页、nextTick、复制对象)