本文是針對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;