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

提升团队工程交付能力,从“看见”工程活动和研发模式开始

作者:张裕、雅纯

理想中的研发团队应当具有以下特征:

  • 总是工作在最高优先级的事项上

    理想的研发团队能够识别并始终集中精力在当前最紧迫和最有价值的任务上。这需要团队具备出色的项目管理能力和决策能力,以便能够正确评估优先级,做出合理的工作分配,并快速适应项目需求的变化。

  • 各个角色既能专注于自身的专业工作,又能彼此高效协同

    每个团队成员都应当是各自领域的专家,并且全身心投入到他们擅长和负责的工作当中。然而,这并不意味着他们仅限于个体工作。一个理想的研发团队鼓励跨学科合作,通过敏捷的沟通机制和共享的工具,确保信息能够顺畅地在团队成员之间流通。团队中的设计师、工程师、产品经理和其他角色之间应当存在协同工作的文化,这样的多元化合作能够促进创新思维,并最终导致更高质量的产品开发。

  • 团队和个体的技术和工程能力能持续改进

    理想研发团队不仅在现有技术上精通,而且持续追求技术和专业技能的提升。这意味着个人和团队都应该鼓励创新和实验,并且能做到快速试错、快速反馈。同时,团队应该有制度鼓励个人在工作中尝试新方法和技术,这种文化不仅有助于团队的长期成长,也有助于吸引和保留那些富有好奇心和热情于学习新事物的人才。

一个拥有如上特质的研发团队更有可能成功地完成复杂的项目,创造创新的产品,并在竞争激烈的市场环境中获得成功。

团队工程交付的常见问题

要成为上面所述的优秀研发团队确实需要付出巨大的努力和持续的改进。在追求理想状态的过程中,以下三个问题经常成为阻碍团队达到理想特质的障碍:

1)信息传递失真: 团队内部成员来自不同的专业背景,使用的术语和概念也各不相同。例如,开发说发布一个应用,运维说对一个服务做变更,但他俩说的其实是同一件事情。在日常协作中,需要将这些信息从一个领域转换到另一个领域,并确保信息不丢失、不扭曲。如果处理不当,就会导致团队成员对项目的理解出现偏差,从而影响决策和执行。为了解决这个问题,可以通过建立统一的概念模型、使用共享的术语库、提供跨部门交流培训和使用相同的工具平台等方式来减少信息传递过程中的失真。

2)流程没有连接: 尽管每个研发阶段内部可能已经实现了自动化和高效的运作,但是当一个项目或需求从一个阶段转移到另一个阶段时,往往缺乏流畅的衔接。举个例子,有的企业开发人员和测试人员属于不同的职能团队,开发人员提交代码后,自动会触发代码的构建、静态检查、单元测试等环节,但到了功能测试阶段,开发人员需要手动填写提测单,在提测单里写上代码版本、单测结果、静态检查结果、部署方式等,由测试人员线下确认后,再流转到功能测试阶段。这种阶段间的断层通常需要依赖于团队成员之间的线下沟通和非正式协议,这容易造成流程上的混乱和效率低下。要打破这些障碍,团队可以尝试引入端到端的研发管理工具和流程,确保流程的透明化和自动化,从而形成一个无缝连接的、整体的研发流程。

3)无法识别重点: 当团队同时处理多个项目和需求时,工程活动可能会分散在不同的工具和平台上。这种分散导致团队成员很难追踪整体的进展,也难以判断哪些任务是当前的重点。信息的碎片化使得团队难以集中注意力在最紧迫的需求上。解决这个问题的关键在于建立统一的研发管理系统,按研发任务聚合工程活动,实时展示各个任务的状态和优先级。此外,定期的回顾会议和优先事项的重新评估也是确保团队能够集中精力在最有价值的工作上的重要做法。

总结来说,成为一个优秀的研发团队不仅需要专业技能的不断提升,而且还需要针对信息流通、流程衔接和重点识别等方面的问题进行系统的解决方案设计和实施。通过持续的努力,优秀的团队可以逐步克服这些拦路虎,走向成熟和效能的最高标准。

因此,改进的第一步是要能看见工程活动和研发模式,进而识别其中存在的问题。

统一工程交付的概念模型

为了有效解决信息传递失真、流程不连贯等问题,确保信息的流畅传递和流程的无缝连接是至关重要的。这就要求从根本上统一工程交付的概念模型,使所有参与者——无论是开发人员、测试人员、产品经理还是任何其他相关方——都拥有共同的理解框架。

