Cursor 使用经验,一个需求开发全流程

软件开发中 Cursor 的使用经验成为关注焦点,尤其是处理大型数据集的需求。用户提到“Cursor 使用经验,一个需求开发全流程”,但“Cursor”可能指数据库游标,涉及逐行处理数据。本文将详细探讨开发一个需求的完整流程,包括需求收集、设计、实现、测试和部署,并结合实际案例和最佳实践,为读者提供全面指导。

本文基于多个权威来源整理了相关信息,包括 MySQL 游标文档、SQL Server 游标文档 和相关行业博客,结合测试人员的实际经验,探讨 Cursor 在开发中的应用。内容包括工具背景、开发流程、社交现象分析和最佳实践,旨在为读者提供一个完整的学习框架。

Cursor 的背景与推测

“Cursor”在编程中可能有多种含义,包括数据库游标、UI 光标或文本编辑中的位置指针。用户提到“一个需求开发全流程”,更可能指数据库游标,常用在 SQL 数据库中,用于遍历结果集,逐行处理数据。由于信息有限,假设“Cursor”指数据库游标,特别是在 SQL Server 或 MySQL 中的应用。

数据库游标是一种机制,允许开发者逐行访问查询结果,适合处理大型数据集,无法一次性加载到内存。例如,在处理客户记录更新忠诚度积分时,游标可逐行读取数据,执行操作。

开发一个需求的完整流程

以下是使用 Cursor 开发一个需求的五步流程,假设需求为“处理客户记录,更新忠诚度积分”:

1. 需求收集
  • 理解需求:确定用户希望系统处理客户记录,更新基于购买历史的忠诚度积分。
  • 数据分析:确认数据量大(如百万条记录),无法一次性加载,需用游标逐行处理。
  • 确认技术栈:选择数据库,如 SQL Server 或 MySQL,确保支持游标功能。

例如,需求可能是“每月自动更新客户忠诚度积分,根据过去12个月的购买金额计算”,数据量大需用游标。

2. 设计
  • 游标类型选择:决定使用哪种游标,如只向前(Forward-only)适合单次遍历,可滚动(Scrollable)适合需要回退的场景。
  • 处理逻辑规划:设计如何打开游标、逐行读取、检查条件(如购买金额>1000元),更新积分,关闭游标。
  • 事务管理:考虑事务隔离级别,确保数据一致性,避免并发问题。
  • 资源管理:规划游标关闭和资源释放,防止内存泄漏。

例如,在 SQL Server 中,设计只向前游标,逐行读取客户记录,计算积分,提交事务后关闭。

3. 实现
  • 编写代码:使用 SQL 或编程语言实现游标操作。以下是 SQL Server 的示例:
    USE AdventureWorks2019;  
    GO  
    -- 创建游标,获取客户记录  
    Declare CustomerCursor CURSOR FOR  
    SELECT CustomerID, PurchaseAmount FROM Sales.Customer WHERE PurchaseAmount > 0;  
    -- 打开游标  
    OPEN CustomerCursor;  
    -- 声明变量  
    Declare @CustomerID int, @PurchaseAmount decimal(10,2), @LoyaltyPoints int;  
    -- 逐行读取  
    Fetch Next From CustomerCursor Into @CustomerID, @PurchaseAmount;  
    While @@FETCH_STATUS = 0  
    Begin  
        -- 计算忠诚度积分,例如每100元1分  
        SET @LoyaltyPoints = @PurchaseAmount / 100;  
        -- 更新客户记录  
        UPDATE Sales.Customer SET LoyaltyPoints = @LoyaltyPoints WHERE CustomerID = @CustomerID;  
        Fetch Next From CustomerCursor Into @CustomerID, @PurchaseAmount;  
    End;  
    -- 关闭和释放游标  
    CLOSE CustomerCursor;  
    DEALLOCATE CustomerCursor;  

  • 注意事项:确保游标正确关闭,防止资源泄漏;考虑批量更新减少事务开销。

