热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

MarsJava推出2.1.7更新版本,带来多项性能优化与功能增强

MarsJava最新发布了2.1.7版本,此次更新带来了多项性能优化和功能增强。新版本在系统稳定性、响应速度和资源管理方面进行了显著改进,进一步提升了用户体验。同时,新增了多个实用功能,满足开发者在复杂应用场景中的需求。

此次更新如下:

  1. 优化了代码结构,性能更高效
  2. mars-jdbc升级,单表操作不需要写sql,不需要用配置或者注解映射,直接一句注解搞定
  3. JdbcTemplete优化升级,支持分页查询,sql参数使用占位符,避免了字符串拼接带来的sql注入风险
  4. mars-cloud 为了配合mars-jdbc的升级,所以发行了一个版本
Mars-jdbc用法

dao 建议用抽象类 的形式创建,这样单表操作可以用抽象方法,多表操作可以自己写sql。
加上MarsDao注解,如下图所示:

 @MarsDao("testDao") public abstract class TestDao {   }


单表操作


根据主键查询一条数据

 @MarsGet(tableName = "userinfo",primaryKey = "id") public abstract Map selectById(int id);

如上面的示例所示,在抽象方法上加上MarsGet注解即可
tableName:要从哪张表里的查询
primarkey:主键字段名
方法的参数:要查主键是什么的数据就传什么

根据主键更新数据

 @MarsUpdate(tableName = "userinfo",operType = OperType.UPDATE,primaryKey = "id") public abstract int update(DemoEntity demoEntity);

如上面的示例所示,在抽象方法上加上MarsUpdate注解即可
tableName:要更新哪张表
primarkey:主键字段名
operType:设置操作方式为update
方法的参数:任意自定义实体对象或者map,对象的字段要跟数据库表的字段名一致

插入一条数据

 @MarsUpdate(tableName = "userinfo",operType = OperType.INSERT) public abstract int insert(DemoEntity demoEntity);

如上面的示例所示,在抽象方法上加上MarsUpdate注解即可
tableName:要插入哪张表
operType:设置操作方式为insert
方法的参数:任意自定义实体对象或者map,对象的字段要跟数据库表的字段名一致

根据主键删除一条数据

 @MarsUpdate(tableName = "userinfo",operType = OperType.DELETE,primaryKey = "id") public abstract int delete(int id);

如上面的示例所示,在抽象方法上加上MarsUpdate注解即可
tableName:要从哪张表删除
primarkey:主键字段名
operType:设置操作方式为delete
方法的参数:要删除主键是什么值的数据就传什么

多表操作


sql语句固定

 @MarsSelect(sql = "select * from userinfo where name = #{name} and age = ${age}") public abstract List> selectList(DemoEntity demoEntity);

