news 2026/4/23 11:31:28

关于select所有情况,阿里巴巴的命名是咋样的

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
关于select所有情况,阿里巴巴的命名是咋样的

阿里巴巴 Select 查询命名规范大全

1. 基础命名模式

核心公式:动词 + 名词 + 限定条件 + 返回类型

部分阿里巴巴常用词示例
动词select,find,get,queryselect(最正式)
名词表名或实体名User,Order,Product
限定ByXxx,ByXxxAndYyy,ForXxxById,ByNameAndStatus
返回可省略,或加List,Page,CountList,Page,One,Count

2. 各种场景的具体命名

场景1:单条记录查询

// 根据ID查询UserDOselectById(@Param("id")Longid);UserDOfindById(@Param("id")Longid);UserDOgetById(@Param("id")Longid);// 根据唯一键查询UserDOselectByUsername(@Param("username")Stringusername);UserDOselectByEmail(@Param("email")Stringemail);UserDOselectByMobile(@Param("mobile")Stringmobile);// 查询单个字段值StringselectNameById(@Param("id")Longid);IntegerselectStatusById(@Param("id")Longid);

场景2:列表查询

// 查询所有List<UserDO>selectAll();List<UserDO>findAll();List<UserDO>listAll();// 条件查询列表List<UserDO>selectByStatus(@Param("status")Integerstatus);List<UserDO>selectByDeptId(@Param("deptId")LongdeptId);List<UserDO>selectByNameLike(@Param("name")Stringname);// 多条件查询List<UserDO>selectByStatusAndDeptId(@Param("status")Integerstatus,@Param("deptId")LongdeptId);List<UserDO>selectByCreateTimeBetween(@Param("startTime")DatestartTime,@Param("endTime")DateendTime);

场景3:分页查询

// 分页查询所有Page<UserDO>selectPage(Page<UserDO>page);// 条件分页查询Page<UserDO>selectPageByStatus(Page<UserDO>page,@Param("status")Integerstatus);Page<UserDO>selectPageByCondition(Page<UserDO>page,@Param("condition")UserQueryConditioncondition);

场景4:统计查询

// 计数LongselectCount();Integercount();LongcountAll();// 条件计数LongselectCountByStatus(@Param("status")Integerstatus);LongcountByDeptId(@Param("deptId")LongdeptId);// 存在性检查BooleanexistsByUsername(@Param("username")Stringusername);BooleanexistsByEmail(@Param("email")Stringemail);

场景5:Map格式查询

// 单条MapMap<String,Object>selectAsMapById(@Param("id")Longid);Map<String,Object>selectUserMap(@Param("id")Longid);// 列表MapList<Map<String,Object>>selectListAsMaps();List<Map<String,Object>>selectMapsByStatus(@Param("status")Integerstatus);List<Map<String,Object>>selectAllAsMaps();// 指定字段MapList<Map<String,Object>>selectIdAndNameAsMaps();List<Map<String,Object>>selectSimpleInfoAsMaps();

3. 你的业务场景专用命名

飞行数据相关查询

// 基础查询List<FlightDataDO>selectByFlightRecordId(@Param("flightRecordId")LongflightRecordId);List<FlightDataDO>selectByRecordIdAndType(@Param("recordId")LongrecordId,@Param("dataType")StringdataType);// Map格式List<Map<String,Object>>selectFlightDataAsMaps(@Param("flightRecordId")LongflightRecordId);List<Map<String,Object>>selectHeightDataAsMaps(@Param("flightRecordId")LongflightRecordId);List<Map<String,Object>>selectSpeedDataAsMaps(@Param("flightRecordId")LongflightRecordId);// 统计LongcountByFlightRecordId(@Param("flightRecordId")LongflightRecordId);Map<String,Object>selectStatsByFlightRecordId(@Param("flightRecordId")LongflightRecordId);

告警规则相关查询

// 规则查询List<AlarmRuleDO>selectByConfigId(@Param("configId")LongconfigId);List<AlarmRuleDO>selectEnabledByConfigId(@Param("configId")LongconfigId);List<AlarmRuleDO>selectByConfigIdAndType(@Param("configId")LongconfigId,@Param("ruleType")StringruleType);// Map格式List<Map<String,Object>>selectRulesAsMaps(@Param("configId")LongconfigId);Map<String,List<Map<String,Object>>>selectRulesGroupByType(@Param("configId")LongconfigId);

告警分析业务查询