在解决这些问题的过程中,云效联合产学研各界于 2022 年发布了 BizDevOps白皮书, 该白皮书提出了 BizDevOps 完整的概念模型,通过该模型,可以更清晰地界定和管理研发生命周期中的各个环节。

图片

具体到模型本身,它将业务需求、产品需求、变更请求定义为时标对象,这些时标对象在时间轴上代表了需求的生成和变更的发生。每一个变更请求都与特定的应用相关联,而应用就是变更请求所属的空间或上下文。这样,工程交付的核心概念就被简化为两个主要元素:应用和变更请求。此外,还包括了应用的一些重要附属属性,例如变更内容、环境、部署编排和研发变更流程等。这些属性共同描述了从需求提出到最终部署的完整过程。

通过应用这个核心概念,工程侧能够高效地聚合研发资产和研发流程,形成一个集中的管理点。这有助于优化资源分配,提高研发效率,同时也有助于跟踪和度量研发过程中的关键指标。

另一方面,变更请求作为时标对象,承担了连接不同研发活动和项目协作的关键角色。通过对变更请求的跟踪和管理,团队可以确保所有的活动都围绕着实现具体的业务目标进行,同时使得整个工程交付过程更加透明和可控。

综上所述,这个模型不仅为团队成员之间的沟通提供了共同的语言,还为整个研发周期的管理提供了一套清晰的指南,从而使得各个环节能够紧密协作,确保研发活动能够高效、有序地进行。

定义应用交付的模式

拥有了统一的概念模型后,我们得以实现对研发资产和流程的系统化规范和高效管理。具体来看:

图片

1)基于应用将研发资产和研发流程有效地规范和管理起来: 我们为此构建了一套标准化模板,旨在帮助团队对应用的研发资产和流程进行全面梳理。这个模板涵盖的内容包括但不限于:

a. 应用相关角色及其权限: 定义每个涉及应用开发的角色(如开发人员、测试工程师、产品经理等)以及它们相对于应用的权限,确保权限的分配既满足安全要求又促进工作效率。

b. 应用的代码和制品: 明确代码库管理和制品库的使用,以及不同角色在代码提交、审核、制品生成和存储过程中的职责和权限。

c. 应用的分支模式: 规定了源代码管理中各种分支的使用场景和规范,以及不同分支对应角色的职责,确保代码的版本管理既清晰又高效。

d. 应用端到端的研发流程: 详细描述了从开发任务的启动到产品的最终上线,涉及的所有阶段和流水线,包括每个阶段的具体任务、责任分配、准入和准出标准,以及阶段间的衔接方法。

e. 应用的环境及其与角色的对应关系: 梳理各种环境(如开发环境、测试环境、生产环境)的配置和用途,以及各个环境中不同角色的责任和权限。

图片

2)基于变更请求将产品需求和开发任务端到端地连接起来: 与上面的静态资产和流程管理相比较,这里更侧重于需求到上线这一动态的研发流程。

a. 创建变更请求: 这一流程的第一步通常是将产品需求转化为技术任务,即变更请求,这些变更请求直接属于相应的应用。

b. 指定变更范围: 变更请求的创建过程中,会指定其变更范围,通常指定为某个代码库的特性分支。开发人员在此分支上进行代码提交,触发应用的研发流程。

c. 执行研发流程: 随着研发流程的展开,变更请求会逐渐通过各个阶段,特性分支也可能会被合并到集成分支或发布分支。每个阶段的执行频率可能不同,一般情况下,越接近流程的末端,执行的次数就越少。

d. 完成变更: 当变更请求成功通过最后一个阶段,它就被视为完成。同理,一个产品需求所对应的所有变更请求一旦全部完成,那么这个产品需求也就可以宣布完成或者发布上线。

基于云效平台的落地方法

我们强烈建议在落地工程交付实践之前,先把需求协作实践梳理清楚,关于这一块内容,推荐参考:如何制定科学有效的需求流程规范。

接下来,我们会借助云效平台,按照前面章节的示例,定义应用的交付模式,并按照该交付模式完成一个产品需求交付的完整流程。

4.1 通过应用模板定义应用交付模式

我们通过应用模板来承载团队的工程交付模式,这里我们以前面提到过的基于 feature 的持续交付模式为例。