4. 测试
  • 小数据集测试:用少量数据验证逻辑正确性,例如10条客户记录,检查积分计算是否准确。
  • 大数据集测试:用大型数据集(如百万条记录)测试性能,确保游标处理高效,无超时。
  • 边缘案例测试:测试空结果集、异常数据(如购买金额为负),确保无错误。
  • 性能监控:监控 CPU、内存使用,确认游标操作不造成瓶颈。

例如,测试发现游标处理100万条记录耗时10分钟,优化后降至5分钟,满足需求。

5. 部署
  • 上线环境:将代码部署到生产数据库,调度任务(如每月运行)。
  • 监控性能:使用工具如 SQL Server Profiler 监控游标执行,确认无性能问题。
  • 日志记录:记录处理结果,如更新了多少记录,方便审计。
  • 异常处理:确保生产环境中能处理异常,如数据库连接中断,自动重试。

例如,部署后每月自动运行,监控发现无瓶颈,满足业务需求。

cursor 支持为项目创建多个 rule,并通过 globs 配置为 rule 指定特定生效的文件或者目录,目前 notta web 已增加了一份全局开发规则,大家感兴趣可以看看,后续若有新建或者调整建议在前端社区做同步,避免带来额外影响。

# Cursor notta web 编码规范指南

你是以下技术栈的专家:
- TypeScript
- Node.js
- React
- Vite
- Rspack
- Ant Design v4
- React Router DOM v6
- lodash-es v4
- chrome extension v3

### 核心原则:

- 编写简洁、技术性的响应,并提供准确的 TypeScript 示例
- 使用函数式、声明式编程,避免使用类
- 优先使用迭代和模块化,而不是代码重复定义
- 使用描述性变量名,包含助动词(如 isLoading)
- 目录使用小写字母加横线(如 components/auth-wizard)
- 组件优先使用命名导出
- 使用接收对象返回对象(RORO)模式

### JavaScript/TypeScript 规范:

- 纯函数使用 "function" 关键字。省略分号
- 所有代码都使用 TypeScript。优先使用接口(interface)而不是类型(type)
- 文件结构:导出组件、子组件、辅助函数、静态内容、类型定义
- 条件语句中避免不必要的大括号
- 单行条件语句省略大括号
- 简单条件语句使用简洁的单行语法(如 if (condition) doSomething())
- 工具函数若 lodash-es 有提供则尽量复用,避免重复定义
- 禁止三元表达式嵌套,使用阅读性更好的条件语句
- if-else 过多时优化为 map 设计

### 错误处理优先级:
- 在函数开始处处理错误和边界情况
- 对错误条件使用提前返回,避免深层嵌套的 if 语句
- 将正常执行路径放在函数末尾以提高可读性
- 避免不必要的 else 语句;使用 if-return 模式
- 使用守卫子句尽早处理前置条件和无效状态
- 实现适当的错误日志记录和用户友好的错误消息
- 考虑使用自定义错误类型或错误工厂以保持错误处理的一致性

### 依赖项:
- React v17
- Ant Design v4
- Rspack
- React Router DOM v6

### React/Next.js 规范:

- 使用函数组件和 TypeScript 接口
- 使用声明式 JSX
- 组件使用 function 而不是 const 声明
- 使用 Ant Design v4 进行组件开发和样式设计
- 采用移动优先的响应式设计方法
- 静态内容和接口放在文件末尾
- 静态内容变量放在渲染函数外
- 最小化 'use client'、'useEffect' 和 'setState' 的使用。优先使用 RSC
- 使用 Suspense 包装客户端组件并提供 fallback
- 非关键组件使用动态加载
- 图片优化:WebP 格式、尺寸数据、懒加载

### 关键约定:

1. 依赖 React Router DOM 进行状态变更
2. 优先考虑 Web Vitals(LCP、CLS、FID)