如上面的示例所示,在抽象方法上加上MarsSelect注解即可
sql:sql语句
方法的参数:任意自定义实体对象或者map,对象的字段要跟sql中的占位符一致(不包含#{})

sql语句不固定(需要根据条件判断,来动态的拼接语句)

这种情况需要使用JdbcTemplete:
在代码里去拼sql,sql拼好以后用下面所示的方式执行
sql中的参数一样用#{}或者${}来占位

 JdbcTemplete.get("数据源名称,不传自动使用默认数据源").selectList(sql,DemoEntity.class); JdbcTemplete.get("数据源名称,不传自动使用默认数据源").update(sql,demoEntity);

JdbcTemplete 这里就不多说了,实际使用的时候,开发环境的自动补全功能会自动弹出里面的方法,选择适合自己的就行了

分页查询


使用JdbcTemplete里的selectPageList

 public PageModel findPage(PageParamModel pageParamModel) throws Exception {     String sql = "select * from userinfo where name like #{name}";     return JdbcTemplete.get().selectPageList(sql,pageParamModel,DemoEntity.class); }

参数必须传PageParamModel,返回类型也必须是PageModel

占位符解释

 #{name}: 这种占位符会被替换成 ? 没有sql注入的风险 ${name}: 这种占位符是字符串拼接,有sql注入的风险


选择数据源

dao层的方法上 可以用 DataSource(name=”数据源name”) 注解 去指定要用的数据源,如果只有一个数据源,则不需要指定
 

具体可看官网:http://mars-framework.com


推荐阅读
  • PHP连接MySQL的三种方法及预处理语句防止SQL注入的技术详解
    PHP连接MySQL的三种方法及预处理语句防止SQL注入的技术详解 ... [详细]
  • 成功实现Asp.Net MVC3网站与MongoDB数据库的高效集成
    我们成功地构建了一个基于Asp.NET MVC3框架的网站,并实现了与MongoDB数据库的高效集成。此次更新不仅完善了基本的创建和显示功能,还全面实现了数据的增删改查操作。在创建功能方面,我们修复了之前代码中的错误,确保每个属性都能正确生成。此外,我们还对数据模型进行了优化,以提高系统的性能和稳定性。 ... [详细]
  • JVM参数设置与命令行工具详解
    JVM参数配置与命令行工具的深入解析旨在优化系统性能,通过合理设置JVM参数,确保在高吞吐量的前提下,有效减少垃圾回收(GC)的频率,进而降低系统停顿时间,提升服务的稳定性和响应速度。此外,本文还将详细介绍常用的JVM命令行工具,帮助开发者更好地监控和调优JVM运行状态。 ... [详细]
  • Jedis接口分类详解与应用指南
    本文详细解析了Jedis接口的分类及其应用指南,重点介绍了字符串数据类型(String)的接口功能。作为Redis中最基本的数据存储形式,字符串类型支持多种操作,如设置、获取和更新键值对等,适用于广泛的应用场景。 ... [详细]
  • 本文将介绍一种扩展的ASP.NET MVC三层架构框架,并通过使用StructureMap实现依赖注入,以降低代码间的耦合度。该方法不仅能够提高代码的可维护性和可测试性,还能增强系统的灵活性和扩展性。通过具体实践案例,详细阐述了如何在实际开发中有效应用这一技术。 ... [详细]
  • 在探讨 AS3 中的数据深度复制技术时,本文详细介绍了实现数据深度克隆的有效方法。通过对比多种方案,最终确定了一种高效且可靠的实现方式,所有代码均来源于公开资源,确保了方法的实用性和可操作性。 ... [详细]
  • 本文提供了 RabbitMQ 3.7 的快速上手指南,详细介绍了环境搭建、生产者和消费者的配置与使用。通过官方教程的指引,读者可以轻松完成初步测试和实践,快速掌握 RabbitMQ 的核心功能和基本操作。 ... [详细]
  • 为了优化直播应用底部聊天框的弹出机制,确保在不同设备上的布局稳定性和兼容性,特别是在配备虚拟按键的设备上,我们对用户交互流程进行了调整。首次打开应用时,需先点击首个输入框以准确获取键盘高度,避免直接点击第二个输入框导致的整体布局挤压问题。此优化通过调整 `activity_main.xml` 布局文件实现,确保了更好的用户体验和界面适配。 ... [详细]
  • 在Spring框架中,基于Schema的异常通知与环绕通知的实现方法具有重要的实践价值。首先,对于异常通知,需要创建一个实现ThrowsAdvice接口的通知类。尽管ThrowsAdvice接口本身不包含任何方法,但开发者需自定义方法来处理异常情况。此外,环绕通知则通过实现MethodInterceptor接口来实现,允许在方法调用前后执行特定逻辑,从而增强功能或进行必要的控制。这两种通知机制的结合使用,能够有效提升应用程序的健壮性和灵活性。 ... [详细]
  • 优化后的标题:PHP分布式高并发秒杀系统设计与实现
    PHPSeckill是一个基于PHP、Lua和Redis构建的高效分布式秒杀系统。该项目利用php_apcu扩展优化性能,实现了高并发环境下的秒杀功能。系统设计充分考虑了分布式架构的可扩展性和稳定性,适用于大规模用户同时访问的场景。项目代码已开源,可在Gitee平台上获取。 ... [详细]
  • 深入解析:RKHunter与AIDE在入侵检测中的应用与优势
    本文深入探讨了RKHunter与AIDE在入侵检测领域的应用及其独特优势。通过对比分析,详细阐述了这两种工具在系统完整性验证、恶意软件检测及日志文件监控等方面的技术特点和实际效果,为安全管理人员提供了有效的防护策略建议。 ... [详细]
  • voc生成xml 代码
    目录 lxmlwindows安装 读取示例 可视化 生成示例 上面是代码,下面有调用示例 api调用代码,其实只有几行:这个生成代码也很简 ... [详细]
  • MySQL 数据操作:增、删、查、改全面解析
    MySQL 数据操作:增、删、查、改全面解析 ... [详细]
  • 在单个图表中实现饼图与条形图的精准对齐 ... [详细]
  • 深入解析十大经典排序算法:动画演示、原理分析与代码实现
    本文深入探讨了十种经典的排序算法,不仅通过动画直观展示了每种算法的运行过程,还详细解析了其背后的原理与机制,并提供了相应的代码实现,帮助读者全面理解和掌握这些算法的核心要点。 ... [详细]
author-avatar
会唱歌的高跟鞋
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有