ERP(TIPTOP)用户自行解锁操作说明(p_kill)

2024-02-21 19:40

本文主要是介绍ERP(TIPTOP)用户自行解锁操作说明(p_kill),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

ERP(TIPTOP)用户自行解锁操作说明(试运行)

 

#操作截图①

 

 

--------------------------------------------------------------------线-----------------

 

#操作截图

 

--------------------------------------------------------------------线-----------------

 

 

# 说明

 

   1.操作说明①:用户输入程序编号p_kill,自动打开界面,自动带出当前登录ERP用户。

(备注: 此处[ERP用户编号]已做输入限制,ERP用户为CLASS-ACLASS-A1的用户可以输入其它用户进行解锁,反之只能对自己用户产生锁表进行解锁)

 

   2.操作说明②:用户输入完成之后,点击确定,然后再点击右边解除锁表按钮,作业会根据当前用户编号,进入数据库查找到此用户造成的表死锁,找到后并将其解除,由于公司数据库为oracle rac此过程会等上1~2分钟。

 

   3.解锁成功之后会弹出以下提示:

         

   4.此作业已经做好了管控,可以给各个基地的user提供执行权限(试运行暂时先开几个用户权限),方便在我们休假的时候,用户锁表,自行运行此作业进行解锁。

 

 

 

--------------------------------------------------------------------线-----------------

 

####(程序原理说明)

  1.新建作业 p_kill ()

  2oralce 数据库建立functionprocedure

Procedure:在oracle system用户下建立procedurexxxx,并将procedure的执行权限赋给其它营运中心(即其它oracle用户)

授权语句如下:

grant excute on xxxx(procedurename) to xx(user)

Function:在function里面调用procedure(因为GP版本太低,直接调用存储过程导致编译不通过!),记得每个营运中心都建立这个一模一样的function

  3.本作业主要调用的function和存储过程如下

fuction :

CREATE OR REPLACE FUNCTION killtable(var_name1 VARCHAR2 )
returnVARCHAR2  ISvar_log VARCHAR2(200);
beginlocktablekill(var_name =>var_name1,var_result => var_log);RETURN(var_log);
end ;

--------------------------------------------------------------------线-----------------

 

