MyBatis-Plusä¸å¦ä½ä½¿ç¨ResultMap
MyBatis-Plus 对 MyBatis åºæ¬é¶ä¾µå ¥ï¼å®å ¨å¯ä»¥ä¸ MyBatis æ··å使ç¨ï¼è¿ç¹å¾èµã
å¨æ¶åå°å ³ç³»åæ°æ®åºå¢å æ¥æ¹çä¸å¡æ¶ï¼ææ¯è¾åæ¬¢ç¨ MyBatis-Plus ï¼å¼åæçæé«ãå ·ä½ç使ç¨å¯ä»¥åèå®ç½ï¼æè èªå·±ä¸ææ¸ç´¢æåä¸ä¸ã
ä¸é¢ç®åæ»ç»ä¸ä¸å¨ MyBatis-Plus ä¸å¦ä½ä½¿ç¨ ResultMap ã
å ç个ä¾åï¼
æå¦ä¸ä¸¤å¼ 表ï¼
å ¶ä¸ï¼ tb_hero ä¸ç bid å ³è tb_book 表ç id ã
ä¸é¢å ç Hero å®ä½ç±»ç代ç ï¼å¦ä¸ï¼
注æäºï¼æç¹å°æ tb_hero 表ä¸ç bid å段æ å°æå®ä½ç±» Hero ä¸ç bookId å±æ§ã
MyBatis-Plus æå°åºç SQL 为ï¼
没æ¯ç ï¼ MyBatis-Plus ä¼æ ¹æ® @TableField æå®çæ å°å ³ç³»ï¼çæ对åºç SQL ã
MyBatis-Plus æå°åºç SQL 为ï¼
ä¹æ²¡æ¯ç ï¼å¯ä»¥çå°çæç SELECT ä¸æ bid åäºå«å bookId ã
æ¯å¦ç°å¨ææ³è¿æ¥ tb_hero ä¸ tb_book è¿ä¸¤å¼ 表ï¼å¦ä¸ï¼
æ¥è¯¢ MyBatis-Plus æå°åºç SQL 为ï¼
SQL没å¥é®é¢ï¼è¿æ»¤ä¸å页ä¹é½æ£å¸¸ï¼ä½æ¯æ¤æ¶ä½ ä¼åç° bookId å±æ§ä¸º null ï¼å¦ä¸ï¼
为ä»ä¹å¢ï¼
è°ç¨ BaseMapper ä¸å ç½®ç selectById() æ¹æ³å¹¶æ²¡æåºç°è¿ç§æ åµåï¼ï¼ï¼
åè¿å¤´æ¥å对æ¯ä¸ä¸å¨ HeroMapper ä¸èªå·±å®ä¹çæ¥è¯¢ä¸ MyBatis-Plus èªå¸¦ç selectById() æå¥ä¸åï¼è¿è®°å¾ä¸é¢çååçæµè¯åï¼çæçSQLæå¥ä¸åï¼
åæ¥ï¼ MyBatis-Plus 为 BaseMapper ä¸å ç½®çæ¹æ³çæSQLæ¶ï¼ä¼æ SELECT åå¥ä¸ bid åå«å bookId ï¼èèªå·±åçæ¥è¯¢ MyBatis-Plus 并ä¸ä¼å¸®ä½ ä¿®æ¹ SELECT åå¥ï¼ä¹å°±å¯¼è´ bookId å±æ§ä¸º null ã
å¨è¿éå°±æ¯ tb_hero 表ä¸ç bid å段æ å°æå®ä½ç±» Hero ä¸ç bid å±æ§ãè¿æ ·å½ç¶å¯ä»¥è§£å³é®é¢ï¼ä½ä¸æ¯æ¬ç¯è®²çéç¹ã
å¨ @TableName 设置 autoResultMap = true
ç¶åå¨èªå®ä¹æ¥è¯¢ä¸æ·»å @ResultMap 注解ï¼å¦ä¸ï¼
è¿æ ·ï¼ä¹è½è§£å³é®é¢ã
ä¸é¢ç®åçä¸æºç ï¼ @ResultMap("mybatis-plus_å®ä½ç±»å") æä¹æ¥çã
详æ è§ï¼ com.baomidou.mybatisplus.core.metadata.TableInfo#initResultMapIfNeed()
注æçä¸é¢çå符串 id çææï¼ä½ åºè¯¥å¯ä»¥æç½ã
æèï¼ è¿ç§æ¹å¼ç ResultMap é»è®¤æ¯å¼ºç»å¨ä¸ä¸ª @TableName ä¸çï¼å¦ææ¯æ个èåæ¥è¯¢æè æ¥è¯¢çç»æ并é对åºä¸ä¸ªçå®ç表æä¹åå¢ï¼æ没ææ´ä¼é çæ¹å¼ï¼
åºäºä¸é¢çæèï¼æåäºä¸é¢ç®åçå®ç°ï¼
å ³é®ä»£ç å ¶å®æ²¡æå è¡ï¼èå¿çä¸åºè¯¥ä¸é¾æã
è¿æ¯ç¨ä¾åæ¥è¯´ææ´ç´è§ã
ä¸é¢æ¯ä¸ä¸ªèåæ¥è¯¢ï¼
å ¶ä¸ BookAgg çå®ä¹å¦ä¸ï¼å¨å®ä½ç±»ä¸ä½¿ç¨äº @AutoResultMap 注解ï¼
å¦ä½å¦ä¹ å«äººçç¨åºä»£ç
å¦ä½å¦ä¹ å«äººçç¨åºä»£ç
åªè¦æ¯ä¸ªç¨åºåå°±ä¼ç代ç ï¼ä½æ¯å¾å¤äººï¼å æ¬æå¨å ï¼å¨çä¸äºå¼æºä»£ç çæ¶åå¾å¾ä¸å¤´é¾æ°´ï¼ä¸ç¥ä»ä½çèµ·ã
è¶æ¯ç»æ好ç代ç ï¼å¦æä¸ç解å®çææ³è¶æ¯é¾å¾çæï¼ä¾å¦QtãAggãCryptPPçãè¿éæå°æçä¸äºç»éªåå¨è¿éï¼ç个记å½å§ã
å®åçå¼æºå·¥ç¨é½ä¼æææ¡£ï¼å³ä½¿æ²¡æææ¡£ä¹åºå½æapi-guidï¼é£ä¹æ们å æ¾å°å®ä»¬ï¼è¿æ¶æ们ä¸è¦ç®¡å®æ¯æä¹è®¾è®¡çï¼å ç¼è¯ä¸ä¸ªï¼ç §çä¾åå个ç¨åºè¿è¡ä¸ä¸å§ï¼åè¯è¯ä¸äºé«çº§åè½ãè¿æ¶æ们å¨å¿ä¸å ççå®åºå½æ¯ææ ·è®¾è®¡çï¼å¤§å¤æ°æ åµæ¯æ²¡ææ³æ³ï¼ã好å§ï¼æ们åæ¥çææ¡£ï¼ææ¡£ä¸ä¸è¬æéæç»æç说æï¼å¦æ¨¡åååãç±»å表ãæ¯ä¸ªç±»çæåå表ãå¯ï¼è¿æ¯ä¸å¤´é¾æ°´åï¼æ²¡åæ³ï¼æ们æå¼æºç æå¨çæ件夹ï¼ççæºç çç»ç»æ¹å¼ãå¯ï¼æç¹å¤´ç»ªäºï¼å¤§å¤æ°æ åµä¸ï¼ç®å½ç»æä¸å·¥ç¨ç»ææ¯ä¸è´çï¼èæ们ç¼åä¾åç¨åºçæ¶å使ç¨çæ¥å£ä¸è¬å¨æºç çincludeç®å½ä¸ãé£å¥½å§ï¼æä»¬æ ¹æ®å¤´æ件ååç®å½ç»æå»æ¾ç¸åºçå®ç°æ件å§ï¼ä½è¿å¾å¾ç¸å½å°é¾ï¼å ä¸ºä½ ä¼åç°å®æ ¹æ¬å°±ä¸æ¯ä½ ææ³çé£æ ·ãä¸ä¸ªç±»æä¸ä¸ªå¤é¨åéï¼ä½ æ³æ¾å°å®å¾å¾ä¼å¨ç¨Windowsçæç´¢ãçäºå 个å°æ¶è¿æ²¡æ太大çè¿å±ï¼ä»ç¶ä¸ç¥éå®ç头ï¼é«å±çå ¥å£ï¼å¨åªï¼å°¾ï¼åºå±çå ·ä½å®ç°ï¼å¨åªï¼ä¸è¿ä½ è³å°å¯¹é£äºå°æ¹æåªäºæ件é½çæäºï¼é£äºé¶æç注éä¹è¢«ä½ çäºä¸éãè¿æ¶è¯¥æä½ åçä¾åç¨åºæ¿åºæ¥äºï¼æ们åæ¥è·è¿å»ï¼è·çåæ¶æ们ä¹æ³¨æä¸ä¸æè·å°çæ件çç©çä½ç½®ãå®éè¿é½æåªäºæ件ãåªäºç±»æç»æãä¸ç´è·ä¸å»ï¼è¿æ ·æ们å¾å¾ä¼é¡ºè¤æ¸çæ¾å°æåºå±çå®ç°ï¼å¹¶åç°ä¸æ¡æ§è¡è·¯å¾ï¼å¤ªåæçæç¨äºä¸å 模æ¿çé¤å¤ï¼ãç±äºä½ å·²ç»å¯¹å·¥ç¨çç»ææäºä¸å®äºè§£ï¼è¿æ¶ä½ å¯ä»¥ä»å¤´åå°¾ä¸èµ·å¼å§ç代ç ï¼åææ¯ä½ å·²ç»æ¾å°äºä¸ä¸ªå¤´åä¸ä¸ªå°¾ï¼ï¼å°ä¸æ¡çº¿å¼æ¸ æ¥ï¼é£ä¹è¿ä¸ªå·¥ç¨çå ¶ä»çº¿ä¹åºè¯¥æ¯å·®ä¸å¤ç设计æè·¯ã
æäºå¼æºå·¥ç¨éé¢çå®ç¹å«å¤ï¼é£ä½ è¦å½å¿ï¼é¦å ææ¸ æ¥è¿äºå®å§ã
ç¨Cåçå·¥ç¨å¾å¾æ¯ç¨C++åç容ææï¼å 为å®æå¤æå¾å¤å½æ°æéåexternåéï¼èåè å令人头ç¼å¾å¤ï¼å¦æä½ å®å¨æ²¡æåæ³ï¼é£ä¹ä¸ç½æå§ï¼å¾å¤èåçå¼æºå·¥ç¨ä¸è¬ä¼æä¸äºäººå°å ¶ç 究å¿å¾æ¾å°blogä¸ï¼çä¸çï¼è¯´ä¸å®ä¸ä¸è±ç¶å¼æã
好å§ï¼å°±åè¿ä¹å¤ï¼çæ¯ä¹±ä¸å «ç³ã
VCF计算机术语
在Outlook中,文件扩展名为.vcf的文件通常包含了联系人信息,可以方便地复制粘贴到联系人列表中,用于发送邮件时作为收件人的地址。 VCF,全称为Visual Component Framework,正版游戏源码是一个基于C++的开源项目,旨在简化高性能应用程序的开发。它借鉴了现代C++设计,并内置了Rapid Application Development(RAD)支持,旨在跨多个平台和编译器保持兼容性,避免为单一平台重写大量代码的困扰。 框架库在软件开发中扮演重要角色,无敌战法源码它们提供固化编程方式,简化系统编程。比如早期的Borland公司推出的OWL库,后来的MFC(Microsoft Foundation Classes)和C++Builder中的VCL,都是经典案例。侯捷对MFC和VCL的评价深入浅出,揭示了它们各自的优缺点。 随着技术进步,框架库种类繁多,如WTL(Windows Template Library)和STL(Standard Template Library)等,这些库的界限有时变得模糊。AGG、皮革溯源码LOKI库和CPPUNIT库等特定功能库,如2D图形处理、设计思维和单元测试,也值得提及。 对于VCF,我特别关注其RTTI(Run-Time Type Information)功能和采用的高级C++编程技术。在开发一个工控软件时,我原本遇到困难,后来发现VCF的RTTI功能恰好能满足需求,尤其是其类信息查找、属性和事件等功能。然而,预警源码分享VCF尚在开发阶段,帮助文档不完整;虽然源码清晰,但RTTI实现方法需要优化,例如提供更便捷的属性操作和性能提升,如直接通过编号访问属性,而非名称。扩展资料
五子棋术语VCF:(Victory of Continuous Four的缩写) 五子棋中引入的英文名称,即利用连续不断冲四这种绝对先手,直至最终成五而取得胜利的一种技巧。简称“连续冲四胜”或“连冲胜”。 常为五子棋残局排局解题的一种取胜技巧。另外还是小狗币源码一种计算机术语、通讯录格式GSDS基因结构图的绘制
GSDS 2.0,一款强大的基因结构可视化工具,让你的基因标注和图表生成如虎添翼。它的设计巧妙地整合了多种数据格式,包括BED、GTF/GFF3、GenBank Accession Number/GI和FASTA,满足不同研究需求。亮点功能如下: 直观展示: GSDS将外显子/CDS的精确坐标呈现,同时揭示了保守元件和结合位点等重要信息,帮助你深入理解基因功能。 统一格式转换: 无论你的原始数据是何种格式,GSDS都能无缝转换为统一的图形生成格式,让数据处理变得更加便捷。 个性化定制: 用户可以自由调整特征显示,轻松导出高质量的SVG、PNG或PDF图,甚至利用SVG-edit进行后期编辑,细节把控无遗漏。 在数据输入方面,BED格式支持如geneID/transcriptID、起始和结束位置,以及可选的相位信息。GTF/GFF3格式则需提供geneID/transcriptID,其他字段则可根据需要自选。 对于GenBank Accession Number/GI,GSDS能帮您提取和整合CDS信息,而FASTA则支持CDS序列输入,并与基因组进行精确映射,挖掘序列背后的生物学含义。 使用GSDS时,只需准备所需的格式化数据,剩下的工作就交给这款强大的工具去处理。对于那些寻求深度定制体验的用户,GSDS提供了本地安装源代码(gsds_v2.tar.gz)的选项,让你拥有更灵活的使用环境。 安装准备: GSDS 2.0的安装需要具备Apache2、Perl 5.8+、SVG、Bio-Phylo、Bedtools、EMBOSS(est2genome、seqretsplit)以及LibRSVG等软件环境。具体步骤包括解压文件、设置权限,并将bedtools和rsvg-convert链接到系统路径。 例如,你可以执行以下命令将bedtools和rsvg-convert添加到系统路径:ln -s -fbedtools
ln -s -frsvg-convert
在讨论非编码区域时,我们不能忽视UTR(Untranslated Regions)。在成熟mRNA中,它位于编码区域(CDS)上游,常常携带着调控基因表达的关键元件。在原核生物中,5'UTR内含 Shine-Dalgarno序列(AGGAGGU),而在真核生物中,5'UTR的平均长度约为nt,极端情况下可达数千bp,这些细节对于理解基因表达调控至关重要。 总而言之,GSDS 2.0为基因结构分析提供了一站式的解决方案,无论是数据处理还是图形生成,都能满足专业研究人员的高效需求。2025-01-23 19:17
2025-01-23 19:17
2025-01-23 19:10
2025-01-23 18:56
2025-01-23 18:23