该交付模式的特点是开发、测试均基于特性分支,集成发布均基于主干分支,属于快速开始,快速集成,快速交付,推崇单个特性的独立开发、独立测试、独立集成于独立交付。

首先,在云效 appstack 上创建一个名为“特性驱动的持续交付模板”的应用模板。

图片

在该模板上开启“变更 + 研发流程”服务。

图片

按照 feature/master 两阶段的研发流程,为这两个阶段分别定义变量组,在变量组中使用不同的 k8s namespace,以及指定不同的副本数。

图片

接下来通过模板来规范应用的部署方式,云效推崇多套环境一套编排模板的实践,差异性的部分通过变量组来定义。

图片

然后,我们规定每个应用都有两套环境,分别为用于 feature 开发验证的“特性验证环境”,和用于集成发布的“生产部署环境”。这两套环境与对应的变量组、部署编排和集群资源(可选)关联。

图片

我们已经确定了应用的环境和部署策略,接下来我们规范应用的研发交付流程。

我们要求应用从开始开发到完成交付,需要经过特性验证和生产部署两个阶段的验证,且只有经过特性验证阶段的 feature,才能进行生产部署。为了做到这一点,我们创建了一个两阶段的研发流程,分别为特性验证阶段和生产部署阶段。

在特性验证阶段,我们定义了一条包含 4 个步骤的流水线,分别为代码检视、构建、部署和测试,且规定分支为自由选择方式(可在流水线配置名称前缀为 feature- 的分支有新的代码提交自动触发)。

图片

在生产部署阶段,我们配置了一条有 5 个步骤的流水线,分别为代码检视、构建、审核、部署和完成变更。同时限制流水线运行分支为 master,且执行时相关 feature 在特性验证阶段的执行结果为成功(云效会自动计算流水线执行时所涉及到的 feature 分支,并判断其前序阶段的执行成功与否)。

图片

至此,我们完成了应用模板的定义,现在,让我们基于该模板来创建一个应用,并完成一个特性的交付。

图片

通过应用模板创建好应用后,还需要设置好应用所关联的代码仓库和相关成员。

图片

图片

4.2 分析产品需求,拆解变更请求

假设我们接到一个产品需求,需要将查询服务接入风控,避免爬虫攻击。为此,我们为 risk-control-srv 拆解了一个变更请求,并关联到该产品需求上。

图片

4.3 在变更分支上提交代码,进行持续验证

由于设置了代码提交至 feature 分支自动触发特性验证阶段的执行,每次在 feature 上 push 代码后,都会自动进行验证并给出反馈。

图片

4.4 通过代码评审合并变更分支,进入生产部署

图片

当代码评审通过并合并入 master 分支后,会自动触发生产部署阶段的执行。

图片

4.5 完成变更,进而完成产品需求

生产部署阶段执行完成后,变更请求会变为已完成状态,同时其对应的产品需求也会自动进入已完成状态。

图片

图片

后记

本文从统一工程交付的概念模型开始,介绍了如何将应用交付的模式显式地定义出来,并通过工具平台落地。但需注意,团队的工程交付实践往往不存在标准解,我们都是在寻求当前场景下的最优解。在具体的场景下,团队的工程交付受到协作机制和技术水平的双重制约,因此需要我们把视角从工程交付本身跳出来,结合协作、技术一起来看,并持续优化和改进,才能找到适合我们自身团队的最佳实践模式。

相关文章:

提升团队工程交付能力,从“看见”工程活动和研发模式开始

作者:张裕、雅纯 理想中的研发团队应当具有以下特征: 总是工作在最高优先级的事项上 理想的研发团队能够识别并始终集中精力在当前最紧迫和最有价值的任务上。这需要团队具备出色的项目管理能力和决策能力,以便能够正确评估优先级&#xff0…...

前端学习之DOM编程案例:全选反选案例

代码 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>全选反选</title> </head> <body><input type"checkbox" id"all">全选<ul><li><…...

golang map

1.底层实现 2.如何解决hash冲突 3.扩容机制 4.无序 5.非线程安全 6.不可寻址 runtime/map.go 1.底层实现 底层基于hash表实现&#xff0c;实现有2个结构体hmap&#xff0c;bmap&#xff0c;map由若干个桶存储&#xff0c;每个桶存8个元素&#xff0c;使用链地址解决hash冲突 …...

设计模式:享元模式案例

