IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> 存储过程修改数据库所有表结构和数据 -> 正文阅读

[大数据]存储过程修改数据库所有表结构和数据

描述

这个函数可以修改数据库中所有表的结构和数据,是同时修改的啊,而且每次执行只能修改一个字段。具体使用看下面的dome。

需要的基础

  • 存储过程的定义
  • 游标
  • 变量的定义
  • 逻辑运算
  • while , if
  • delimiter

代码

-- 创建存储过程
drop procedure if exists proc01;
delimiter $$;
create procedure proc01(
  -- 字段值
	in lg varchar(255), 
	-- 库名
	in `database` varchar(255),
	-- 字段名
	in `field` varchar(255),
	-- 修改后的字段类型
	in `type` varchar(255)
)
begin
	declare table_name_copy varchar(255) default '';
	declare table_index int(11) default 0;
	-- 表 游标
	declare cursor_table cursor for select table_name from information_schema.tables where table_schema = `database`;
	-- 记录,不知道专有名词
	declare continue handler for not found set table_index = 1;
	open cursor_table;
	-- 执行记录
	set @response = '';
	fetch cursor_table INTO table_name_copy;
	while table_index <> 1 do
	-- 判断字段是否存在
		if exists(select * from information_schema.columns where table_schema = `database` and table_name = `table_name_copy` and column_name = `field`)  then
			begin
				set @tb = table_name_copy;
				-- 	修改表结构
				set @ddl = concat("alter table `", @tb, "` modify column ", `field` ," ", `type`);
				prepare sddl from @ddl;
				execute sddl;
				deallocate prepare sddl;
				set @response = concat(@response, ",", @ddl);
				-- 	修改数据
				set @sqlStr = concat("update `", @tb , "` set ", `field`,"='", lg, "'");
				prepare stmt from @sqlStr;
				execute stmt;
				deallocate prepare stmt;
			end;
		end if;
		-- 取游标
		fetch cursor_table INTO table_name_copy;
	end while;
	close cursor_table;
	select @response;
end $$;

-- 调用存储过程
--           字段值    库名       字段             类型
call proc01('ZH_CN', 'hczn', 'sys_language', 'varchar(255)');
  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-04-26 11:47:11  更:2022-04-26 11:48:44 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 3:19:48-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码