最佳实践
  • 类型选择:根据需求选择合适游标类型,只向前适合单次遍历,可滚动适合需要回退。
  • 性能优化:批量处理减少事务开销,关闭游标防止资源泄漏。
  • 测试覆盖:覆盖小数据集、大数据集和边缘案例,确保稳定。
  • 文档记录:详细记录游标使用逻辑,方便维护和优化。

在数据驱动决策日益流行的今天,Cursor 的使用反映了效率和可扩展性的追求。就像年轻人热衷“不好好说话”的梗文化,开发者也在追求“偷懒的艺术”——通过游标处理大型数据集,减少内存压力,体现了现代开发对性能优化的重视。尤其在电商、金融等高数据量场景,游标成为标配,测试人员需确保其稳定运行。

一个意料之外的细节是,游标的使用不仅影响性能,还需考虑事务管理和资源释放。例如,游标未正确关闭可能导致数据库连接泄漏,影响系统效率,这超出初学者对游标的预期。

Cursor 使用经验涉及需求开发的全流程,包括需求收集、设计、实现、测试和部署。意料之外的是,事务管理和资源释放需特别注意,影响系统效率。掌握这些技巧,开发者能更高效地处理大型数据集,满足业务需求。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

vue2实现组件库的自动按需引入,unplugin-auto-import,unplugin-vue-components

1.使用ant-design-vue或者element-ui时,如何每个组件都去import导入组件,大大降低了开发效率,如果全局一次性注册会增加项目体积,那么如何实现既不局部引入,也不全局注册? 2.在element-plus官网看到有说明…

蓝桥杯备赛:一道数学题(练思维(同余的应用))

题目:请问由1-8组成的8位数中有多少个数字可以被1111整除? 首先这道题目看着很难,如果我们直接用代码做的话,也要跑很久,那能不呢想想有什么样的思路可以巧妙一点解开这道题目呢? 有的兄弟有的 这道题目的…

[Lc7_分治-快排] 快速选择排序 | 数组中的第K个最大元素 | 库存管理 III

目录 1. 数组中的第K个最大元素 题解 代码 2.库存管理 III 代码 1. 数组中的第K个最大元素 题目链接:215. 数组中的第K个最大元素 题目分析: 给定整数数组 nums 和整数 k,请返回数组中第 k 个最大的元素。 请注意,你需要…

Unity引擎使用HybridCLR(华佗)热更新

大家好,我是阿赵。   阿赵我做手机游戏已经有十几年时间了。记得刚开始从做页游的公司转到去做手游的公司,在面试的时候很重要的一个点,就是会不会用Lua。使用Lua的原因很简单,就是为了热更新。   热更新游戏内容很重要。如果…

【神经网络】python实现神经网络(一)——数据集获取

一.概述 在文章【机器学习】一个例子带你了解神经网络是什么中,我们大致了解神经网络的正向信息传导、反向传导以及学习过程的大致流程,现在我们正式开始进行代码的实现,首先我们来实现第一步的运算过程模拟讲解:正向传导。本次代…

【Linux】冯诺依曼体系与操作系统理解

🌟🌟作者主页:ephemerals__ 🌟🌟所属专栏:Linux 目录 前言 一、冯诺依曼体系结构 二、操作系统 1. 操作系统的概念 2. 操作系统存在的意义 3. 操作系统的管理方式 4. 补充:理解系统调用…

HTML-网页介绍

一、网页 1.什么是网页: 网站是指在因特网上根据一定的规则,使用 HTML 等制作的用于展示特定内容相关的网页集合。 网页是网站中的一“页”,通常是 HTML 格式的文件,它要通过浏览器来阅读。 网页是构成网站的基本元素&#xf…

STM32——GPIO介绍

GPIO(General-Purpose IO ports,通用输入/输出接口)模块是STM32的外设接口的核心部分,用于感知外界信号(输入模式)和控制外部设备(输出模式),支持多种工作模式和配置选项。 1、GPIO 基本结构 STM32F407 的每个 GPIO 引脚均可独立配置,主要特性包括: 9 组 GPIO 端口…

字节码是由什么组成的?