让我们以游戏开发中的棋类游戏&#xff08;例如国际象棋&#xff09;为例来展示享元模式的代码实现。在这个例子中&#xff0c;棋子的类型是内部状态&#xff0c;而棋子的位置是外部状态。 Java 代码示例 import java.util.HashMap; import java.util.Map;// 享元接口 interf…...

pandas(day5)

一. 检测重复值 1.1 检测 data pd.read_csv("./teacher/订单数据.csv")检测行与行之前是否有重复值 data.drop_duplicates()检测 列是否有重复值出现&#xff0c; keep first 从前往后判定 &#xff0c; last是从后往前判定data.drop_duplicates(subset["产…...

如何注册midjourney账号

注册Midjourney账号比较简单&#xff0c;准备好上网工具&#xff0c;进入官网 Midjourney访问地址&#xff1a; https://www.midjourney.com/ 目前没有免费使用额度了&#xff0c;会员最低 10 美元/月&#xff0c;一般建议使用30美元/月的订阅方案。了解如何订阅可以查看订阅…...

探索数据结构:特殊的双向队列

✨✨ 欢迎大家来到贝蒂大讲堂✨✨ &#x1f388;&#x1f388;养成好习惯&#xff0c;先赞后看哦~&#x1f388;&#x1f388; 所属专栏&#xff1a;数据结构与算法 贝蒂的主页&#xff1a;Betty’s blog 1. 双向队列的定义 **双向队列(double‑ended queue)**是一种特殊的队列…...

16_I2C库函数

