广告
返回顶部
首页 > 资讯 > 数据库 >PostgreSQL 中有哪些钩子函数
  • 993
分享到

PostgreSQL 中有哪些钩子函数

2024-04-02 19:04:59 993人浏览 八月长安
摘要

postgresql 中有哪些钩子函数,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、需求删除数据库pg12db时,只能使用pg12用户

postgresql 中有哪些钩子函数,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

一、需求

删除数据库pg12db时,只能使用pg12用户删除,其他用户(包括超级用户)均不能删除此数据库

二、实现步骤

删除数据库的命令是drop database,属于Utility命令,而PG提供了ProcessUtility_hook钩子可供使用.
实现一个钩子函数,判断sql语句是否为T_DropdbStmt,如是,则判断数据库名称和用户名称是否匹配,如不匹配,则报错,源码如下:

[pg12@localhost hookdemo_dbrestrict]$ cat hookdemo_dbrestrict.c

#include "postgres.h"
#include "miscadmin.h"
#include "tcop/utility.h"
PG_MODULE_MAGIC;
void _PG_init(void);
void _PG_fini(void);
static char *undroppabledb = "pg12db";
static char *hooksuperuser = "pg12";
static ProcessUtility_hook_type prev_utility_hook = NULL;
static void hookdemodbrestrict_ProcessUtility(PlannedStmt *pstmt, const char *queryString,
                          ProcessUtilityContext context, ParamListInfo params,
                          QueryEnvironment *queryEnv,
                          DestReceiver *dest, char *completionTag)
{
    
    switch(nodeTag(pstmt->utilityStmt))
    {   
        case T_DropdbStmt:
        {
            DropdbStmt *stmt = (DropdbStmt *)pstmt->utilityStmt;
            char *username = GetUserNameFromId(GetUserId(),false);
            
            if (strcmp(stmt->dbname, undroppabledb) == 0 &&
                    strcmp(username, hooksuperuser) != 0)
                ereport(ERROR,(errcode(ERRCODE_INSUFFICIENT_PRIVILEGE),errmsg("Only superuser \"%s\" can drop database \"%s\"",hooksuperuser,undroppabledb)));
            break;
        }
        default:
            break;
    }
    
    standard_ProcessUtility(pstmt, queryString, context, params, queryEnv, dest, completionTag);
}

void
_PG_init(void)
{
    prev_utility_hook = ProcessUtility_hook;
    ProcessUtility_hook = hookdemodbrestrict_ProcessUtility;
}

void
_PG_fini(void)
{
    ProcessUtility_hook = prev_utility_hook;
}
[pg12@localhost hookdemo_dbrestrict]$

三、实际效果

创建超级用户superx,使用该用户登录,创建pg12db数据库,删除数据库,报错.

[local:/data/run/pg12]:5120 pg12@testdb=# create user superx with superuser passWord 'root';
CREATE ROLE
[local:/data/run/pg12]:5120 pg12@testdb=# \q
[pg12@localhost pg122db]$ psql -U superx
Expanded display is used automatically.
psql (12.2)
Type "help" for help.
[local:/data/run/pg12]:5120 superx@testdb=# create database pg12db;
CREATE DATABASE
[local:/data/run/pg12]:5120 superx@testdb=# drop database pg12db;
ERROR:  Only superuser "pg12" can drop database "pg12db"
[local:/data/run/pg12]:5120 superx@testdb=#

关于PostgreSQL 中有哪些钩子函数问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注编程网数据库频道了解更多相关知识。

您可能感兴趣的文档:

--结束END--

本文标题: PostgreSQL 中有哪些钩子函数

