当前位置: 首页 > news >正文

企业级SQL开发:如何审核发布到生产环境的SQL性能

自从上世纪 70 年代数据库开始普及以来,DBA 们就不停地遭遇各种各样的数据库管理难题,其中最为显著的,可能就是日常的开发任务中,研发人员们对于核心库进行变更带来的一系列风险。由于针对数据库的数据变更是一项非常常见的任务,几乎所有开发者都会涉及对核心数据库的结构、数据内容的修改,如果企业缺乏有效的数据安全方案,就可能导致一系列严重的问题,例如:

  • 删库跑路:没有比这更坏的情况了,笔者知道的实际事件就有好几起,例如某大型房产中介的员工,登录财务系统删除了所有财务数据,直接影响了公司人员的工资发放;又例如某云端商业营销解决方案集团企业,整个数据库被删除,导致集团损失数亿。此类事件不胜枚举,谁也无法预测明天会发生什么,如果没有完善的对策,灾难就可能降临。

近些年,删库跑路事件频发

  • 数据泄露:如果公司是我家,那毫无疑问,业务数据就是家里的金库,因为其中包含了大量的敏感信息,如客户的个人身份信息、财务数据、商业机密等。如果没有任何数据安全方案,那无疑就是我家大门常打开(参考索尼一年一度的数据泄露事件),一旦遭遇数据泄露,遭殃的可不仅仅只有公司了,客户那头都够喝一壶的,由此带来的法律责任和声誉问题也不是所有企业都能扛得住的。

因此,在变更 SQL 实际应用到数据库之前,SQL 的审核成为了一项至关重要的任务,需要确保数据库结构和数据的变更是合理、安全、符合规范的。

在此向大家隆重推荐一款数据库管理产品:NineData SQL 任务。

这是一个有效的审核 SQL 变更的解决方案,提供了一系列完善的规范和审批流程,给每一条变更 SQL 设置了层层关卡,包括基于智能化算法,以及 SQL 开发规范的系统预检,以及多级审批功能。

简单介绍一下 NineData SQL 任务

  • 预制的超百条 SQL 审核规范:NineData 平台提供了完整的库表结构定义规范、索引规范等,帮助企业内所有开发人员规范使用和变更数据库。

  • 定时SQL自动化执行:SQL 任务允许用户设置定时执行 SQL 操作,从而自动完成一系列数据库变更任务。有助于提高效率,特别是对于重复性的、计划性的任务。

  • 企业协同数据变更:SQL 任务功能支持多用户协同进行数据变更,通过审批流程和权限管理,不同团队成员可以有序地提交、审批和执行 SQL 任务,确保变更的有序进行,避免冲突和错误。

  • SQL 权限校验:SQL 任务具备权限校验机制,只有具有足够权限的用户才能提交和执行 SQL 任务,防止未授权的操作,加强对数据库的访问控制。

  • 审批流程联动:SQL 任务功能集成了审批流程,确保对 SQL 任务的提交和执行进行逐级审批。这种联动的审批流程可以在变更管理中提供额外的安全层,确保变更可追溯。

  • 自动数据备份:在您通过 SQL 任务对目标数据源执行更改之前,系统会自动对即将被变更的数据进行数据备份,并保留 7 天时间,在 7 天时间内,您可以随时下载该备份并将数据恢复到变更前的状态,相当于为您的数据提供了一道安全屏障,无需再畏惧数据安全问题。

  • 回滚预案填写:随着企业对数据安全与合规性要求的不断提高,数据回滚预案变得不可或缺,因此我们提供了回滚 SQL 填写入口,填写后会永久记录在当前 SQL 任务中,可以在数据出现问题时随时查看并回滚数据。

为了更加一目了然,简单演示一下 SQL 任务的能力

  • 步骤一:禁用生产库的 SQL 窗口变更能力

图片

禁用生产库的 SQL 窗口变更能力

关闭后尝试 SQL 窗口执行变更语句,语句被拦截,无法执行。

图片

尝试SQL窗口执行变更后语句语句被拦截

  • 步骤二:通过 SQL 任务发布变更

图片

使用NineData通过SQL任务发布变更

为演示 SQL 任务的整体流程,录屏中配置了单级审批。您可以根据实际需求,灵活配置审批流程,要求 SQL 任务在执行之前,通过多级审批,确保每个变更都经过适当的审核和授权。

  • 步骤三:审批 SQL 任务

