mysql增量语句如何修改表的字段

 更新时间:2024年12月23日 08:39:05   作者:Mars'Ares  
本文介绍了如何在MySQL中实现数据库的增量更新,确保多次执行增量语句不会影响最终结果,通过使用存储过程,解决了MySQL无法直接执行块语句的问题,文章详细描述了增量添加、修改和删除某个字段的操作,并总结了增量语句的编写方法,类似于编写幂等接口

前言

1、数据库增量语句:基于现有语句实现增量更新且多次执行增量语句不会影响最终结果。即满足幂等操作。

2、mysql似乎不支持不建立存储过程/函数情况,直接执行块语句。。。这点有些无语

3、本文以存储过程为例。

实现

思路

  • 查询是否满足条件
  • 执行满足条件的操作
  • 删除所有临时变量

实现前提

-- 查询当前库表信息
SELECT * FROM information_schema. COLUMNS WHERE TABLE_SCHEMA = (SELECT DATABASE())

-- 查询当前库某表信息
SELECT * FROM information_schema. COLUMNS WHERE TABLE_SCHEMA = (SELECT DATABASE()) 
AND TABLE_NAME = '表名'

-- 查询当前库某表某字段信息
SELECT * FROM information_schema. COLUMNS WHERE TABLE_SCHEMA = (SELECT DATABASE()) 
AND TABLE_NAME = '表名'
AND COLUMN_NAME = '字段名'

	
-- 删除某个表字段(不能有引号)
alter table 表名 drop column 字段名; 
-- 添加某个表字段(不能有引号)
alter table 表名 add 字段名 varchar(128) comment '备注等';
-- 修改某个表字段(不能有引号)
alter table 表名 change 旧字段名 新字段名 varchar(128) comment '备注等';



-- 实现用户变量
SET @变量名='变量值';
SELECT @变量名;

-- 实现条件语句(必须在代码块中)
IF @变量='变量值' THEN 
SELECT @变量名;
END IF;

-- 删除存储函数
DROP PROCEDURE IF EXISTS deptProc; 

-- 创建存储函数
DELIMITER //
CREATE PROCEDURE deptProc() 
BEGIN
SET @变量名='变量值';
SELECT @变量名;
IF @变量='变量值' THEN 
SELECT @变量名;
END IF;
END//
DELIMITER ;

-- 调用存储函数
CALL deptProc(); 

增量添加某个字段

-- 删除存储过程
DROP PROCEDURE IF EXISTS testProc; 

DELIMITER //

-- 创建存储过程
CREATE PROCEDURE testProc() 
BEGIN
    -- 查询条件
	SELECT
		COUNT(*) into @y
	FROM
		information_schema. COLUMNS
	WHERE
        TABLE_SCHEMA = (SELECT DATABASE())
		 AND TABLE_NAME = '表名'
	     AND COLUMN_NAME = '字段名';
    -- 查询条件

    -- 判断存在
    IF @y=0 THEN 
        alter table 表名 add 字段名 varchar(32)  comment '备注等';
    -- ELSEIF alter table 表名 change 字段名 字段名 varchar(32)  comment '备注等';
    END IF;
    -- 判断存在
END

//DELIMITER ;

-- 调用存储过程
CALL testProc(); 

-- 删除存储过程
DROP PROCEDURE IF EXISTS testProc; 

增量修改某个字段

-- 删除存储过程
DROP PROCEDURE IF EXISTS testProc; 

DELIMITER //

-- 创建存储过程
CREATE PROCEDURE testProc() 
BEGIN
    -- 查询条件
	SELECT
		COUNT(*) into @y
	FROM
		information_schema. COLUMNS
	WHERE
        TABLE_SCHEMA = (SELECT DATABASE())
		 AND TABLE_NAME = '表名'
	     AND COLUMN_NAME = '旧字段名';
    -- 查询条件

    -- 判断存在
    IF @y=1 THEN 
        alter table 表名 change 旧字段名 新字段名 varchar(32)  comment '备注等';
    -- ELSEIF @y =0 THEN  alter table 表名 add 新字段名 varchar(32)  comment '备注等';
    END IF;
    -- 判断存在
