postgresql存储过程实例:已审核证书存入临时表

本文涉及的产品
云原生数据库 PolarDB PostgreSQL 版,标准版 2核4GB 50GB
云原生数据库 PolarDB MySQL 版,通用型 2核4GB 50GB
简介:
存储过程实例: 


需求: 
思路:建立存储过程 
代码逻辑: 
1、先清空缓存表t_cert_sample_tmp; 
2、获取列表, 查询语句: 
SELECT cert_id 
FROM t_cert_state where is_export=1 and check_state=1 and ylf_export=0 group by cert_id; 
3、循环计算单个cert_id的方法: 
1)如果证书修改后状态为'W':取状态为G且未进入筛分系统的样本MD5 
sqlsexec='select sample_md5 from t_cert_sample where cert_id=' || cert_id || ' and not exists (select sample_hash from t_sfa_sample where state=-1 
and sample_hash=t_cert_sample.sample_md5) and exists (select sample_hash from t_white where sample_state=''G'' and sample_hash=t_cert_sample.sample_md5) limit 1'; 
2)如果证书修改后状态不是'W': 
  步骤1:优先查黑表,如果此证书下有黑样本,则取该证书下默认第一例黑样本MD5 
sqlsexec='select sample_md5 from t_cert_sample t1,t_black t2 where t1.cert_id=' || cert_id || 'and  t1.sample_md5=t2.sample_hash  limit 1'; 
步骤2:如果黑表没有样本,则再查白表,取该证书下默认第一例样本MD5 
sqlsexec='select sample_md5 from t_cert_sample t1,t_white t2 where t1.cert_id=' || cert_id || ' and  t1.sample_md5=t2.sample_hash limit 1'; 
4、将证书id和刚刚获取到的样本MD5,插入到缓存表t_cert_sample_tmp(对应字段分别为cert_id和sample_md5) 


建表: 
CREATE TABLE t_cert_sample_tmp 

id serial NOT NULL primary key, 
cert_id integer NOT NULL, 
sample_md5 character varying(41) NOT NULL 

WITH ( 
OIDS=FALSE 
); 
ALTER TABLE t_cert_sample_tmp OWNER TO postgres; 
GRANT ALL ON TABLE t_cert_sample_tmp TO postgres; 
GRANT SELECT, UPDATE, INSERT, DELETE ON TABLE t_cert_sample_tmp TO sqluser; 
GRANT SELECT ON TABLE t_cert_sample_tmp TO fenxi; 
grant SELECT, UPDATE ON sequence t_cert_sample_tmp_id_seq to sqluser; 

--描述 
COMMENT ON TABLE t_cert_sample_tmp IS '存放捕获判定分析已审核证书界面MD5实例数据'; 
COMMENT ON COLUMN t_cert_sample_tmp .cert_id IS '证书id'; 
COMMENT ON COLUMN t_cert_sample_tmp .sample_md5 IS '样本的md5值'; 


以下几种其实实现的是不同的结果,可以仔细研究下 

实现: 
-- Function: cert_sample_tmp() 

-- DROP FUNCTION cert_sample_tmp(); 

CREATE OR REPLACE FUNCTION cert_sample_tmp() 
  RETURNS text AS 
$BODY$ 
DECLARE 
sqlsexec  character varying :=''; 
        sqlsexec1  character varying :=''; 
        sqlsexec2  character varying :=''; 
        sqlsexec3  character varying :='';       
        insexec character varying :=''; 
        tmp_hash varchar(32); 
r record; 
r1 record; 
r2 record; 
r3 record;

BEGIN 
        ------------------------------------------ 
        ----函数功能:优化捕获分析判定系统已审核证书界面md5取值逻辑,并提高页面加载性能 
        ------------------------------------------ 