procedure:CREATEOR REPLACE PROCEDURE LOCKTABLEKILL(VAR_NAME  IN VARCHAR2,VAR_RESULTOUT VARCHAR2) ISVAR_SID    VARCHAR2(20);VAR_SERIALVARCHAR2(20);VAR_SQL    VARCHAR2(2000);VAR_SQL2   VARCHAR2(2000);VAR_USER   VARCHAR2(20);VAR_END    VARCHAR2(50);-------------------------------------------------------------------------description :  erp 用户调用procedure 给用户解锁---date&author : add by kk 2014-10-23---environment: oracle 10g  RAC----------------------------------------------------------------------
BEGINVAR_USER :=VAR_NAME;VAR_SQL  := 'select a.sid,a.serial#  FROM                                                                                                                                     
(SELECTSUBSTR(all_objects.owner||''.''||object_name,1,16) LockedOBJECT                                                            
,SUBSTR(os_user_name,1,10)TiptopUser                                                                                           
,gv$locked_object.processProcID                                                                                                
,SUBSTR(terminal,1,7)Terminal                                                                                                  
,gv$session.sid,gv$session.serial#                                                                                                 
,gv$session.machine                                                                                                                
,gv$session.INST_ID                                                                                                                FROMgv$locked_object,all_objects,gv$session                                                                                     WHEREgv$locked_object.object_id=all_objects.object_id                                                                             ANDgv$locked_object.SESSION_ID=gv$session.SID
) awhere   a.TiptopUser = ''' || VAR_USER ||'''
ANDrownum =1 ';--------------------------------------------------------------------------------------------  --上面这段sql只针对oracle 10g RAC, 如果是非RAC就简单多了,sql重新写下.
--这里只取了一行,当然你如果想把用户所有的锁表都罗列然后解锁 ,--可以考虑使用cursor, 然后再loop,循环使用alter命令干掉进程 ;--------------------------------------------------------------------------------------------DBMS_OUTPUT.PUT_LINE(VAR_SQL);EXECUTE IMMEDIATE VAR_SQLINTO VAR_SID, VAR_SERIAL;IF VAR_SID IS NOT NULL AND VAR_SERIAL IS NOTNULL THENSELECT VAR_SID || ',' || VAR_SERIAL INTOVAR_END FROM DUAL;VAR_RESULT := '死锁用户存在';DBMS_OUTPUT.PUT_LINE(VAR_END);VAR_SQL2 := 'alter system killsession ''' || VAR_END ||''' immediate ';DBMS_OUTPUT.PUT_LINE(VAR_SQL2);EXECUTE IMMEDIATE VAR_SQL2;VAR_RESULT := '死锁用户存在,且已经解锁!请重新运行ERP作业!';END IF;
EXCEPTIONWHEN NO_DATA_FOUND THENVAR_RESULT := '不存在死锁的用户';
END;

 

___________________________________________________________________

--------界面粗糙了一点,内容也单调了一些,功能还不够强大,后期继续改进------

---------各位大神多支招,感谢!!!-------------------------------------------------------------

------------------------------------------------edit by  kk  2014-10-23------------------

------------------------------------------------QQ309200966--------------------------------

___________________________________________________________________

这篇关于ERP(TIPTOP)用户自行解锁操作说明(p_kill)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/732859

相关文章

Before和BeforeClass的区别及说明

《Before和BeforeClass的区别及说明》:本文主要介绍Before和BeforeClass的区别及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Before和BeforeClass的区别一个简单的例子当运行这个测试类时总结Before和Befor

Python pip下载包及所有依赖到指定文件夹的步骤说明

《Pythonpip下载包及所有依赖到指定文件夹的步骤说明》为了方便开发和部署,我们常常需要将Python项目所依赖的第三方包导出到本地文件夹中,:本文主要介绍Pythonpip下载包及所有依... 目录步骤说明命令格式示例参数说明离线安装方法注意事项总结要使用pip下载包及其所有依赖到指定文件夹,请按照以

SQL中JOIN操作的条件使用总结与实践

《SQL中JOIN操作的条件使用总结与实践》在SQL查询中,JOIN操作是多表关联的核心工具,本文将从原理,场景和最佳实践三个方面总结JOIN条件的使用规则,希望可以帮助开发者精准控制查询逻辑... 目录一、ON与WHERE的本质区别二、场景化条件使用规则三、最佳实践建议1.优先使用ON条件2.WHERE用

Linux链表操作方式

《Linux链表操作方式》:本文主要介绍Linux链表操作方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、链表基础概念与内核链表优势二、内核链表结构与宏解析三、内核链表的优点四、用户态链表示例五、双向循环链表在内核中的实现优势六、典型应用场景七、调试技巧与

Java Multimap实现类与操作的具体示例

《JavaMultimap实现类与操作的具体示例》Multimap出现在Google的Guava库中,它为Java提供了更加灵活的集合操作,:本文主要介绍JavaMultimap实现类与操作的... 目录一、Multimap 概述Multimap 主要特点:二、Multimap 实现类1. ListMult

Python中文件读取操作漏洞深度解析与防护指南

《Python中文件读取操作漏洞深度解析与防护指南》在Web应用开发中,文件操作是最基础也最危险的功能之一,这篇文章将全面剖析Python环境中常见的文件读取漏洞类型,成因及防护方案,感兴趣的小伙伴可... 目录引言一、静态资源处理中的路径穿越漏洞1.1 典型漏洞场景1.2 os.path.join()的陷

Python使用Code2flow将代码转化为流程图的操作教程

《Python使用Code2flow将代码转化为流程图的操作教程》Code2flow是一款开源工具,能够将代码自动转换为流程图,该工具对于代码审查、调试和理解大型代码库非常有用,在这篇博客中,我们将深... 目录引言1nVflRA、为什么选择 Code2flow?2、安装 Code2flow3、基本功能演示

Spring中管理bean对象的方式(专业级说明)

《Spring中管理bean对象的方式(专业级说明)》在Spring框架中,Bean的管理是核心功能,主要通过IoC(控制反转)容器实现,下面给大家介绍Spring中管理bean对象的方式,感兴趣的朋... 目录1.Bean的声明与注册1.1 基于XML配置1.2 基于注解(主流方式)1.3 基于Java

Python中OpenCV与Matplotlib的图像操作入门指南

《Python中OpenCV与Matplotlib的图像操作入门指南》:本文主要介绍Python中OpenCV与Matplotlib的图像操作指南,本文通过实例代码给大家介绍的非常详细,对大家的学... 目录一、环境准备二、图像的基本操作1. 图像读取、显示与保存 使用OpenCV操作2. 像素级操作3.

Mysql中的用户管理实践

《Mysql中的用户管理实践》:本文主要介绍Mysql中的用户管理实践,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录13. 用户管理13.1 用户 13.1.1 用户信息 13.1.2 创建用户 13.1.3 删除用户 13.1.4 修改用户