// 分析相关List<Map<String,Object>>selectForAlarmAnalysis(@Param("configId")LongconfigId,@Param("flightRecordId")LongflightRecordId);List<Map<String,Object>>selectAnalysisResult(@Param("analysisId")StringanalysisId);Page<Map<String,Object>>selectAnalysisHistory(Page<?>page,@Param("query")AnalysisQueryquery);

4. 阿里巴巴内部特殊命名

复杂查询命名

// 联表查询List<UserWithDeptDO>selectUserWithDeptByUserId(@Param("userId")LonguserId);List<Map<String,Object>>selectUserJoinDept(@Param("deptId")LongdeptId);// 嵌套查询List<UserDO>selectWithSubQuery(@Param("minOrderCount")IntegerminOrderCount);// 聚合查询Map<String,Object>selectUserStats(@Param("deptId")LongdeptId);List<Map<String,Object>>selectGroupByDept();// 窗口函数List<Map<String,Object>>selectWithRank(@Param("deptId")LongdeptId);

批量查询命名

// IN查询List<UserDO>selectByIds(@Param("ids")List<Long>ids);List<UserDO>selectByUsernames(@Param("usernames")List<String>usernames);// 批量Map查询List<Map<String,Object>>selectMapsByIds(@Param("ids")List<Long>ids);Map<Long,UserDO>selectMapByIds(@Param("ids")List<Long>ids);// 返回Map结构

5. 阿里巴巴的命名约定俗成

前缀约定

// select 系列(最规范)UserDOselectById(Longid);List<UserDO>selectListByStatus(Integerstatus);// find 系列(查询语义)UserDOfindById(Longid);List<UserDO>findAll();// get 系列(获取语义)UserDOgetById(Longid);List<UserDO>getAll();// query 系列(复杂查询)Page<UserDO>queryPage(UserQueryquery);List<UserDO>queryByCondition(UserConditioncondition);

后缀约定

// List - 返回列表List<UserDO>selectListByDeptId(LongdeptId);// Page - 返回分页Page<UserDO>selectPageByStatus(Page<?>page,Integerstatus);// Count - 返回数量LongselectCountByStatus(Integerstatus);// One - 返回单个UserDOselectOneByUsername(Stringusername);// Map - 返回Map格式Map<String,Object>selectMapById(Longid);List<Map<String,Object>>selectMapListByStatus(Integerstatus);

6. 实战中的最佳实践

原则1:保持一致性

// ✅ 好:统一风格UserDOselectById(Longid);List<UserDO>selectByStatus(Integerstatus);Page<UserDO>selectPage(Page<UserDO>page);// ❌ 不好:风格混乱UserDOgetById(Longid);List<UserDO>findListByStatus(Integerstatus);Page<UserDO>queryPage(Page<UserDO>page);

原则2:方法名自解释

// ✅ 好:清晰明了List<UserDO>selectByDeptIdAndStatus(LongdeptId,Integerstatus);UserDOselectByUsernameAndPassword(Stringusername,Stringpassword);// ❌ 不好:模糊不清List<UserDO>selectUsers(LongdeptId,Integerstatus);// 参数意义不明UserDOselectUser(Stringparam1,Stringparam2);// 参数名无意义

原则3:避免过长

// ✅ 好:适中长度List<UserDO>selectByDeptId(LongdeptId);UserDOselectByUsername(Stringusername);// ❌ 不好:过长List<UserDO>selectAllUserRecordsByDepartmentIdentifier(LongdeptId);// 太长了!

7. 你的业务完整示例