Java字节码是Java程序编译后的中间产物,它是一种二进制格式的代码,可以在Java虚拟机(JVM)上运行。理解字节码的组成有助于我们更好地理解Java程序的运行机制。 1. Java字节码是什么? 定义 Java字节码是Java源代码经过…

链表算法题目

1.两数相加 两个非空链表,分别表示两个整数,只不过是反着存储的,即先存储低位在存储高位。要求计算这两个链表所表示数的和,然后再以相同的表示方式将结果表示出来。如示例一:两个数分别是342和465,和为807…

blender学习25.3.8

【04-进阶篇】Blender材质及灯光Cycle渲染&后期_哔哩哔哩_bilibili 注意的问题 这一节有一个大重点就是你得打开显卡的渲染,否则cpu直接跑满然后渲染的还十分慢 在这里你要打开GPU计算,但是这还不够 左上角编辑,偏好设置,系…

【godot4.4】布局函数库Layouts

概述 为了方便编写一些自定义容器和控件、节点时方便元素布局,所以编写了一套布局的求取函数,统一放置在一个名为Layouts的静态函数库中。 本文介绍我自定义的一些布局计算和实现以及函数编写的思路,并提供完整的函数库代码(持续…

Windows下配置Conda环境路径

问题描述: 安装好Conda之后,创建好自己的虚拟环境,同时下载并安装了Pycharm,但在Pycharm中找不到自己使用Conda创建好的虚拟环境。显示“Conda executable is not found” 解决办法(依次尝试以下) 起初怀…

OpenHarmony子系统开发编译构建指导

OpenHarmony子系统开发编译构建指导 概述 OpenHarmony编译子系统是以GN和Ninja构建为基座,对构建和配置粒度进行部件化抽象、对内建模块进行功能增强、对业务模块进行功能扩展的系统,该系统提供以下基本功能: 以部件为最小粒度拼装产品和独…

leetcode日记(80)复原IP地址

只能说之前动态规划做多了,看到就想到动态规划,然后想想其实完全不需要,回溯法就行了。 一开始用了很多莫名其妙的代码,写的很复杂……(主要因为最后不能加‘.’)其实想想只要最后加入vector时去掉最后一个…

LINUX网络基础 [五] - HTTP协议

目录 HTTP协议 预备知识 认识 URL 认识 urlencode 和 urldecode HTTP协议格式 HTTP请求协议格式 HTTP响应协议格式 HTTP的方法 HTTP的状态码 ​编辑HTTP常见Header HTTP实现代码 HttpServer.hpp HttpServer.cpp Socket.hpp log.hpp Makefile Web根目录 H…

【A2DP】SBC 编解码器互操作性要求详解

目录 一、SBC编解码器互操作性概述 二、编解码器特定信息元素(Codec Specific Information Elements) 2.1 采样频率(Sampling Frequency) 2.2 声道模式(Channel Mode) 2.3 块长度(Block Length) 2.4 子带数量(Subbands) 2.5 分配方法(Allocation Method) 2…

电脑内存智能监控清理,优化性能的实用软件

软件介绍 Memory cleaner是一款内存清理软件。功能很强,效果很不错。 Memory cleaner会在内存用量超出80%时,自动执行“裁剪进程工作集”“清理系统缓存”以及“用全部可能的方法清理内存”等操作,以此来优化电脑性能。 同时,我…

基于multisim的花样彩灯循环控制电路设计与仿真

1 课程设计的任务与要求 (一)、设计内容: 设计一个8路移存型彩灯控制器,基本要求: 1. 8路彩灯能演示至少三种花型(花型自拟); 2. 彩灯用发光二极管LED模拟; 3. 选做…

Axure常用变量及使用方法详解

点击下载《Axure常用变量及使用方法详解.pdf》 摘要 Axure RP 作为一款领先的前端原型设计工具,提供了全面的 变量 和 函数 系统,以支持复杂的交互设计和动态内容展示。本文将从专业角度详细解析 Axure 中的 全局变量、中继器数据集变量/函数、元件变量…