600字范文,内容丰富有趣,生活中的好帮手!
600字范文 > Mysql 检查表是否存在并创建表 检查列是否存在并新增 修改 删除列

Mysql 检查表是否存在并创建表 检查列是否存在并新增 修改 删除列

时间:2022-10-31 08:22:13

相关推荐

Mysql 检查表是否存在并创建表 检查列是否存在并新增 修改 删除列

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

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

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

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

参考:/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)BEGINDECLARE Rows1 INT;SET Rows1=0;SELECT COUNT(*) INTO Rows1 FROM INFORMATION_SCHEMA.ColumnsWHERE table_schema= DATABASE() AND table_name=TableName AND column_name=ColumnName;-- 新增列IF (CType=1 AND Rows1<=0) THENSET SqlStr := CONCAT( 'ALTER TABLE ',TableName,' ADD COLUMN ',ColumnName,' ',SqlStr);-- 修改列类型ELSEIF (CType=2 AND Rows1>0) THENSET SqlStr := CONCAT('ALTER TABLE ',TableName,' MODIFY ',ColumnName,' ',SqlStr);-- 删除列ELSEIF (CType=3 AND Rows1>0) THENSET 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列名 SqlStr 字段参数,用来拼接sql语句-- CType 类型 / 1 为新增 ,2为 修改 , 3 为删除-- 新增列-- CALL Pro_Temp_ColumnWork ('表名','字段名','字段参数 ', 1);-- CALL Pro_Temp_ColumnWork ('表名','字段名','int(11) NULL DEFAULT NULL;', 1);-- CALL Pro_Temp_ColumnWork ('example','status','int(11) NULL DEFAULT NULL;', 1);-- 删除列-- CALL Pro_Temp_ColumnWork ('example','status','', 3);

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