I2C库函数 1.void I2C_DeInit(I2C_TypeDef* I2Cx);2.void I2C_Init(I2C_TypeDef* I2Cx, I2C_InitTypeDef* I2C_InitStruct);3.void I2C_StructInit(I2C_InitTypeDef* I2C_InitStruct);4.void I2C_Cmd(I2C_TypeDef* I2Cx, FunctionalState NewState);5.void I2C_DMACmd(I2C_Type…...

十八、Rust gRPC 多 proto 演示

十八、Rust gRPC 多 proto 演示 网上及各官方资料&#xff0c;基本是一个 proto 文件&#xff0c;而实际项目&#xff0c;大多是有层级结构的多 proto 文件形式&#xff0c;本篇文章 基于此诉求&#xff0c;构建一个使用多 proto 文件的 rust grpc 使用示例。 关于 grpc 的实现…...

【Linux】Linux64位环境下编译32位报错skipping incompatible的解决办法

本文首发于 ❄️慕雪的寒舍 问题 如题&#xff0c;当我尝试在wsl2的ubuntu中使用-m32选项编译32位程序的时候&#xff0c;出现了下面的两种报错 ❯ g -m32 test.cpp -o test1 && ./test1 In file included from test.cpp:1: /usr/include/stdio.h:27:10: fatal error…...

vue指令v-model

<!DOCTYPE html> <html lang"en"> <head> <meta charset"UTF-8"> <meta name"viewport" content"widthdevice-width, initial-scale1.0"> <title>vue指令v-model</title> </head>…...

CentOS安装MySQL数据库

一、更新yum源 #下载对应repo文件 wget -O CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-8.repo #清除缓存 yum clean all #生成新缓存 yum makecache #更新 yum update -y 二、安装MySQL #获取源 wget http://repo.mysql.com/mysql80-community-release-el7-3.…...

从B2B转向B2B2C模式:工业品牌史丹利百得的转型历程

图片来源&#xff1a;Twitter 在当今数据驱动的营销环境中&#xff0c;企业努力更好了解客户&#xff0c;并在整个客户旅程中提供个性化体验。史丹利百得&#xff08;Stanley Black & Decker&#xff09;是一家领先的工具和工业设备供应商&#xff0c;近年来开始重大转型。…...

Redis群集模式和rsync远程同步

一、Redis群集模式 1.1 概念 1.2 作用 1.2.1 Redis集群的数据分片 1.2.2 Redis集群的主从复制模型 1.3 搭建Redis 群集模式 1.3.1 开启群集功能 1.3.2 启动redis节点 1.3.3 启动集群 1.3.4 测试群集 二、rsync远程同步 2.1 概念 2.2 同步方式 2.3 备份的方式 2.4…...

JAVA—抽象—定义抽象类Converter及其子类WeightConverter

同样&#xff0c;我们由这道题引出抽象类&#xff0c;抽象方法这个概念。 按下面要求定义类Converter及其子类WeightConverter 定义抽象类&#xff1a;Converter&#xff1a; 定义一个抽象类Converter&#xff0c;表示换算器&#xff0c;其定义的如下&#xff1a; 一个私有…...

面对复杂多变的网络攻击,企业应如何守护网络安全

企业上云&#xff0c;即越来越多的企业把业务和数据&#xff0c;迁移到云端。随着云计算、大数据、物联网、人工智能等技术的发展&#xff0c;用户、应用程序和数据无处不在&#xff0c;企业之间的业务边界逐渐被打破&#xff0c;网络攻击愈演愈烈&#xff0c;手段更为多。 当前…...

计算机网络练习-计算机网络概述与性能指标

计算机网络概述 ----------------------------------------------------------------------------------------------------------------------------- 1. 计算机网络最据本的功能的是( )。 1,差错控制 Ⅱ.路由选择 Ⅲ,分布式处理 IV.传输控制 …...

vite vue3 ts import.meta在vscode中报错

问题描述&#xff1a;开发使用的框架为vitevue3ts&#xff0c;在开发过程中莫名其妙报仅当“--module”选项为“es2020”、“esnext”或“系统”时才允许使用“import.meta”元属性 问题解决&#xff1a; 通过更改tsconfig.json的module为esnext&#xff0c;es2022等&#xff0…...

Java synchronized(详细)

​ synchronized 一&#xff0c;介绍 在Java中&#xff0c;synchronized关键字用于解决多线程并发访问共享资源时可能出现的线程安全问题。当多个线程同时访问共享资源时&#xff0c;如果没有合适的同步机制&#xff0c;可能会导致以下问题&#xff1a; 竞态条件&#xff08…...

算法设计与分析实验报告python实现(排序算法、三壶谜题、交替放置的碟子、带锁的门)

一、 实验目的 1&#xff0e;加深学生对算法设计方法的基本思想、基本步骤、基本方法的理解与掌握&#xff1b; 2&#xff0e;提高学生利用课堂所学知识解决实际问题的能力&#xff1b; 3&#xff0e;提高学生综合应用所学知识解决实际问题的能力。 二、实验任务 1、排序算法…...

实训问题总结——ajax用get可以成功调用controller方法,用POST就出404错误

因为传输密码时必须用POST。 还有用GET传输参数&#xff0c;说有非法字符&#xff0c;想试试POST是否可以解决。 404错误的三个大致原因&#xff0c;1&#xff1a;找不到对的请求路径&#xff0c;2&#xff1a;请求方式错误&#xff0c;3、请求参数错误。 后来可以调用了。但…...

1、认识MySQL存储引擎吗?

目录 1、MySQL存储引擎有哪些&#xff1f; 2、默认的存储引擎是哪个&#xff1f; 3、InnoDB和MyISAM有什么区别吗&#xff1f; 3.1、关于事务 3.2、关于行级锁 3.3、关于外键支持 3.4、关于是否支持MVCC 3.5、关于数据安全恢复 3.6、关于索引 3.7、关于性能 4、如何…...

微信小程序媒体查询

在微信小程序中&#xff0c;media媒体查询不支持screen关键字&#xff0c;因为小程序页面是再webview中渲染的&#xff0c;而不是在浏览器中渲染的。 在设置样式时&#xff0c;可以使用 wxss 文件中的 media 规则来根据屏幕宽度或高度设置不同的样式。 device-width:设备屏幕…...

前端(动态雪景背景+动态蝴蝶)

1.CSS样式 <style>html, body, a, div, span, table, tr, td, strong, ul, ol, li, h1, h2, h3, p, input {font-weight: inherit;font-size: inherit;list-style: none;border-spacing: 0;border: 0;border-collapse: collapse;text-decoration: none;padding: 0;margi…...

软考-系统集成项目管理中级-新一代信息技术

本章历年考题分值统计 本章重点常考知识点汇总清单(掌握部分可直接理解记忆) 本章历年考题及答案解析 32、2019 年上半年第 23 题 云计算通过网络提供可动态伸缩的廉价计算能力&#xff0c;(23)不属于云计算的特点。 A.虚拟化 B.高可扩展性 C.按需服务 D.优化本地存储 【参考…...

【卷积神经网络进展】

打基础日常记录 CNN基础知识1. 感知机2. DNN 深度神经网络&#xff08;全连接神经网络&#xff09;DNN 与感知机的区别DNN特点&#xff0c;全连接神经网络DNN前向传播和反向传播 3. CNN结构【提取特征分类】4. CNN应用于文本 CNN基础知识 1. 感知机 单层感知机就是一个二分类…...

yarn的安装和使用

windows mac 环境 yarn的安装和使用 yarn安装 npm install -g yarnyarn设置代理 yarn config set registry https://registry.npm.taobao.org -gyarn官方源 yarn config set registry https://registry.yarnpkg.comyarn使用 // 查看板本 yarn --version// 安装指定包 yarn…...

Golang | Leetcode Golang题解之第10题正则表达式匹配

题目&#xff1a; 题解&#xff1a; func isMatch(s string, p string) bool {m, n : len(s), len(p)matches : func(i, j int) bool {if i 0 {return false}if p[j-1] . {return true}return s[i-1] p[j-1]}f : make([][]bool, m 1)for i : 0; i < len(f); i {f[i] m…...

【Leetcode】top 100 图论

基础知识补充 1.图分为有向图和无向图&#xff0c;有权图和无权图&#xff1b; 2.图的表示方法&#xff1a;邻接矩阵适合表示稠密图&#xff0c;邻接表适合表示稀疏图&#xff1b; 邻接矩阵&#xff1a; 邻接表&#xff1a; 基础操作补充 1.邻接矩阵&#xff1a; class GraphAd…...

【沈阳航空航天大学】 <C++ 类与对象计分作业>

C类与对象 1. 设计用类完成计算两点距离2. 设计向量类3. 求n!4. 出租车收费类的设计与实现5. 定义并实现一个复数类6. 线性表类的设计与实现7. 数组求和8. 数组求最大值 1. 设计用类完成计算两点距离 【问题描述】设计二维点类Point&#xff0c;包括私有成员&#xff1a;横坐标…...

青岛网站平台开发/广告网络推广

点击上方“Github爱好者社区”&#xff0c;选择星标回复“资料”&#xff0c;获取小编整理的一份资料大家好&#xff0c;我是GG哥。今天推荐的这个项目是「list-of-wechat-mini-program-list」&#xff0c;开源微信小程序列表的列表、有赚钱能力的小程序开源代码。这个项目分为…...

科普网站建设的支持力度/网站托管服务商

一、先安装npm 教程如下链接&#xff1a; 安装npm教程&#xff1a;https://www.cnblogs.com/lgx5/p/10732016.html 每天进步多一点 感谢分享&#xff0c;介绍的非常详细的教程。。。 二、安装cnpm 1. 打开cmd 输入&#xff1a; $ npm install -g cnpm --registryhttps://re…...

wordpress 301定向/怎么在百度打广告

舵机 舵机是一种位置伺服的驱动器&#xff0c;主要是由外壳、电路板、无核心马达、齿轮与位置检测器所构成。其工作原理是由接收机或者单片机发出信号给舵机&#xff0c;其内部有一个基准电路&#xff0c;产生周期为 20ms&#xff0c;宽度为 1.5ms 的基准信号&#xff0c;将获…...

一键抓取的网站怎么做/苏州百度推广公司

span默认是行属性&#xff0c;而div默认是块属性。 对行内元素&#xff08;不包括可替换元素如img等&#xff09;&#xff1a; 1. 设置宽度width 无效。 2. 设置高度height无效&#xff0c;可以通过line-height来设置高度。 3. 设置margin只有左右margin有效&#xff0c;上下无…...

建设企业网站企业网上银行官网官方/广告联盟点击赚钱平台

题目&#xff1a;原题链接&#xff08;中等&#xff09; 标签&#xff1a;SQL 解法时间复杂度空间复杂度执行用时Ans 1 (Python)341ms (42.83%)Ans 2 (Python)Ans 3 (Python) 解法一&#xff1a; SELECT Name FROM Candidate WHERE id IN(SELECT CandidateIdFROM (SELECT Ca…...

网站制作小常识/百度云网盘资源链接

前言程序员平时和mysql打交道一定不少&#xff0c;可以说每天都有接触到&#xff0c;但是mysql一张表到底能存多少数据呢&#xff1f;计算根据是什么呢&#xff1f;接下来咱们逐一探讨知识准备数据页在操作系统中&#xff0c;我们知道为了跟磁盘交互&#xff0c;内存也是分页的…...