zoukankan      html  css  js  c++  java
  • MySql数据库中,判断表、表字段(存储过程)是否存在,不存在就新增

    本文是针对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
    -- 定义Row1,设置初始值,下一步count(*)赋值给Row1 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'; -- 新增列,下一步Sqlstr赋值 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; -- 执行命令 如果Sqlstr非空,执行sql表达式 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;

    作者:仙桃小白菜 

  • 相关阅读:
    面向对象的静态属性和静态方法
    面向对象魔术方法及类的自动加载
    面向对象
    mysql cmd 创表查表练习
    创建表 查询表以及添加数据
    windows cmd命令
    4.20 mysq数据库 创建表
    cmd控制数据库初步了解
    Jquery初步了解
    故宫博物院项目 JS功能整理
  • 原文地址:https://www.cnblogs.com/renjiaqi/p/12217173.html
Copyright © 2011-2022 走看看