END

//DELIMITER ;

-- 调用存储过程
CALL testProc(); 

-- 删除存储过程
DROP PROCEDURE IF EXISTS testProc; 

增量删除某个字段

-- 删除存储过程
DROP PROCEDURE IF EXISTS testProc; 

DELIMITER //

-- 创建存储过程
CREATE PROCEDURE testProc() 
BEGIN
    -- 查询条件
	SELECT
		COUNT(*) into @y
	FROM
		information_schema. COLUMNS
	WHERE
        TABLE_SCHEMA = (SELECT DATABASE())
		 AND TABLE_NAME = '表名'
	     AND COLUMN_NAME = '旧字段名';
    -- 查询条件

    -- 判断存在
    IF @y=1 THEN 
        alter table 表名 drop 旧字段名;
    END IF;
    -- 判断存在
END

//DELIMITER ;

-- 调用存储过程
CALL testProc(); 

-- 删除存储过程
DROP PROCEDURE IF EXISTS testProc; 

总结

1、增量语句写法类似于编写幂等接口,实现多次操作结果一致。

2、实例中多次使用存储函数创建和删除,实在是因为块语句无法脱离存储过程/函数执行

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • MySQL 创建索引(Create Index)的方法和语法结构及例子

    MySQL 创建索引(Create Index)的方法和语法结构及例子

    MySQL 创建索引(Create Index)的方法和语法结构及例子
    2009-07-07
  • MySQL实战之Insert语句的使用心得

    MySQL实战之Insert语句的使用心得

    这篇文章主要给大家介绍了关于MySQL实战之Insert语句的使用心得的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-10-10
  • MySQL慢SQL语句常见诱因以及解决方法

    MySQL慢SQL语句常见诱因以及解决方法

    在本篇文章里小编给大家整理的关于MySQL慢SQL语句常见诱因以及解决方法,有需要的朋友们可以学习下。
    2019-08-08
  • 详解MySQL拼接函数CONCAT的使用心得

    详解MySQL拼接函数CONCAT的使用心得

    这篇文章主要介绍了详解MySQL拼接函数CONCAT的使用心得,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • mysql日志触发器实现代码

    mysql日志触发器实现代码

    这篇文章主要介绍了mysql日志触发器实现代码,需要的朋友可以参考下
    2020-02-02
  • Mysql数据库的主从同步配置

    Mysql数据库的主从同步配置

    这篇文章主要介绍了Mysql主从同步配置的相关资料,需要的朋友可以参考下文内容
    2021-08-08
  • MySQL数据实时同步到MongoDB的实践分享

    MySQL数据实时同步到MongoDB的实践分享

    很多 DBA 同学经常会遇到要从一个数据库实时同步到另一个数据库的问题,同构数据还相对容易,遇上异构数据、表多、数据量大等情况就难以同步,我自己亲测了一种方式可以实现MySQL数据实时同步到MongoDB,跟大家分享一下,希望对你有帮助
    2024-01-01
  • mysql数据库日志binlog保存时效问题(expire_logs_days)

    mysql数据库日志binlog保存时效问题(expire_logs_days)

    这篇文章主要介绍了mysql数据库日志binlog保存时效问题(expire_logs_days),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-03-03
  • MySQL中使用MD5加密的实现

    MySQL中使用MD5加密的实现

    本文主要介绍了MySQL中使用MD5加密的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-08-08
  • MYSQL使用inner join 进行 查询/删除/修改示例

    MYSQL使用inner join 进行 查询/删除/修改示例

    本文为大家介绍下使用inner join 进行查询/删除/修改,具体实现如下,学习mysql的朋也可以学习下,希望对大家有所帮助
    2013-07-07

最新评论