sqlsexec = 'truncate table t_cert_sample_tmp;'; 
execute sqlsexec; 


      ----只取最新修改的一条记录 
        sqlsexec = 'select a.cert_id,a.later_state from 
                   (select cert_id,later_state,record_time from t_cert_state where is_export=1 and check_state=1 and ylf_export=0 )a, 
                   (select cert_id,max(record_time) as max_record_time from t_cert_state where is_export=1 and check_state=1 and ylf_export=0 group by cert_id)b 
                    where a.record_time=b.max_record_time and a.cert_id=b.cert_id;'; 
        for r in execute sqlsexec 
        loop        

              ---如果证书修改后状态为'W':取状态为G且未进入筛分系统的样本MD5,将证书对应的hash取一条插入t_cert_sample_tmp表中 
              if r.later_state='W' then 
                  sqlsexec1='select sample_md5,cert_id from t_cert_sample where cert_id='''|| r.cert_id ||''' and not exists (select sample_hash from t_sfa_sample where state=-1 
                         and sample_hash=t_cert_sample.sample_md5) and exists (select sample_hash from t_white where sample_state=''G'' and sample_hash=t_cert_sample.sample_md5) limit 1'; 
                  raise notice '%',sqlsexec1; 
                  execute sqlsexec1 into r1; 
                  if r1.sample_md5 is not null then 
                  tmp_hash = r1.sample_md5; 
                  end if; 
              else 
                       ----如果证书修改后状态不是'W':1.优先查黑表,如果此证书下有黑样本,则取该证书下默认第一例黑样本MD5 
                       sqlsexec2='select sample_md5 from t_cert_sample t1,t_black t2 where t1.cert_id='''|| r.cert_id ||''' and  t1.sample_md5=t2.sample_hash  limit 1'; 
                       raise notice '%',sqlsexec2; 
                       execute sqlsexec2 into r2; 
                       if r2.sample_md5 is not null then 
                       tmp_hash = r2.sample_md5; 
                       else 
                           ----2.如果黑表没有样本,则再查白表,取该证书下默认第一例样本MD5 
                           sqlsexec3='select sample_md5 from t_cert_sample t1,t_white t2 where t1.cert_id='''||r.cert_id ||''' and  t1.sample_md5=t2.sample_hash limit 1'; 
                           raise notice '%',sqlsexec3; 
                           execute sqlsexec3 into r3; 
                           if r3.sample_md5 is not null then 
                           tmp_hash = r3.sample_md5; 
                           end if; 
                       end if; 
              end if; 
                       insexec = 'insert into t_cert_sample_tmp(cert_id,sample_md5) values ('''||r.cert_id||''','''||tmp_hash||''');'; 
                       raise notice '%',insexec; 
                       execute insexec;        
        end loop;             
     
        RETURN 'DONE'; 
exception when others then 
RAISE EXCEPTION '(%)', SQLERRM; 
return 'error'; 
END 
$BODY$ 
  LANGUAGE plpgsql VOLATILE 
  COST 100; 
ALTER FUNCTION cert_sample_tmp() 
  OWNER TO postgres; 
GRANT EXECUTE ON FUNCTION cert_sample_tmp() TO public; 
GRANT EXECUTE ON FUNCTION cert_sample_tmp() TO postgres; 
GRANT EXECUTE ON FUNCTION cert_sample_tmp() TO sqluser; 


====================================================================== 

DECLARE 
sqlsexec  character varying :=''; 
        sqlsexec1  character varying :=''; 
        sqlsexec2  character varying :=''; 
        sqlsexec3  character varying :='';       
        insexec character varying :=''; 
        tmp_hash varchar(32); 
r record; 
r1 record; 
r2 record; 
r3 record;

BEGIN 
        ------------------------------------------ 
        ----函数功能:优化捕获分析判定系统已审核证书界面md5取值逻辑,并提高页面加载性能(每个证书下面只显示一个样本hash) 
        ------------------------------------------ 
sqlsexec = 'truncate table t_cert_sample_tmp;'; 
execute sqlsexec; 

        sqlsexec = 'SELECT distinct cert_id FROM t_cert_state where is_export=1 and check_state=1 and ylf_export=0'; 
        for r in execute sqlsexec 
        loop        
              sqlsexec1='select sample_md5,cert_id from t_cert_sample where cert_id='''|| r.cert_id ||''' and not exists (select sample_hash from t_sfa_sample where state=-1 
                         and sample_hash=t_cert_sample.sample_md5) and exists (select sample_hash from t_white where sample_state=''G'' and sample_hash=t_cert_sample.sample_md5) limit 1'; 
              raise notice '%',sqlsexec1; 
              execute sqlsexec1 into r1; 
             
              ---如果证书修改后状态为'W':取状态为G且未进入筛分系统的样本MD5,将证书对应的所有hash都逐条插入t_cert_sample_tmp表中 
                   if r1.sample_md5 is not null then 
                       tmp_hash = r1.sample_md5;   
                   else 
                       ----如果证书修改后状态不是'W':1.优先查黑表,如果此证书下有黑样本,则取该证书下默认第一例黑样本MD5 
                       sqlsexec2='select sample_md5 from t_cert_sample t1,t_black t2 where t1.cert_id='''|| r.cert_id ||''' and  t1.sample_md5=t2.sample_hash  limit 1'; 
                       raise notice '%',sqlsexec2; 
                       execute sqlsexec2 into r2; 
                       if r2.sample_md5 is not null then 
                       tmp_hash = r2.sample_md5; 
                       else 
                           ----2.如果黑表没有样本,则再查白表,取该证书下默认第一例样本MD5 
                           sqlsexec3='select sample_md5 from t_cert_sample t1,t_white t2 where t1.cert_id='''||r.cert_id ||''' and  t1.sample_md5=t2.sample_hash limit 1'; 
                           raise notice '%',sqlsexec3; 
                           execute sqlsexec3 into r3; 
                           if r3.sample_md5 is not null then 
                           tmp_hash = r3.sample_md5; 
                           end if; 
                       end if; 
                  end if; 
                  insexec = 'insert into t_cert_sample_tmp(cert_id,sample_md5) values ('''||r.cert_id||''','''||tmp_hash||''');'; 
                       raise notice '%',insexec; 
                       execute insexec;          
        end loop;             
     
        RETURN 'DONE'; 
exception when others then 
RAISE EXCEPTION '(%)', SQLERRM; 
return 'error'; 
END 


==================================================================================== 

DECLARE 
sqlsexec  character varying :=''; 
        sqlsexec1  character varying :=''; 
        sqlsexec2  character varying :=''; 
        sqlsexec3  character varying :='';       
        insexec character varying :=''; 
        tmp_hash varchar(32); 
r record; 
r1 record; 
r2 record; 
r3 record;

BEGIN 
        ------------------------------------------ 
        ----函数功能:优化捕获分析判定系统已审核证书界面md5取值逻辑,并提高页面加载性能(每个证书下面满足条件的hash都显示出来) 
        ------------------------------------------ 
sqlsexec = 'truncate table t_cert_sample_tmp;'; 
execute sqlsexec; 

        sqlsexec = 'SELECT distinct cert_id FROM t_cert_state where is_export=1 and check_state=1 and ylf_export=0'; 
        for r in execute sqlsexec 
        loop        
              sqlsexec1='select sample_md5,cert_id from t_cert_sample where cert_id='''|| r.cert_id ||''' and not exists (select sample_hash from t_sfa_sample where state=-1 
                         and sample_hash=t_cert_sample.sample_md5) and exists (select sample_hash from t_white where sample_state=''G'' and sample_hash=t_cert_sample.sample_md5)'; 
              raise notice '%',sqlsexec1; 
              for r1 in execute sqlsexec1 
                  loop 
             
              ---如果证书修改后状态为'W':取状态为G且未进入筛分系统的样本MD5,将证书对应的所有hash都逐条插入t_cert_sample_tmp表中 
                   if r1.sample_md5 is not null then 
                       tmp_hash = r1.sample_md5; 
                       insexec = 'insert into t_cert_sample_tmp(cert_id,sample_md5) values ('''||r1.cert_id||''','''||tmp_hash||''');'; 
                       raise notice '%',insexec; 
                       execute insexec;    
                   else 
                       ----如果证书修改后状态不是'W':1.优先查黑表,如果此证书下有黑样本,则取该证书下默认第一例黑样本MD5 
                       sqlsexec2='select sample_md5 from t_cert_sample t1,t_black t2 where t1.cert_id='''|| r.cert_id ||''' and  t1.sample_md5=t2.sample_hash  limit 1'; 
                       raise notice '%',sqlsexec2; 
                       execute sqlsexec2 into r2; 
                       if r2.sample_md5 is not null then 
                       tmp_hash = r2.sample_md5; 
                       else 
                           ----2.如果黑表没有样本,则再查白表,取该证书下默认第一例样本MD5 
                           sqlsexec3='select sample_md5 from t_cert_sample t1,t_white t2 where t1.cert_id='''||r.cert_id ||''' and  t1.sample_md5=t2.sample_hash limit 1'; 
                           raise notice '%',sqlsexec3; 
                           execute sqlsexec3 into r3; 
                           if r3.sample_md5 is not null then 
                           tmp_hash = r3.sample_md5; 
                           end if; 
                       end if; 
                       insexec = 'insert into t_cert_sample_tmp(cert_id,sample_md5) values ('''||r.cert_id||''','''||tmp_hash||''');'; 
                       raise notice '%',insexec; 
                       execute insexec;  
                  end if; 
                end loop;       
        end loop;             
     
        RETURN 'DONE'; 
exception when others then 
RAISE EXCEPTION '(%)', SQLERRM; 
return 'error'; 
END 
相关实践学习
使用PolarDB和ECS搭建门户网站
本场景主要介绍基于PolarDB和ECS实现搭建门户网站。
阿里云数据库产品家族及特性
阿里云智能数据库产品团队一直致力于不断健全产品体系,提升产品性能,打磨产品功能,从而帮助客户实现更加极致的弹性能力、具备更强的扩展能力、并利用云设施进一步降低企业成本。以云原生+分布式为核心技术抓手,打造以自研的在线事务型(OLTP)数据库Polar DB和在线分析型(OLAP)数据库Analytic DB为代表的新一代企业级云原生数据库产品体系, 结合NoSQL数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
相关文章
|
7月前
|
存储
Cloudstack启动实例模板从二级存储复制到主存储过程
Cloudstack启动实例模板从二级存储复制到主存储过程
|
关系型数据库 OLAP 数据库
如何克隆AnalyticDB PostgreSQL实例
AnalyticDB PostgreSQL版支持基于已有实例,快速克隆出一个完全相同的实例。
|
8月前
|
关系型数据库 PostgreSQL
postgresql日程排程函数的编写实例
postgresql日程排程函数的编写实例
|
8月前
|
SQL 关系型数据库 C语言
PostgreSQL【应用 03】Docker部署的PostgreSQL扩展SQL之C语言函数(编写、编译、载入)计算向量余弦距离实例分享
PostgreSQL【应用 03】Docker部署的PostgreSQL扩展SQL之C语言函数(编写、编译、载入)计算向量余弦距离实例分享
109 0
|
8月前
|
SQL 关系型数据库 数据库
PostgreSQL【应用 02】扩展SQL之C语言函数(编写、编译、载入)实例分享
PostgreSQL【应用 02】扩展SQL之C语言函数(编写、编译、载入)实例分享
252 0
|
存储 关系型数据库 MySQL
MySQL定时任务存储过程函数和动态表名实例
MySQL定时任务存储过程函数和动态表名实例
105 0
|
存储 关系型数据库 MySQL
MySQL的临时表以及视图与存储过程、触发器等功能概念详细解释说明以及它们的使用方法举例?
MySQL的临时表以及视图与存储过程、触发器等功能概念详细解释说明以及它们的使用方法举例?
|
存储 关系型数据库 MySQL
MySQL存储过程中双层游标嵌套循环实例
MySQL存储过程中双层游标嵌套循环实例
392 0
|
关系型数据库 数据库 PostgreSQL
PG技术大讲堂 - Part 4:PostgreSQL实例结构
PostgreSQL从小白到专家,是从入门逐渐能力提升的一个系列教程,内容包括对PG基础的认知、包括安装使用、包括角色权限、包括维护管理、、等内容,希望对热爱PG、学习PG的同学们有帮助,欢迎持续关注CUUG PG技术大讲堂。
230 1
PG技术大讲堂 - Part 4:PostgreSQL实例结构
|
SQL Cloud Native 关系型数据库
《阿里云认证的解析与实战-数据仓库ACP认证》——云原生数据仓库AnalyticDB PostgreSQL版功能演示(上)——一、创建实例
《阿里云认证的解析与实战-数据仓库ACP认证》——云原生数据仓库AnalyticDB PostgreSQL版功能演示(上)——一、创建实例