图片

使用NineData审批 SQL 任务

这里可以根据实际情况驳回或通过 SQL 变更的请求。

后记

自从公司引入 NineData 这个产品,发生了好几个积极的变化。

首先是最明显的一个变化,由于 SQL 任务的预审机制,让我这个曾经的背锅侠彻底解放,由于数据库变更可能带来的潜在风险,让我整天压力山大,年纪轻轻老态龙钟,而现在头发也不掉了,人也精神了,自信又回来了。就在前不久,我们公司一个新人程序员由于业务不熟悉,为了给表加一个字段,他的操作居然是 DROP 原表,还好让 SQL 任务给拦了下来,不然我这个 DBA 好卷铺盖走人了。

然后就是 NineData SQL 任务的多级审批机制为我们的团队协作带来了更高效的保障。以前,由于变更 SQL 的责任不够明确,经常会导致沟通不畅,审批流程混乱。而现在,不仅审批流程更加透明准确,同时也提高了团队协作的效率。相关负责人也能够更清晰地了解每个 SQL 变更的具体内容,减少了误解和错误的发生。

最后,严重推荐这款产品,如果你也想和我一样年轻帅气,那信我的准没错!

相关文章:

企业级SQL开发:如何审核发布到生产环境的SQL性能

自从上世纪 70 年代数据库开始普及以来,DBA 们就不停地遭遇各种各样的数据库管理难题,其中最为显著的,可能就是日常的开发任务中,研发人员们对于核心库进行变更带来的一系列风险。由于针对数据库的数据变更是一项非常常见的任务&a…...

linux 手动安装移植 haveged,解决随机数初始化慢的问题

文章目录 1、问题描述2、安装 haveged3、问题解决4、将安装好的文件跟库移植到开发板下 Haveged是一个软件工具,用于生成高质量的熵(Entropy)源,以供计算机系统使用。熵在计算机科学中指的是一种随机性或不可预测性的度量&#xf…...

如何使用llm 制作多模态

首先将任何非字符的序列信息使用特殊n个token 编码。 具体编码方法以图像为例子说明: 将固定尺寸图像如256256 的图像分割为1616 的子图像块。 将已知的所有图像数据都分割后进行str将其看做是一个长的字符,而后去重后方式一个词表。 使用特殊1024 个tok…...

k8s(二):Pod

Pod pod 是K8s中最小的可部署单元,用于容纳一个或多个容器。Pod为容器提供了一个共享的环境,包括网络命名空间、存储卷和IP地址。 pod的阶段(phase) Pending: Pod 已被 Kubernetes 系统接受,但有一个或者多个容器尚未创建亦未运行。此阶段包…...

Python 字典详解(dict)

文章目录 1 概述1.1 性质 2 常用方法2.1 以列表返回所有键:keys()2.2 以列表返回所有值:values()2.3 以列表返回所有键值对:items()2.4 返回键对应的值:get()2.5 添加键值对:setdefault()2.6 修改键值对:di…...

IPoIB在国产并行系统上的实现与优化

目录 1 国产异构众核系统 2 相关工作 3 IPoIB在国产并行系统上的实现 3.1 IPoIB协议原理...

东南大学与OpenHarmony携手共建开源生态,技术俱乐部揭牌成立并迎来TSC专家进校园

11月25日,OpenAtom OpenHarmony(以下简称“OpenHarmony”)项目群技术指导委员会(以下简称“TSC”)与东南大学携手,于东南大学九龙湖校区金智楼一楼报告厅举办了“东南大学OpenHarmony技术俱乐部成立仪式暨OpenHarmony TSC专家进校园”活动。此次盛会标志着OpenHarmony开源社区和…...

NPU、CPU、GPU算力及算力计算方式

NVIDIA在9月20日发布的NVIDIA DRIVE Thor 新一代集中式车载计算平台,可在单个安全、可靠的系统上运行高级驾驶员辅助应用和车载信息娱乐应用。提供 2000 万亿次浮点运算性能(2000 万亿次8位浮点运算)。NVIDIA当代产品是Orin,算力是…...

华清远见嵌入式学习——C++——作业6

