【PostgreSQL】pgsql编写函数实现批量删除数字结尾的备份表
执行前:
最终代码:
CREATE OR REPLACE FUNCTION "ap"."iter_drop_table_bak"()
RETURNS "pg_catalog"."void" AS $BODY$
DECLARE
row_tag VARCHAR(200);
BEGIN
FOR row_tag IN (
select
tablename
from pg_tables
where
schemaname='ap'
and
tablename SIMILAR TO 'analysis_[a-z,_]+_[0-9]+'
) LOOP
RAISE notice '表名为:%',row_tag;
EXECUTE concat('drop table ',row_tag);
END LOOP;
END;
$BODY$
LANGUAGE plpgsql VOLATILE
COST 100
-- 删除备份表
-- 〇、概述
1、所需库表
库:雪蕾DEV
模式:ap中生成的分析模型
表:analysis_automodelaiyp_202207201611
2、所需函数
case when then end
REGEXP_LIKE(String, Regexp)
3、步骤
(1)获得指定库模式下的所有表,并建立临时表
(2)查找临时表的内容
(3)选用合适的正则表达式匹配函数
(4)使用CASE WHEN,删除表
4、所需资料
(1)查看数据库的所有表
http://www.viiis.cn/news/show_93227.html
(2)SQL正则表达式及案例
https://zhuanlan.zhihu.com/p/352635770
(3)创建临时表
http://t.zoukankan.com/lhdz_bj-p-9024183.html
(4)腾讯pgsql模式匹配文档
https://cloud.tencent.com/document/product/878/33579
(5)pgsql存储过程
一、分步骤实施
0、测试
case
when REGEXP_LIKE(table_name, "^[A-Z]+_[a-z0-9]+$")
then
drop table_name
else
continue
end
1、获得指定库模式下的所有表,并建立临时表
(1)查询所有表
select * from pg_tables; -- 查询当前数据库的所有表
-- 字段schemaname/tablename
(2)筛选出指定模式的所有表
select tablename
from pg_tables
where schemaname='ap';
(3)使用原生语法查询【需要在pgadmin查询】
\d
(4)建立临时表
create temp table delete_table_list_all(tablename varchar(255));
(5)向临时表中插入数据
insert into delete_table_list_all(tablename)
select tablename
from pg_tables
where schemaname='ap';
(6)查询临时表的数据
select * from delete_table_list_all;
(7)最终效果
create temp table delete_table_list_all(tablename varchar(255)); -- 建临时表
insert into delete_table_list_all(tablename) -- 插入数据
select tablename
from pg_tables
where schemaname='ap';
select * from delete_table_list_all; -- 查询临时表所有数据
2、选用合适的正则表达式匹配函数
方式:SIMILAR TO 或 ~ 或 LIKE
(1)查询出指定表名(使用LIKE)
select tablename
from pg_tables
where
schemaname='ap'
and
tablename LIKE 'a%';
(2)使用SIMILAR TO -- OKAY
select tablename
from pg_tables
where
schemaname='ap'
and
tablename SIMILAR TO 'analysis_[a-z]+_[0-9]+';
(3)使用regexp/~/POSIX正则表达式
(4)最终SIMILAR TO
select tablename
from pg_tables
where
schemaname='ap'
and
tablename SIMILAR TO 'analysis_[a-z]+_[0-9]+';
4、通过创建函数或存储过程,删除查到的所有表
(1)测试创建存储过程
-- 循环(mysql)
create or replace procedure p_xunhuan(input in number,output out number) as
temp number(10);
begin
temp := 0;
for temp in 0..input loop
begin
output := input+temp;
dbms_output.put_line('----'||output);
end;
end loop;
end p_xunhuan;
-- 执行存储过程(mysql)
declare
sr number;
sc number;
begin
sr := 7;
p_xunhuan(sr,sc);
end;
-- 创建存储过程(pgsql)
CREATE OR REPLACE FUNCTION learn_conditional01(IN num integer,OUT result_str varchar(20)) AS
$BODY$
BEGIN
IF num <= 0 THEN
result_str = '小于等于0';
ELSIF num <= 100 THEN
result_str = '(0-100]';
ELSIF num <= 1000 THEN
result_str = '(100-1000]';
ELSE
result_str = '1000以上';
END IF;
END;
$BODY$
LANGUAGE plpgsql;
-- 执行存储过程
select learn_conditional01(-1);
-- 存储过程循环
-- IN可以跟子查询
CREATE OR REPLACE FUNCTION learn_conditional06()
RETURNS Void AS
$BODY$
DECLARE counter integer = 1;
BEGIN
RAISE notice '--------------';
FOR i IN 1..10 LOOP
RAISE notice '这是第%次循环',i;
END LOOP;
RAISE notice '--------------';
FOR i IN REVERSE 10..1 LOOP
RAISE notice '这是倒序的第%次循环',i;
END LOOP;
RAISE notice '--------------';
FOR i IN 1..10 BY 3 LOOP --间隔2个数字
RAISE notice '这是间隔2个数的第%次循环',i;
END LOOP;
END;
$BODY$
LANGUAGE plpgsql;
-- 循环执行
select learn_conditional06();
(2)创建存储过程,遍历数据
CREATE OR REPLACE FUNCTION iter_drop_table_bak()
RETURNS Void AS
$BODY$
DECLARE
row_tag VARCHAR(200);
table_name VARCHAR(200);
BEGIN
FOR row_tag IN (
select
tablename
from pg_tables
where
schemaname='ap'
and
tablename SIMILAR TO 'analysis_[a-z,_]+_[0-9]+'
) LOOP
RAISE notice '表名为:%',row_tag;
EXECUTE concat('drop table ',row_tag);
END LOOP;
END;
$BODY$
LANGUAGE plpgsql;
-- 执行
select iter_drop_table_bak();
(3)执行删除操作
set a = btrim('(123)','()');
【PostgreSQL】pgsql编写函数实现批量删除数字结尾的备份表的更多相关文章
- mysql批量删除指定前缀或后缀表
今天突然发现我们数据库中多出很多表,后缀名为"copy",预计是navicat直接拷贝导致的,然后要对这些有同样后缀名的表进行删除,假设一个一个选择会非常麻烦,表计较多,在网上找了 ...
- oracle批量删除某用户下的表
昨天干了一天的体力活,到快下班时被要求删除一批测试库上错误的表,主要是这些表的字段和生产上字段顺序对不上,然后让我写个脚本,让dba执行一下,主要是删表这种东西我们都没权限. 然后,我就被难到了,我记 ...
- Greenplum(PostgreSql)函数实现批量删除表
项目做库迁移,前期需要经常调整表结构语句,涉及多次的批量drop,本着偷懒精神写了这个函数.鉴于本函数在生产环境有巨大风险,建议测试完毕后立即删除. 主要步骤很简单:1)从pg_tables查询得到相 ...
- sqlserver 批量删除相同前缀名的表
) DECLARE tmpCur CURSOR FOR SELECT name FROM sys.objects WHERE TYPE='U' AND name LIKE N'HSUPA%' OPEN ...
- python 批量删除mysql前缀相同的表
1,一般游戏log数据库会存储大量的玩家行为日志,一种行为一张表,每天生成一张新表,一天会有30+张不同行为的表,通常会保留玩家日志1年左右,对于超过1年的日志需要删除 2,log数据库一年会保存1W ...
- mssql批量删除数据库里所有的表
go declare @tbname varchar(250) declare #tb cursor for select name from sysobjects where objectprope ...
- SQL删除语句同时向备份表插入数据
从这里摘抄下来的,觉得很不错,http://www.cnblogs.com/ljhdo/p/5792886.html#3503524 ,以后就用这种方式删除,再也不用担心删除错数据啦!!!
- PHP数据访问批量删除(10261101)
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- sqlserver中自定义函数+存储过程实现批量删除
由于项目的需要,很多模块都要实现批量删除的功能.为了方便模块的调用,把批量删除方法写成自定义函数.直接上代码. 自定义函数: ALTER FUNCTION [dbo].[func_SplitById] ...
- postgresql批量删除表
CREATE FUNCTION del_ora_table() RETURNS void AS $$ DECLARE tmp ); DECLARE names CURSOR FOR select ta ...
随机推荐
- Java开发学习(三十六)----SpringBoot三种配置文件解析
一. 配置文件格式 我们现在启动服务器默认的端口号是 8080,访问路径可以书写为 http://localhost:8080/books/1 在线上环境我们还是希望将端口号改为 80,这样在访问的时 ...
- 基于Qt Designer和PyQt5的桌面软件开发--环境搭建和入门例子
本文介绍了如何使用技术栈PyCharm+Qt Designer+PyQt5来开发桌面软件,从环境搭建.例子演示到对容易混淆概念的解释.文中用到的全部软件+代码下载链接为:https://url39 ...
- .Net CLR GC plan_phase二叉树和Brick_table
楔子 别那么懒,勤快点.以下取自CLR PreView 7.0. 主题 GC计划阶段(plan_phase)主要就两个部分,一个是堆里面的对象构建一颗二叉树(这颗二叉树的每个节点包含了诸如对象移动信息 ...
- Docker容器技术基础
Docker基础 目录 Docker基础 容器(Container) 传统虚拟化与容器的区别 Linux容器技术 Linux Namespaces CGroups LXC docker基本概念 doc ...
- Ubuntu 环境下安装 Docker
系统要求 Docker目前只能运行在64位平台上,并且要求内核版本不低于3.10,实际上内核越新越好,过低的内核版本容易造成功能不稳定. 用户可以通过如下命令检查自己的内核版本详细信息: $ unam ...
- 面试突击91:MD5 加密安全吗?
MD5 是 Message Digest Algorithm 的缩写,译为信息摘要算法,它是 Java 语言中使用很广泛的一种加密算法.MD5 可以将任意字符串,通过不可逆的字符串变换算法,生成一个唯 ...
- Docker | redis安装及测试
此篇文章目的是熟悉一下redis的下载安装使用,为后面部署redis集群做准备. 下载安装 linux上,我在/download目录下,执行下载的命令 root@--- ~]# wget http:/ ...
- lnmp配置laravel访问环境报错锦集
1.laravel配置域名访问变成下载,实际就是Nginx没有识别到.php文件.把.php文件的配置加到Nginx即可 .... # 这一段放到项目的Nginx.conf配置文件里面 locatio ...
- golang中的nil接收器
索引:https://waterflow.link/articles/1666534616841 我们先看一个简单的例子,我们自定义一个错误,用来把多个错误放在一起输出: type CustomErr ...
- NLP之TextLSTM(预测单词下一个字母)
LSTM 目录 LSTM 1.理论 1.1 LSTM与RNN 1.1.1 RNN的缺点 1.1.2 LSTM 1.2 LSTM基本结构 2.实验 2.1 实验步骤 2.2 算法模型 1.理论 1.1 ...