ChatGPT 提高工作效率-一例SQL编写的过程
ChatGPT 提高工作效率-一例SQL编写的过程
前言
遇到一个问题, 怀疑是有一些补丁没有被依赖.
导致第一次更新时没有更新这些没依赖的补丁.
后面更新时又更新了这些游离态的补丁.
导致出现 old 文件 覆盖 new 文件
出现程序问题.
一个补丁还好着, 但是所有的补丁去检查就比较麻烦了.
所以想写出一个SQL来.
问题是 此处设计到了 3张表,
一张信息表, 一张依赖关系表, 一张发布时间表
自己SQL能力非常菜鸡. 所以在贵文老师的帮助下使用了ChatGPT提高了编写效率.
所以想记录一下. 科学技术的确是生产力
思路
1. 主要是要获取所有模块最后一个发布的补丁列表
2. 查询所有没有被依赖信息的已发布补丁信息.
3. 基于2再删除1的结果, 获取如下内容:
不是该模块最后一个已发布, 并且没有依赖关系的补丁
ChatGPT的讲解
考虑到上一步的场景1
应该需要使用窗口函数进行查询
但是自己的窗口函数处理能力基本上等于 0 语法都不熟悉
所以打开如下网站:https://chat.aidutu.cn/
我问的:
SQLSERVER 查询 多分组情况下 每个分组的最后一个记录
ChatGPT答复的
您可以使用子查询和窗口函数来实现按多个分组列对结果进行分组,并且获取每个分组的最后一个记录。下面是一种可能的解决方案:
sql
SELECT *
FROM (
SELECT
*,
ROW_NUMBER() OVER (PARTITION BY col1, col2 ORDER BY id DESC) as rn
FROM your_table
) t
WHERE rn = 1;
基于ChatGPT的讲解编写自己的SQL
解释:
首先在 FROM 子句中使用子查询,以便在内部查询中计算每个分组的最后一个记录。这个查询返回以下列:
col1、col2 和所有你需要的其他列,作为 GROUP BY 的参数。
id,作为分组内的排序列,并按降序排列,意味着第一行就是最后一行。
将这个子查询封装在外面的 SELECT 语句中,它过滤了每个分组中只包含 ID 最大的行。如果某个分组有多个相同的 ID,则该查询将返回其中任何一个。
总之,这个查询将返回每个分组的最后一个记录,即每个不同于其它分组的唯一组合。
自己编写的SQL就为:
SELECT
patchcode
FROM
xxxx.patchinfo
WHERE
patchid NOT IN ( SELECT deppatchid FROM xxxx.patchdepinfo )
AND patchstate = 'PUBLISHED'
AND patchid NOT IN (
SELECT
patchid
FROM
(
SELECT
*,
ROW_NUMBER ( ) OVER ( PARTITION BY patchmodule ORDER BY publishtime DESC ) AS rn
FROM
(
SELECT
a.patchid,
a.patchcode,
a.patchmodule,
b.publishtime
FROM
LCBM9999.patchinfo a
INNER JOIN LCBM9999.PATCHPUBLISHED b ON a.patchid = b.patchid
) w
) t
WHERE
rn = 1
) order by patchcode asc
感想
ChatGPT 的确是生产力工具
能够让我这种SQL菜鸡实现一定程度的高级SQL编写能力.
感觉的确会对IT数从业人员产生巨大的挑战.
需要不停的学习. 比机器人更能思考,更能创造价值才可以利于不败之地.
学会的东西可能明天就是废纸了. 但是必须得有获取新知识,新方向的能力.
ChatGPT 提高工作效率-一例SQL编写的过程的更多相关文章
- paip.提高工作效率--数据绑定到table原则和过程Angular js jquery实现
paip.提高工作效率--数据绑定到table原理和流程Angular js jquery实现 html #--keyword 1 #---原理和流程 1 #----jq实现的代码 1 #----- ...
- 可提高工作效率的 PL/SQL Developer 设置
1.将Window List 列表展示出来并保存当前布局 ①Tools-->Windows List (展示窗口列表) ②Window-->Save Layout (保存当前布局) 2.设 ...
- 倍数提高工作效率的 Android Studio 奇技
来源:JeremyHe 链接:http://zlv.me/posts/2015/07/13/14_android-studio-tips/ 这是从Philippe Breault的系列文章<An ...
- [转]倍数提高工作效率的 Android Studio 奇技
转自:http://android.jobbole.com/81687/ 倍数提高工作效率的 Android Studio 奇技 2015/10/08 · 技术分享 · 4 评论· Android S ...
- 15款提高工作效率的 Web 项目管理工具
在今天的快节奏的商业世界里,能够通过计划.组织.和管理资源池以及评估开发资源的模式来管理一个项目,是一个很艰巨的任务. 有很多现成的项目管理软件来帮助减轻项目管理的负担,并且他们几乎覆盖了所有类型的业 ...
- 美国一家科技公司毕威拓(Pivotal)规定员工在早上9点06分准时上班,以提高工作效率。
美国一家科技公司毕威拓(Pivotal)规定员工在早上9点06分准时上班,以提高工作效率. 据<英国广播公司BBC>报道,美国科技公司毕威拓(Pivotal)的员工每天都要在9点06分准时 ...
- 巧用Excel提高工作效率
程序员如何巧用Excel提高工作效率 主要讲解下Excel中VLOOKUP函数的使用,相比于上一篇中的内容,个人觉得这个相对高级一些. 1.使用背景 为什么会使用到这个函数呢,背景是这样的,有两个系统 ...
- 怎样使用ListView实现一个带有网络请求,解析,分页,缓存的公共的List页面来大大的提高工作效率
在寻常的开发中常常会有非常多列表页面.每做一个列表页就须要创建这个布局文件那个Adapter适配器文件等等一大堆与之相关的附属的不必要的冗余文件. 假设版本号更新迭代比較频繁,如此以往,就会使项目pr ...
- 使用并行ssh提高工作效率
我们经常需要ssh到多个主机上执行相同的命令,为了提高效率,我们通常会自己写个脚本,循环遍历执行我们的命令,比如: for host in `cat hosts.txt`;do ssh usernam ...
- Android Studio in OSX 提高工作效率的快捷键
前言 本篇文章参考了<倍数提高工作效率的Android Studio>一文,快捷键基于OS X系统. OS X Yosemite 10.10.5 Android Studio 1.3.1 ...
随机推荐
- Windows使用docker踩坑记录
一.安装踩坑 安装时会让你选择:是否使用Windows容器 Use Windows containers instead of Linux containers(this can be changed ...
- Linux系统快速入门(完整版)
LINUX基础知识 I.Linux概述 linux是啥? 一套免费使用和自由传播的类Unix操作系统,是一个基于POSIX和Unix的多用户.多任务.支持多线程和多CPU的操作系统.它能运行主要的Un ...
- 【Pandas】groupby连用的count()和size()的区别
groupby连用的count()和size()的区别 count() 计算的是 value(数值): size() 计算的是 size(个数) 我们有以下表: size() age = df.gro ...
- 实战案例丨GaussDB for DWS如何识别坏味道的SQL
摘要:SQL中的坏味道,你知道吗? SQL语言是关系型数据库(RDB)的标准语言,其作用是将使用者的意图翻译成数据库能够理解的语言来执行.人类之间进行交流时,同样的意思用不同的措辞会产生不同的效果. ...
- 大数据场景下Volcano高效调度能力实践
摘要:本篇文章将会从Spark on Kubernetes 发展历程以及工作原理,以及介绍一下Spark with Volcano,Volcano如何能够帮助 Spark运行地更高效. Spark o ...
- 如何给MindSpore添加一个新的硬件后端?快速构建测试环境!
摘要:介绍如何给MindSpore添加一个新的硬件后端. 本文分享自华为云社区<如何给MindSpore添加一个新的硬件后端?快速构建测试环境!>,原文作者:HWCloudAI. Mind ...
- TS数据类型:从C++/Java/Python到TS看元组tuple—元组的来龙去脉
在C++有Java这种强类型语言中,常用的Array.List.Set ,在集合中只能是一种类型(可以复习下:<再谈Java数据结构-分析底层实现与应用注意事项). int data[] = n ...
- Python 获取控制台输入的值
获取控制台输入参数 if __name__ == '__main__': while 1: question = input('用户:') answer = "你的问题是:" + ...
- 断点续传(上传)C#版
断点续传(上传)Java版 1. 客户每次上传前先获取一下当前文件已经被服务器接受了多少 2. 上传时设定偏移量 服务端代码如下: /// <summary> /// 断点续传,获取已上传 ...
- 【django-vue】celery延迟任务、定时任务 django中使用celery 秒杀功能 双写一致性 首页轮播图定时更新 课程前端页面
目录 上节回顾 字符编码 django-redis 今日内容 1 celery 执行异步任务,延迟任务,定时任务 延时任务 定时任务 2 django中使用celery 2.1 秒杀功能 2.1.1 ...