本文链接: https://www.lsjlt.com/news/58620.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • PostgreSQL 中有哪些钩子函数
    PostgreSQL 中有哪些钩子函数,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、需求删除数据库pg12db时,只能使用pg12用户...
    99+
    2022-10-18
  • python钩子函数的作用有哪些
    Python钩子函数的作用有以下几个: 在特定事件发生时触发执行。钩子函数可以在特定事件发生时被调用,比如在程序启动、关闭、异常...
    99+
    2023-10-24
    python
  • JavaScript钩子函数包括哪些
    JavaScript钩子函数包括以下几种类型: before、after 和 around。before钩子before钩子函数在主函数执行之前执行,它的作用是能够拦截主函数的执行,并对其进行某些前置处理。before钩子的实现方法是在调用...
    99+
    2023-05-14
  • vue的生命周期钩子函数有哪些
    vue的生命周期钩子函数有:1.beforeCreate,对应阶段为创建前;2.created,对应阶段为创建后;3.beforemount,对应阶段为载入前;4.mounted,对应阶段为载入后;5.beforeUpdate,对应阶段为更...
    99+
    2022-10-16
  • textout钩子函数无法触发的原因有哪些
    textout钩子函数无法触发的原因可能有以下几个:1. 钩子函数未正确安装:钩子函数需要通过SetWindowsHookEx函数安...
    99+
    2023-08-19
    textout
  • Vue中钩子函数有什么用
    这篇文章给大家分享的是有关Vue中钩子函数有什么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Vue-Router导航守卫有的时候,我们需要通过路由来进行一些操作,比如最常见的...
    99+
    2022-10-19
  • Vue中钩子函数怎么用
    小编给大家分享一下Vue中钩子函数怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!在Vue 中可以把一系列复杂的操作包装为一...
    99+
    2022-10-19
  • PostgreSQL中heap_insert依赖的函数有哪些
    本篇内容主要讲解“PostgreSQL中heap_insert依赖的函数有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“PostgreSQL中heap_in...
    99+
    2022-10-18
  • vue路由钩子函数是哪几种
    这篇文章主要介绍“vue路由钩子函数是哪几种”,在日常操作中,相信很多人在vue路由钩子函数是哪几种问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue路由钩子函数是哪几种”...
    99+
    2022-10-19
  • vue-router的导航钩子有哪些
    vue-router的导航钩子有:1.全局导航钩子;2.组件内的钩子;3.单独路由独享组。vue-router的导航钩子有三种,分别是:1.全局导航钩子;2.组件内的钩子;3.单独路由独享组,主要是用来拦截导航,让他完成跳转或取消,以下是导...
    99+
    2022-10-06
  • Vue中callHook钩子函数怎么调用
    这篇“Vue中callHook钩子函数怎么调用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue中callHook钩子函数...
    99+
    2023-07-04
  • Vue中钩子函数的示例分析
    这篇文章主要介绍了Vue中钩子函数的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。Vue-Router导航守卫:有的时候,我们需要通...
    99+
    2022-10-19
  • 聊聊vue生命周期钩子函数有哪些,分别什么时候触发
    目录vue生命周期钩子函数以下为详解版生命周期mounted和activated使用、踩坑 activatedmounted踩坑vue生命周期钩子函数 vue生命周期即为一...
    99+
    2022-11-13
  • Vue2.X中钩子函数的示例分析
    这篇文章给大家分享的是有关Vue2.X中钩子函数的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。$route可以在子组件任何地方调用,代表当前路由对象,这个属性是只读的,...
    99+
    2022-10-19
  • Node.js的require函数中如何添加钩子
    本文小编为大家详细介绍“Node.js的require函数中如何添加钩子”,内容详细,步骤清晰,细节处理妥当,希望这篇“Node.js的require函数中如何添加钩子”文章能帮助大家解决疑惑,下面跟着小编...
    99+
    2022-10-19
  • vue中的生命周期及钩子函数
    目录1.什么是生命周期2.vue 的生命周期3.生命周期钩子函数1.什么是生命周期 Vue 实例有一个完整的生命周期,也就是从开始创建、初始化数据、编译模板、挂载 Dom、渲染 &r...
    99+
    2022-11-12
  • 详解JavaScript中的before-after-hook钩子函数
    目录before-after-hook1.单独的钩子2.Hook collectionbefore-after-hook 最近看别人的代码,接触到一个插件,before-after-...
    99+
    2022-12-15
    JavaScript before-after-hook钩子函数 JavaScript before-after-hook JavaScript 钩子函数
  • PostgreSQL中set_base_rel_sizes函数及其子函数案例分析
    本篇内容介绍了“PostgreSQL中set_base_rel_sizes函数及其子函数案例分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况...
    99+
    2022-10-19
  • PostgreSQL中用于计算merge join的Cost函数有哪些
    本篇内容主要讲解“PostgreSQL中用于计算merge join的Cost函数有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“PostgreSQL中用于...
    99+
    2022-10-18
  • Python中Hook钩子函数的作用是什么
    本篇文章为大家展示了Python中Hook钩子函数的作用是什么,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1. 什么是Hook经常会听到钩子函数(hook function)这个概念,最近在看目标...
    99+
    2023-06-15
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作