作业要求&#xff1a; 代码&#xff1a; #include <iostream>using namespace std;class Animal { public:virtual void perform() 0;};class Lion:public Animal { private:string foods;string feature; public:Lion(){}Lion(string foods,string feature):foods(foo…...

k8s安装学习环境

目录 环境准备 配置hosts 关闭防火墙 关闭交换分区 调整swappiness参数 关闭setlinux Ipv4转发 时钟同步 安装Docker 配置Yum源 安装 配置 启动 日志 安装k8s 配置Yum源 Master节点 安装 初始化 配置kubectl 部署CNI网络插件 Node节点 检查 环境准备 准…...

RepidJson将内容写入文件简单代码示例

以下是使用RapidJSON将内容写入文件的示例代码&#xff1a; #include <rapidjson/document.h> #include <rapidjson/writer.h> #include <rapidjson/stringbuffer.h> #include <iostream> #include <fstream>using namespace rapidjson;int mai…...

golang构建docker镜像的几种方式

目前docker支持以下几种方式指定上下文来构建镜像 本地项目路径&#xff08;如&#xff1a;/tmp/xxx&#xff09;本地压缩包路径&#xff08;如&#xff1a;/tmp/xxx.tar&#xff09;docekrfile文本链接&#xff08;如&#xff1a;https://x.com/xxx/dockerfile&#xff09;压…...

golang使用sip协议 用户名和密码注册到vos3000

在Go语言中&#xff0c;要使用SIP协议进行注册&#xff0c;您可以使用第三方库&#xff0c;如github.com/cloudwebrtc/sip。以下是一个简单的示例代码&#xff0c;演示如何使用Go语言中的该库进行基本的SIP注册&#xff1a; 首先&#xff0c;您需要安装该库&#xff1a; go ge…...

第4章 互联网

文章目录 4.1 计算机网络基础 94 4.1.1 计算机网络的基本概念 94 4.1.2 局域网的基本原理 96 4.1.3 局域网协议与应用 98 4.2 Internet 100 4.2.1 TCP/IP 101 4.2.2 TCP/IP应用 106 4.2.3 网络操作系统的功能 112 4.2.4 网络安全的概念 116 4.3 计算机软件编程基础 …...

【JavaWeb】前端工程化(VUE3)

前端工程化&#xff08;VUE3&#xff09; 文章目录 前端工程化&#xff08;VUE3&#xff09;一、概述二、ECMA6Script2.1 es6的变量和模板字符串2.2 es6的解构表达式2.3 es6的箭头函数2.4 rest和spread2.5 es6的对象创建和拷贝2.6 es6的模块化处理 三、前端工程化环境搭建3.1 N…...

JAVA基础知识:异常处理

异常处理是Java编程中至关重要的一部分&#xff0c;它允许程序在出现错误或异常情况时进行适当的处理&#xff0c;以保证程序的稳定性和可靠性。本文将详细介绍Java中的异常处理机制&#xff0c;并提供相关示例代码&#xff0c;帮助读者更好地理解和应用异常处理的概念和技巧。…...

PostGIS学习教程十:空间索引

PostGIS学习教程十&#xff1a;空间索引 回想一下&#xff0c;空间索引是空间数据库的三个关键特性之一。空间索引使得使用空间数据库存储大型数据集成为可能。在没有空间索引的情况下&#xff0c;对要素的任何搜索都需要对数据库中的每条记录进行"顺序扫描"。索引通…...

LeetCode 13 罗马数字转整数

题目描述 罗马数字转整数 罗马数字包含以下七种字符: I&#xff0c; V&#xff0c; X&#xff0c; L&#xff0c;C&#xff0c;D 和 M。 字符 数值 I 1 V 5 X 10 L 50 C 100 D 500 M …...

【动态规划】LeetCode2111:使数组 K 递增的最少操作次数

作者推荐 [二分查找]LeetCode2040:两个有序数组的第 K 小乘积 本文涉及的基础知识点 二分查找算法合集 分组 动态规划 题目 给你一个下标从 0 开始包含 n 个正整数的数组 arr &#xff0c;和一个正整数 k 。 如果对于每个满足 k < i < n-1 的下标 i &#xff0c;都有…...

SpringCloud面试题——Nacos