@MapperpublicinterfaceFlightDataMapperextendsBaseMapper<FlightDataDO>{// === 基础查询 ===FlightDataDOselectById(Longid);List<FlightDataDO>selectByFlightRecordId(LongflightRecordId);List<FlightDataDO>selectByRecordIdAndType(LongrecordId,StringdataType);// === Map格式查询 ===Map<String,Object>selectMapById(Longid);List<Map<String,Object>>selectMapsByFlightRecordId(LongflightRecordId);List<Map<String,Object>>selectSimpleMapsByRecordId(LongrecordId);// === 统计查询 ===LongcountByFlightRecordId(LongflightRecordId);IntegercountByRecordIdAndType(LongrecordId,StringdataType);Map<String,Object>selectStatsByFlightRecordId(LongflightRecordId);// === 存在性检查 ===BooleanexistsBySeqIdAndRecordId(IntegerseqId,LongflightRecordId);// === 分页查询 ===Page<FlightDataDO>selectPageByRecordId(Page<FlightDataDO>page,LongflightRecordId);Page<Map<String,Object>>selectMapPageByRecordId(Page<?>page,LongflightRecordId);// === 批量查询 ===List<FlightDataDO>selectBySeqIds(@Param("recordId")LongrecordId,@Param("seqIds")List<Integer>seqIds);Map<Integer,FlightDataDO>selectMapBySeqIds(@Param("recordId")LongrecordId,@Param("seqIds")List<Integer>seqIds);// === 业务专用查询 ===List<Map<String,Object>>selectForAlarmAnalysis(LongflightRecordId);List<Map<String,Object>>selectHeightDataForAnalysis(LongflightRecordId);List<Map<String,Object>>selectSpeedDataForAnalysis(LongflightRecordId);// === 扩展查询 ===List<Map<String,Object>>selectWithFlightRecord(LongflightRecordId);List<Map<String,Object>>selectDetailByRecordId(LongflightRecordId);}

8. 阿里巴巴的黄金法则

记住这几点:

  1. select开头- 最规范
  2. 名词用实体名-User,Order,Product
  3. 条件用ByXxx-ById,ByStatus
  4. 返回类型可暗示-List,Page,Count
  5. Map格式加AsMapsMap- 可选

快速决策树:

要查什么? ├── 单条记录 → selectById / selectByXxx ├── 多条记录 → selectListByXxx / selectByXxx (返回List) ├── 分页 → selectPageByXxx ├── 统计 → selectCountByXxx / countByXxx ├── 存在 → existsByXxx ├── Map格式 → selectAsMapsByXxx / selectMapByXxx └── 复杂业务 → selectFor[业务场景]ByXxx

对于你的selectFlightDataListByRecordId

  • ✅ 是阿里巴巴标准命名
  • 如果要加关联表,建议:selectFlightDataWithFlightRecordByRecordId
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/17 19:20:11

智能体:未来社会的核心竞争力

引言&#xff1a;为何必须学习智能体&#xff1f;在2025年的今天&#xff0c;人工智能已从概念走向现实&#xff0c;而智能体&#xff08;Agent&#xff09; 作为能够自主感知环境、决策并执行任务的AI系统&#xff0c;正成为驱动社会变革的核心力量。学习智能体&#xff0c;已…

作者头像 李华
网站建设 2026/4/20 18:13:20

这个CNN-LSTM融合模型真是我最近调试得最顺手的分类工具了。咱们直接上代码,先从数据预处理开始看

CNN-LSTM 分类&#xff0c;基于卷积神经网络(CNN)-长短期记忆神经网络(LSTM)数据分类预测 MATLAB(2020及以上版本以上)语言 中文注释清楚 非常适合科研小白&#xff0c;程序已经调试好&#xff0c;替换数据就可以直接使用 多特征输入单输出的二分类及多分类模型。 预测结果图…

作者头像 李华
网站建设 2026/4/22 2:06:29

开源社区治理终极指南:构建高效协作的完整方案

在当今开源生态中&#xff0c;Champ项目通过其3D参数化人体动画技术展示了技术创新与社区治理的完美结合。开源社区治理不仅是代码协作的框架&#xff0c;更是项目可持续发展的核心引擎。本文将为新手开发者和项目维护者提供一套完整的社区治理构建方案&#xff0c;帮助您从零开…

作者头像 李华
网站建设 2026/4/18 19:10:16

MakeMeAHanzi完整指南:免费获取9000+汉字笔画数据

MakeMeAHanzi完整指南&#xff1a;免费获取9000汉字笔画数据 【免费下载链接】makemeahanzi Free, open-source Chinese character data 项目地址: https://gitcode.com/gh_mirrors/ma/makemeahanzi 想要学习汉字书写却苦于没有标准笔画顺序参考&#xff1f;MakeMeAHanz…

作者头像 李华
网站建设 2026/3/20 3:27:41

狂飙突进的新能源车,需要一场人车信任的重建

真理总是越辩越明。作者 I 王彬封面 I F1&#xff1a;狂飙飞车当前的新能源车市场似乎陷入了一个怪圈。一方面&#xff0c;技术迭代持续提速&#xff0c;智能化成为今年车市主流&#xff0c;年初比亚迪就喊出了“智驾平权”的口号&#xff0c;年底高阶智能辅助驾驶已经杀入 15 …

作者头像 李华
网站建设 2026/4/22 2:35:53

Edge-TTS终极指南:免费文本转语音的完美解决方案

Edge-TTS终极指南&#xff1a;免费文本转语音的完美解决方案 【免费下载链接】edge-tts Use Microsoft Edges online text-to-speech service from Python WITHOUT needing Microsoft Edge or Windows or an API key 项目地址: https://gitcode.com/GitHub_Trending/ed/edge-…

作者头像 李华