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

相关文章

python panda库从基础到高级操作分析

《pythonpanda库从基础到高级操作分析》本文介绍了Pandas库的核心功能,包括处理结构化数据的Series和DataFrame数据结构,数据读取、清洗、分组聚合、合并、时间序列分析及大数据... 目录1. Pandas 概述2. 基本操作:数据读取与查看3. 索引操作:精准定位数据4. Group

Python操作PDF文档的主流库使用指南

《Python操作PDF文档的主流库使用指南》PDF因其跨平台、格式固定的特性成为文档交换的标准,然而,由于其复杂的内部结构,程序化操作PDF一直是个挑战,本文主要为大家整理了Python操作PD... 目录一、 基础操作1.PyPDF2 (及其继任者 pypdf)2.PyMuPDF / fitz3.Fre

最新Spring Security的基于内存用户认证方式

《最新SpringSecurity的基于内存用户认证方式》本文讲解SpringSecurity内存认证配置,适用于开发、测试等场景,通过代码创建用户及权限管理,支持密码加密,虽简单但不持久化,生产环... 目录1. 前言2. 因何选择内存认证?3. 基础配置实战❶ 创建Spring Security配置文件

Python对接支付宝支付之使用AliPay实现的详细操作指南

《Python对接支付宝支付之使用AliPay实现的详细操作指南》支付宝没有提供PythonSDK,但是强大的github就有提供python-alipay-sdk,封装里很多复杂操作,使用这个我们就... 目录一、引言二、准备工作2.1 支付宝开放平台入驻与应用创建2.2 密钥生成与配置2.3 安装ali

MySQL 强制使用特定索引的操作

《MySQL强制使用特定索引的操作》MySQL可通过FORCEINDEX、USEINDEX等语法强制查询使用特定索引,但优化器可能不采纳,需结合EXPLAIN分析执行计划,避免性能下降,注意版本差异... 目录1. 使用FORCE INDEX语法2. 使用USE INDEX语法3. 使用IGNORE IND

mybatis-plus QueryWrapper中or,and的使用及说明

《mybatis-plusQueryWrapper中or,and的使用及说明》使用MyBatisPlusQueryWrapper时,因同时添加角色权限固定条件和多字段模糊查询导致数据异常展示,排查发... 目录QueryWrapper中or,and使用列表中还要同时模糊查询多个字段经过排查这就导致只要whe

Python使用openpyxl读取Excel的操作详解

《Python使用openpyxl读取Excel的操作详解》本文介绍了使用Python的openpyxl库进行Excel文件的创建、读写、数据操作、工作簿与工作表管理,包括创建工作簿、加载工作簿、操作... 目录1 概述1.1 图示1.2 安装第三方库2 工作簿 workbook2.1 创建:Workboo

SpringBoot改造MCP服务器的详细说明(StreamableHTTP 类型)

《SpringBoot改造MCP服务器的详细说明(StreamableHTTP类型)》本文介绍了SpringBoot如何实现MCPStreamableHTTP服务器,并且使用CherryStudio... 目录SpringBoot改造MCP服务器(StreamableHTTP)1 项目说明2 使用说明2.1

JAVA覆盖和重写的区别及说明

《JAVA覆盖和重写的区别及说明》非静态方法的覆盖即重写,具有多态性;静态方法无法被覆盖,但可被重写(仅通过类名调用),二者区别在于绑定时机与引用类型关联性... 目录Java覆盖和重写的区别经常听到两种话认真读完上面两份代码JAVA覆盖和重写的区别经常听到两种话1.覆盖=重写。2.静态方法可andro

Ubuntu 24.04启用root图形登录的操作流程

《Ubuntu24.04启用root图形登录的操作流程》Ubuntu默认禁用root账户的图形与SSH登录,这是为了安全,但在某些场景你可能需要直接用root登录GNOME桌面,本文以Ubuntu2... 目录一、前言二、准备工作三、设置 root 密码四、启用图形界面 root 登录1. 修改 GDM 配