企业级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 变更的具体内容,减少了误解和错误的发生。

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/210981.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

对抗生成网络-G与D的loss异常问题

我最近在**使用DCGAN训练个人的数据集**时,出现了D loss 下降趋于0,但是G loss 却不停上升。我总结了一下几点原因: 生成器损失为1或者大于1通常表明生成器的训练可能存在问题,这可能是由于训练不稳定、超参数设置不当或网络结构问…

基于阿里云服务网格流量泳道的全链路流量管理(一):严格模式流量泳道

作者:尹航 概述 灰度发布是一种常见的对新版本应用服务的发布手段,其特点在于能够将流量在服务的稳定版本和灰度版本之间时刻切换,以帮助我们用更加可靠的方式实现服务的升级。在流量比例切换的过程中,我们可以逐步验证新版本服…

【网络奇缘】- 如何自己动手做一个五类|以太网|RJ45|网络电缆

​ ​ 🌈个人主页: Aileen_0v0🔥系列专栏: 一见倾心,再见倾城 --- 计算机网络~💫个人格言:"没有罗马,那就自己创造罗马~" 本篇文章关于计算机网络的动手小实验---如何自己动手做一个网线, 也是为后面的物理层学习进…

C# WPF上位机开发(图形显示软件)

【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing 163.com】 在实际应用中,有一种情况就是,我们需要经常对数据进行图形化显示,这样会比较直观一点。比如经济统计里面的同比…

软件设计之桥接模式

实现茶水间:茶可以分红茶和绿茶,每种茶又可以分大杯和中杯,现在你是服务员需要计算茶水的价格。 package Bridge;public class BlackTea implements TeaKind{private float redTeaPrice 2.0f;Overridepublic float price() {return redTeaPr…

WordPiece词表的创建

文章目录 一、简单介绍二、步骤流程2.1 预处理2.2 计数2.3 分割2.4 添加subword 三、代码实现 本篇内容主要介绍如何根据提供的文本内容创建 WordPiece vocabulary,代码来自谷歌; 一、简单介绍 wordpiece的目的是:通过考虑单词内部构造&…

Canal笔记:安装与整合Springboot模式Mysql同步Redis

官方文档 https://github.com/alibaba/canal 使用场景 学习一件东西前,要知道为什么使用它。 1、同步mysql数据到redis 常规情况下,产生数据的方法可能有很多地方,那么就需要在多个地方中,都去做mysql数据同步到redis的处理&…

2005-2021年地级市绿色发展注意力数据(根据政府报告文本词频统计)

2005-2021年地级市绿色发展注意力数据(根据政府报告文本词频统计) 1、时间:2005-2021年 2、指标:省、市、年份、一级指标、关键词、关键词词频、总词频 3、范围:270个地级市 4、来源:地级市政府工作报告…

深度学习TensorFlow2基础知识学习前半部分

目录 测试TensorFlow是否支持GPU: 自动求导: 数据预处理 之 统一数组维度 定义变量和常量 训练模型的时候设备变量的设置 生成随机数据 交叉熵损失CE和均方误差函数MSE 全连接Dense层 维度变换reshape 增加或减小维度 数组合并 广播机制&#…

CCKS2023-面向金融领域的主体事件检测-亚军方案分享

赛题分析 大赛地址 https://tianchi.aliyun.com/competition/entrance/532098/introduction?spma2c22.12281925.0.0.52b97137bpVnmh 任务描述 主体事件检测是语言文本分析和金融领域智能应用的重要任务之一,如在金融风控领域往往会对公司主体进行风险事件的检测…

杂散表的阅读

杂散表得阅读 —— 以Marki公司得手册为例 混频杂散(Mixing Spurs)是指信号经过混频器时,不仅会与本振混频,还会与本振的高次谐波混频(对于第二章说的方波本振,信号只与本振的奇次谐波混频因为方波只含有奇…

VSC改造MD编辑器及图床方案分享

VSC改造MD编辑器及图床方案分享 用了那么多md编辑器,到头来还是觉得VSC最好用。这次就来分享一下我的blog文件编辑流吧。 这篇文章包括:VSC下md功能扩展插件推荐、图床方案、blog文章管理方案 VSC插件 Markdown All in One Markdown Image - 粘粘图片…

gitLab创建新项目

1.进入git2.选择创建项目3.勾选生成readme.md文件4.邀请成员

【MATLAB源码-第93期】基于matlab的白鲸优化算法(BWO)和鲸鱼优化算法(WOA)机器人栅格路径规划对比。

操作环境: MATLAB 2022a 1、算法描述 白鲸优化算法(BWO) 白鲸优化算法是受到白鲸捕食和迁徙行为启发的一种算法。其主要特点和步骤包括: 1. 搜索食物(全局搜索):算法模仿白鲸寻找食物的行为。…

流媒体音视频/安防视频云平台/可视化监控平台EasyCVR无法启动且打印panic报错,是什么原因?

国标GB视频监控管理平台/视频集中存储/云存储EasyCVR能在复杂的网络环境中,将分散的各类视频资源进行统一汇聚、整合、集中管理,实现视频资源的鉴权管理、按需调阅、全网分发、智能分析等。AI智能大数据视频分析EasyCVR平台已经广泛应用在工地、工厂、园…

分布式搜索引擎(Elastic Search)+消息队列(RabbitMQ)部署

一、分布式搜索引擎:Elastic Search Elastic Search的目标就是实现搜索。是一款非常强大的开源搜索引擎,可以帮助我们从海量数据中快速找到需要的内容。在数据量少的时候,我们可以通过索引去搜索关系型数据库中的数据,但是如果数…

【C++11】线程库/异常

一:线程库 1.1:线程库(thread) 1.1.1:为什么要有线程库 1.1.2:thread库中的成员函数 1.1.3:线程函数参数 1.2:互斥锁(mutex) 1.2.1:为什么要有互斥锁 1.2.2:C11中的互斥锁 1.3:原子操作(atomic) 1.4:条件变…

Apollo新版本Beta技术沙龙

有幸参加Apollo开发者社区于12月2日举办的Apollo新版本(8.0)的技术沙龙会,地址在首钢园百度Apollo Park。由于去的比较早,先参观了一下这面的一些产品,还有专门的讲解,主要讲了一下百度无人驾驶的发展历程和历代产品。我对下面几个…

Java画爱心

Java画爱心代码,每个人都可以被需要 效果图 源代码 package com.example.test; import java.awt.Color; import java.awt.Font; import java.awt.Graphics; import java.awt.Image; import java.awt.Toolkit; import javax.swing.JFrame; class Cardioid extend…

Java+Swing+Mysql实现超市管理系统

一、系统介绍 1.开发环境 操作系统:Win10 开发工具 :IDEA2018 JDK版本:jdk1.8 数据库:Mysql8.0 2.技术选型 JavaSwingMysql 3.功能模块 4.系统功能 1.系统登录登出 管理员可以登录、退出系统 2.商品信息管理 管理员可以对商品信息…