开发过程中经常需要提交可以重复执行的sql,当设计到需要增加字段时,可以参考如下办法:
1.如果是mysql 版本高于5.7.5
ALTER TABLE table_name DROP COLUMN IF EXISTS column_name;
2.通用方法
写一个存储过程,然后用存储过程取执行删除字段,然后在脚本执行完后,可以根据自己的实际情况选择删除掉存储过程
--切换到指定的数据 根据自己的情况
use your_dbname;
-- 删除存储过程
DROP PROCEDURE IF EXISTS sp_delete_column_if_exists;
-- 创建存储过程
DELIMITER $$
CREATE PROCEDURE `sp_delete_column_if_exists`(
IN `dbName` VARCHAR(255),
IN `tableName` VARCHAR(255),
IN `columnName` VARCHAR(255)
)
begin
SET @stmt = NULL;
SELECT
COUNT(*) INTO @stmt
FROM
information_schema.columns
WHERE
table_schema = dbName
AND table_name = tableName
AND column_name = columnName;
SELECT
COUNT(*)
FROM
information_schema.columns
WHERE
table_schema = dbName
AND table_name = tableName
AND column_name = columnName;
IF @stmt > 0 THEN
SET @drop_column = CONCAT('ALTER TABLE `', dbName, '`.`', tableName, '` DROP COLUMN `', columnName, '`;');
PREPARE drop_column FROM @drop_column;
EXECUTE drop_column;
DEALLOCATE PREPARE drop_column;
END IF;
END$$
DELIMITER ;
-- 调用存储过程
call sp_delete_column_if_exists('your_db', 'your_table' , 'your_column');
补充:mysql删除语句-delete
一、删除一条(一行)数据
delete from table where id='1'
注: 上述语句含义:删除表名为table中id=1的一条数据
二、删除整表数据
delete from table
注: 上述语句含义:删除表名为table中所有数据,但是不会删除表结构
ps:表结构简单说就是表字段。
小结:
这是本系列第二篇,通过我自己碎片化的学习,我知道在我进行搜索的时候,急需的是一个可用的结果,无需全面广泛的学习。所以本系列不展开扩展,用最少的图文帮助急需使用命令的你。当然,还是推荐能够系统的学习一下sql知识。
到此这篇关于MYSQL 删除一个字段前判断字段是否存在的办法的文章就介绍到这了,更多相关mysql判断字段是否存在内容请搜索编程客栈(www.lsjlt.com)以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网(www.lsjlt.com)!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
软考中级精品资料免费领
- 历年真题答案解析
- 备考技巧名师总结
- 高频考点精准押题
- 资料下载
- 历年真题
193.9 KB下载数265
191.63 KB下载数245
143.91 KB下载数1148
183.71 KB下载数642
644.84 KB下载数2756
相关文章
发现更多好内容- 如何在 Java 中实现对正方形的缩放操作?(如何在Java中对正方形进行缩放操作)
- 如何正确使用 Java 的 join 方法?(java join方法怎么使用)
- Java 中 DecimalFormat 在哪些场景下使用较为合适?(Java DecimalFormat在哪里使用合适)
- 如何确保Redis客户端的安全性:实用技巧与最佳实践
- 在 JavaScript 中如何使用 parentNode?(javascript中的parentNode怎么用)
- 如何高效编码 Java Supplier 接口?(java supplier接口的高效编码技巧)
- 如何进行 Java NoSQL 查询优化?(java nosql查询优化怎样进行)
- Java 中 `equals()` 的核心究竟是什么?(java eques的核心是什么)
- Java代理模式的优缺点分别有哪些?(Java代理模式有哪些优缺点)
- 2024下半年北京软考成绩复查时间及流程