一&#xff1a;什么是Nacos&#xff1f; 二&#xff1a;服务心跳与服务注册原理&#xff1f; 在spring容器启动的时候&#xff0c;nacos客户端会进行两步操作。 向nacos服务端发送心跳向nacos服务端注册当前服务 服务心跳 客户端在启动的时候&#xff0c;会开启一个心跳线程…...

华为云AI开发平台ModelArts

华为云ModelArts&#xff1a;重塑AI开发流程的“智能引擎”与“创新加速器”&#xff01; 在人工智能浪潮席卷全球的2025年&#xff0c;企业拥抱AI的意愿空前高涨&#xff0c;但技术门槛高、流程复杂、资源投入巨大的现实&#xff0c;却让许多创新构想止步于实验室。数据科学家…...

谷歌浏览器插件

项目中有时候会用到插件 sync-cookie-extension1.0.0&#xff1a;开发环境同步测试 cookie 至 localhost&#xff0c;便于本地请求服务携带 cookie 参考地址&#xff1a;https://juejin.cn/post/7139354571712757767 里面有源码下载下来&#xff0c;加在到扩展即可使用FeHelp…...

【ROS】Nav2源码之nav2_behavior_tree-行为树节点列表

1、行为树节点分类 在 Nav2(Navigation2)的行为树框架中,行为树节点插件按照功能分为 Action(动作节点)、Condition(条件节点)、Control(控制节点) 和 Decorator(装饰节点) 四类。 1.1 动作节点 Action 执行具体的机器人操作或任务,直接与硬件、传感器或外部系统…...

Mobile ALOHA全身模仿学习

一、题目 Mobile ALOHA&#xff1a;通过低成本全身远程操作学习双手移动操作 传统模仿学习&#xff08;Imitation Learning&#xff09;缺点&#xff1a;聚焦与桌面操作&#xff0c;缺乏通用任务所需的移动性和灵活性 本论文优点&#xff1a;&#xff08;1&#xff09;在ALOHA…...

Pinocchio 库详解及其在足式机器人上的应用

Pinocchio 库详解及其在足式机器人上的应用 Pinocchio (Pinocchio is not only a nose) 是一个开源的 C 库&#xff0c;专门用于快速计算机器人模型的正向运动学、逆向运动学、雅可比矩阵、动力学和动力学导数。它主要关注效率和准确性&#xff0c;并提供了一个通用的框架&…...

10-Oracle 23 ai Vector Search 概述和参数

一、Oracle AI Vector Search 概述 企业和个人都在尝试各种AI&#xff0c;使用客户端或是内部自己搭建集成大模型的终端&#xff0c;加速与大型语言模型&#xff08;LLM&#xff09;的结合&#xff0c;同时使用检索增强生成&#xff08;Retrieval Augmented Generation &#…...

代码随想录刷题day30

1、零钱兑换II 给你一个整数数组 coins 表示不同面额的硬币&#xff0c;另给一个整数 amount 表示总金额。 请你计算并返回可以凑成总金额的硬币组合数。如果任何硬币组合都无法凑出总金额&#xff0c;返回 0 。 假设每一种面额的硬币有无限个。 题目数据保证结果符合 32 位带…...

【Go语言基础【12】】指针:声明、取地址、解引用

文章目录 零、概述&#xff1a;指针 vs. 引用&#xff08;类比其他语言&#xff09;一、指针基础概念二、指针声明与初始化三、指针操作符1. &&#xff1a;取地址&#xff08;拿到内存地址&#xff09;2. *&#xff1a;解引用&#xff08;拿到值&#xff09; 四、空指针&am…...

Python实现简单音频数据压缩与解压算法

Python实现简单音频数据压缩与解压算法 引言 在音频数据处理中&#xff0c;压缩算法是降低存储成本和传输效率的关键技术。Python作为一门灵活且功能强大的编程语言&#xff0c;提供了丰富的库和工具来实现音频数据的压缩与解压。本文将通过一个简单的音频数据压缩与解压算法…...

ArcGIS Pro+ArcGIS给你的地图加上北回归线!

今天来看ArcGIS Pro和ArcGIS中如何给制作的中国地图或者其他大范围地图加上北回归线。 我们将在ArcGIS Pro和ArcGIS中一同介绍。 1 ArcGIS Pro中设置北回归线 1、在ArcGIS Pro中初步设置好经纬格网等&#xff0c;设置经线、纬线都以10间隔显示。 2、需要插入背会归线&#xf…...