【Mysql】修改definer
修改definer
本文介绍如何修改MySQL中的function、procedure、event、view和trigger的definer
修改function、procedure的definer
首先,我们需要登录MySQL命令行界面,然后执行以下命令:
select definer from mysql.proc;
这个命令会列出所有的function和procedure,同时显示它们的definer。如果要修改definer,可以执行以下命令:
update mysql.proc set definer='user@localhost';
其中,user@localhost可以是任何合法的用户名和主机名,表示只有这个用户才能访问数据库。
修改event的definer
如果要修改event的definer,可以执行以下命令:
select DEFINER from mysql.EVENT;
这个命令会列出所有的event,并显示它们的definer。如果要修改definer,可以执行以下命令:
update mysql.EVENT set definer='user@localhost';
修改view的definer
如果要修改view的definer,可以使用以下命令:
select DEFINER from information_schema.VIEWS;
如果只是想查询指定的数据库的,需要加一个条件
select DEFINER from information_schema.VIEWS table_schema = 'test_rex';
这个命令会列出所有的view,并显示它们的definer。如果要修改definer,可以执行以下命令:
select concat("alter DEFINER=`user`@`localhost` SQL SECURITY DEFINER VIEW ", TABLE_SCHEMA, ".", TABLE_NAME, " as ", VIEW_DEFINITION, ";") from information_schema.VIEWS where DEFINER = 'user@localhost';
这个命令会查询出需要修改的VIEW,并生成修改语句,如下所示:
alter DEFINER=`user`@`localhost` SQL SECURITY DEFINER VIEW mydb.myview as select * from mytable;
执行这条修改语句即可完成修改。
这里有一个细节,需要注意下,就是我第一次写成了如下,结果mysql会自动再拼接上@%,导致结果是吧definer改成了 user@localhost@%
alter DEFINER='user@localhost' SQL SECURITY DEFINER VIEW mydb.myview as select * from mytable;
修改trigger的definer
目前还没有找到具体方便的方法来修改trigger的definer。可以借助工具端如HeidiSQL、sqlyog等来一个个修改。需要注意的是,在修改trigger的definer之前,需要先锁表,以避免在修改过程中出现数据不一致的情况。
总结
本文介绍了如何修改MySQL中的function、procedure、event、view和trigger的definer。通过修改definer,您可以更好地控制数据库的访问权限,保证数据库的安全性。需要注意的是,在修改definer之前,需要先备份数据,以防修改出现错误。同时,在执行修改操作时,也需要谨慎操作,以免造成不可逆的损失。
相关文章:
【Mysql】修改definer
修改definer 本文介绍如何修改MySQL中的function、procedure、event、view和trigger的definer 修改function、procedure的definer 首先,我们需要登录MySQL命令行界面,然后执行以下命令: select definer from mysql.proc;这个命令会列出所…...
图片预览插件vue-photo-preview的使用
移动端项目中需要图片预览的功能,但本身使用mintui,vantui中虽然也有,但是为了一个组件安装这个有点儿多余,就选用了vue-photo-preview插件实现(其实偷懒也不想自己写)。 1、安装 npm i vue-photo-preview…...
最强自动化测试框架Playwright(20)- iframe
一个页面可以附加一个或多个 Frame 对象。每个页面都有一个主框架,并且假定页面级交互(如)在主框架中运行。click frame_locator 使用 iframe 时,可以创建一个框架定位器,该定位器将进入 iframe 并允许选择该 iframe…...
leetcode 516. 最长回文子序列(JAVA)题解
题目链接https://leetcode.cn/problems/longest-palindromic-subsequence/description/?utm_sourceLCUS&utm_mediumip_redirect&utm_campaigntransfer2china 目录 题目描述: 暴力递归: 动态规划: 题目描述: 给你一个…...
在Java中操作Redis(详细-->从环境配置到代码实现)
在Java中操作Redis 文章目录 在Java中操作Redis1、介绍2、Jedis3、Spring Data Redis3.1、对String的操作3.2、对哈希类型数据的操作3.3、对list的操作3.4、对set类型的操作3.5、对 ZSet类型的数据(有序集合)3.6、通用类型的操作 1、介绍 Redis 的Java客…...
分布式作业调度框架——ElasticJob
1、简介 ElasticJob 是面向互联网生态和海量任务的分布式调度解决方案,由两个相互独立的子项目 ElasticJob-Lite 和 ElasticJob-Cloud 组成。 它通过弹性调度、资源管控、以及作业治理的功能,打造一个适用于互联网场景的分布式调度解决方案,…...
react如何实现数据渲染
React数据渲染是指将组件中的数据映射到页面上,以展示出来。在React中,数据渲染通常是通过JSX和组件的state或props完成的。 JSX是一个类似HTML的语法,可以在其中嵌入JavaScript表达式。在JSX中,可以使用{}包裹JavaScript表达式&…...
在Java中如何使用List集合实现分页,以及模糊查询后分页
物理分页工具类 package com.yutu.garden.utils;import com.baomidou.mybatisplus.core.toolkit.CollectionUtils;import java.util.ArrayList; import java.util.List; import java.util.stream.Collectors;/*** ClassName: PageUtils* Description: 物理分页* Author* Date …...
【JAVA】包装类、正则表达式、Arrays类、Lambda表达式
1 包装类 包装类是8种基本数据类型对应的引用类型 作用:后期的集合和泛型不支持基本类型,只能使用包装类 基本数据类型和其对应的引用数据类型的变量可以互相赋值 基本数据类型引用数据类型 byte Byte short Short int Integer long Long ch…...
Java中的Maven Assembly插件是什么?
Maven Assembly插件是Maven中的一个插件,用于创建自定义的构建过程。它允许你在构建过程中执行一些自定义的操作,例如打包、编译、复制文件等。对于新手来说,Maven Assembly插件可能有点复杂,但是我们可以使用一些幽默的方式来解释…...
SpringBoot禁用Swagger3
Swagger3默认是启用的,即引入包就启用。 <dependency><groupId>io.springfox</groupId><artifactId>springfox-boot-starter</artifactId><version>3.0.0</version> </dependency> <dependency><groupId…...
小红书Java后端2023-8-6笔试
小红书推荐系统 时间限制:3000MS;内存限制:589824KB 题目描述 小红书有一个推荐系统,可以根据用户搜索的关键词推荐用户希望获取的内容。现在给定小孩的搜索记录(记录是分词后的结果),我们认…...
metaRTC7 demo mac/ios编译指南
概要 metaRTC7.0开始全面支持mac/ios操作系统,新版本7.0.023 mac os demo 包含有srs/zlm的推拉流演示。发布版自带了x64版第三方类库,arm版第三方类库还需开发者自己编译。 源码下载 下载文件metartc7.023.7z https://github.com/metartc/metaRTC/re…...
systemd-journal 占用内存的问题
最近发现部分 Debian 机器的 systemd-journal 占用了非常多内存。这和 Debian 对其的 错误配置有关系(查了一下其他发行版,有和 Debian 一样的配置的也有和 Debian 不一样 的配置的,说明这个配置有争议)。 systemd-journal 简介 …...
Java # Spring(2)
一、Spring事物 一、分类 编程式事物:代码中硬编码(不推荐使用) 声明式事物:配置文件中配置(推荐使用) 分类: 基于xml的声明式事物基于注解的声明式事物 二、隔离级别 ISOLATION_DEFAULT&…...
2021年03月 C/C++(二级)真题解析#中国电子学会#全国青少年软件编程等级考试
第1题:石头剪刀布 石头剪刀布是常见的猜拳游戏。石头胜剪刀,剪刀胜布,布胜石头。如果两个人出拳一样,则不分胜负。 一天,小A和小B正好在玩石头剪刀布。已知他们的出拳都是有周期性规律的,比如:“…...
应用程序运行报错:First section must be [net] or [network]:No such file or directory
应用程序报错环境: 在linux下,调用darknet训练的模型,报错:First section must be [net] or [network]:No such file or directory,并提示:"./src/utils.c:256: error: Assertion 0 failed." 如…...
【ECMAScript】ES6-ES11学习笔记
文章目录 注意事项1.声明变量2.定义常量3.解构赋值4.模板字符串5.简化对象写法6.箭头函数7.参数默认值8.rest参数9.扩展运算符10.Symbol11.生成器函数12.Promise基本语法13.集合set14.Map15.类class16.数值扩展17.对象私有属性18.对象方法扩展19.js文件模块化20.async和await21…...
K8S MetalLB LoadBalancer
1. 简介 kubernetes集群没有L4负载均衡,对外暴漏服务时,只能使用nodePort的方式,比较麻烦,必须要记住不同的端口号。 LoadBalancer:使用云提供商的负载均衡器向外部暴露服务,外部负载均衡器可以将流量路由…...
kubernetes二进制部署2之 CNI 网络组件部署
CNI 网络组件部署 一:K8S提供三大接口1容器运行时接口CRI2云原生网络接口CNI3云原生存储接口CSI 部署 flannelK8S 中 Pod 网络通信:Overlay Network:VXLAN:Flannel:Flannel udp 模式的工作原理:ETCD 之 Flannel 提供说…...
专业付费墙突破技术:5个高效解决方案完整指南
专业付费墙突破技术:5个高效解决方案完整指南 你是否在为付费墙而烦恼?想要获取优质内容却被各种限制困扰?今天我将为你详细介绍5种专业的付费墙突破技术,帮助你在合法范围内更好地获取所需信息。本文仅用于技术研究和学习目的&am…...
**Pandas实战进阶:用“链式操作+自定义函数”重构数据清洗流程,效率提升3倍不止!**在日常数据分析中,我
Pandas实战进阶:用“链式操作自定义函数”重构数据清洗流程,效率提升3倍不止! 在日常数据分析中,我们常遇到这样的场景:从原始CSV文件加载数据后,需要进行多步清洗——缺失值填充、类型转换、去重、分组聚合…...
Java 微服务弹性模式:构建高可用分布式系统
Java 微服务弹性模式:构建高可用分布式系统今天我们来聊聊 Java 微服务中的弹性模式,这是构建高可用分布式系统的核心能力。一、为什么需要弹性模式 在分布式系统中,故障是不可避免的。网络延迟、服务宕机、资源耗尽等问题随时可能发生。如果…...
Youtu-VL-4B-Instruct生产环境:银行柜台业务凭证OCR+合规字段校验流水线
Youtu-VL-4B-Instruct生产环境:银行柜台业务凭证OCR合规字段校验流水线 1. 引言 想象一下,银行柜员每天要处理成百上千张业务凭证——开户申请书、转账单、存款凭条。每一张都需要人工核对姓名、身份证号、金额、日期等关键信息,确保填写规…...
Qwen-Image-2512-Pixel-Art-LoRA高清展示:1024×1024输出+RGB精准色彩还原实测
Qwen-Image-2512-Pixel-Art-LoRA高清展示:10241024输出RGB精准色彩还原实测 想不想亲手创造出那种充满复古魅力的像素艺术?那种让你瞬间回到童年游戏机时代的画面,现在用AI就能轻松搞定。今天,我们就来深度实测一个专门为像素艺术…...
Navicat找回历史执行记录突然失效怎么办_重置与缓存清理
Navicat历史记录消失是因异常退出导致history.db处于WAL日志不一致或事务未提交状态,并非数据被删;需关闭所有实例、备份并重命名history.db及相关文件后重启,新记录将重新生成。Navicat 历史执行记录消失,history.db 文件还在但不…...
前端-Node.js
1. 什么是Node.jsNode.js是一个跨平台JavaScript运行环境,使开发者可以搭建服务器端的JavaScript应用程序。作用:使用Node.js编写服务端程序。编写数据接口,提供网页资源浏览功能等等。前端工程化:为后续学习Vue和React等框架做铺…...
Bypass Paywalls Chrome Clean:突破付费内容壁垒的高效浏览器扩展
Bypass Paywalls Chrome Clean:突破付费内容壁垒的高效浏览器扩展 在信息爆炸的数字时代,优质内容常被付费墙阻隔,学术文献、深度报道和专业期刊的访问限制成为知识获取的主要障碍。Bypass Paywalls Chrome Clean作为一款开源浏览器扩展&…...
DDD难落地?就让AI干吧! - cleanddd-skills介绍儆
AI训练存储选型的演进路线 第一阶段:单机直连时代 早期的深度学习数据集较小,模型训练通常在单台服务器或单张GPU卡上完成。此时直接将数据存储在训练机器的本地NVMe SSD/HDD上。 其优势在于IO延迟最低,吞吐量极高,也就是“数据离…...
超流体真空理论:光速本质、微观粒子结构与量子纠缠拓扑机制
摘要本文基于超流体真空理论框架,揭示狭义相对论洛伦兹变换的物理本源,诠释光速不变的底层形成机制,明确微观基本粒子的真空结构起源;同时提出原创性量子纠缠拓扑结构模型,定义纠缠传态的速度极限与物理机制࿰…...
