Mybatis plus insert添加后返回主键ID

           长话短说,集成了Mybatis Plus之后,自带的Save()方法虽然返回的是boolean类型的,但其实只要执行成功,就可以直接拿到ID,不需要其他什么配置。代码如下

        Test test = new Test();
        /*此处省略斌值部分*/

        //直接调用save方法获取boolean返回值
		boolean f= testService.save(test);
        //如果为true,添加成功之后,那么原有对象就会带有ID值,就可以点出来
		if (f) System.out.println("该数据Id为:"test.getId());
  • 19
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
智慧校园整体解决方案是响应国家教育信息化政策,结合教育改革和技术创新的产物。该方案以物联网、大数据、人工智能和移动互联技术为基础,旨在打造一个安全、高效、互动且环保的教育环境。方案强调从数字化校园向智慧校园的转变,通过自动数据采集、智能分析和按需服务,实现校园业务的智能化管理。 方案的总体设计原则包括应用至上、分层设计和互联互通,确保系统能够满足不同用户角色的需求,并实现数据和资源的整合与共享。框架设计涵盖了校园安全、管理、教学、环境等多个方面,构建了一个全面的校园应用生态系统。这包括智慧安全系统、校园身份识别、智能排课及选课系统、智慧学习系统、精品录播教室方案等,以支持个性化学习和教学评估。 建设内容突出了智慧安全和智慧管理的重要性。智慧安全管理通过分布式录播系统和紧急预案一启动功能,增强校园安全预警和事件响应能力。智慧管理系统则利用物联网技术,实现人员和设备的智能管理,提高校园运营效率。 智慧教学部分,方案提供了智慧学习系统和精品录播教室方案,支持专业级学习硬件和智能化网络管理,促进个性化学习和教学资源的高效利用。同时,教学质量评估中心和资源应用平台的建设,旨在提升教学评估的科学性和教育资源的共享性。 智慧环境建设则侧重于基于物联网的设备管理,通过智慧教室管理系统实现教室环境的智能控制和能效管理,打造绿色、节能的校园环境。电子班牌和校园信息发布系统的建设,将作为智慧校园的核心和入口,提供教务、一卡通、图书馆等系统的集成信息。 总体而言,智慧校园整体解决方案通过集成先进技术,不仅提升了校园的信息化水平,而且优化了教学和管理流程,为学生、教师和家长提供了更加便捷、个性化的教育体验。
### 回答1: Mybatis plus是一款基于Mybatis的增强工具,它在Mybatis的基础上进行了扩展,提供了更加便捷的使用方式。在使用mybatis plus的mapper.insert方法时,如果没有返回id,这可能是由于数据源连接池未配置正确导致的。常见设置方式是在application.yml或application.properties文件中增加如下配置: ``` # datasource spring.datasource.url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8&useSSL=false&serverTimezone=GMT%2B8 spring.datasource.username=root spring.datasource.password=123456 spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver spring.datasource.initialSize=1 spring.datasource.maxActive=10 spring.datasource.minIdle=1 spring.datasource.maxWait=60000 spring.datasource.timeBetweenEvictionRunsMillis=60000 spring.datasource.minEvictableIdleTimeMillis=300000 spring.datasource.validationQuery=SELECT 1 spring.datasource.testWhileIdle=true spring.datasource.testOnBorrow=false spring.datasource.testOnReturn=false ``` 如果以上配置项设置正确,但仍然无法返回id,则可以考虑通过在实体类中使用@TableId注解指定生成策略来解决问题。例如: ``` @TableId(value = "id", type = IdType.AUTO) private Long id; ``` 通过指定type属性值为IdType.AUTO,可以让Mybatis plus自动根据数据库自增长生成id。 当然,如果以上解决方法均无效,则可以考虑在mapper.xml文件中使用<selectKey>标签手动获取id。 总的来说,使用Mybatis plus时如果mapper.insert无法返回id要检查数据源连接池配置是否正确,并注意实体类中的生成策略设置。 ### 回答2: Mybatis Plus是一个基于Mybatis的增强工具库,提供了很多便捷的方法和功能。Mapper.insert方法是其中一个经常被使用的方法,它可以将一个实体类对象插入到数据库中。但是,在使用Mapper.insert方法插入数据的时候,有的时候我们会遇到一个问题,即没有返回id。 造成这种情况的原因是,当我们使用Mapper.insert方法插入数据时,如果实体类中没有id属性或者id属性的值为null,则Mybatis Plus默认使用数据库自增插入id。而这时,插入操作是通过SQL语句完成的,数据库返回id并不会映射到实体类的id属性上,因此Mapper.insert方法无法返回id值。 为了解决这个问题,我们可以使用Mybatis Plus提供的两种方法: 1.使用注解@TableId(type= IdType.AUTO)标注实体类的id属性,表示id是自增的,默认类型为雪花算法(63位随机自增的唯一ID),这样Mybatis Plus会在插入成功后将id赋值到实体类的id属性上。 2.在Mapper.insert操作后,通过实体类对象获取id值,可以使用Mybatis Plus提供的两种方法: (1)实体类id属性用@TableId注解,并指定id生成策略,如自增: User user = new User(); user.setName("test"); user.setAge(20); user.setSex(1); user.setAddress("test"); mapper.insert(user); Long id = user.getId(); (2)实体类id属性不用@TableId注解,Mapper.insert方法后使用数据库的CURRVAL或NEXTVAL获取id: User user = new User(); user.setName("test"); user.setAge(20); user.setSex(1); user.setAddress("test"); mapper.insert(user); Long id = (Long)SqlHelper.getObject(user, MetaObject.forObject(user), "id"); 综上所述,Mybatis Plus Mapper.insert方法没有返回id,是因为实体类id属性没有映射到返回值里。我们可以使用@TableId注解或者getObject方法获取实体类id属性的值来解决这个问题。 ### 回答3: MyBatis Plus作为一个流行的ORM框架,大大简化了Java应用程序与数据库的交互。在使用MyBatis Plus中的Mapper接口进行数据插入时,如果使用Mapper.insert方法,可能会遇到无法返回id的情况。 造成该现象的要原因在于Mapper.insert方法使用了另一个名为SqlMethod.INSERT_ONE的私有静态方法,该方法会忽略对id的处理。实际上,该方法的insert语句并没有包含列,所以也就无法返回id了。 在这种情况下,我们可以使用Mapper.insert方法的重载版本,即Mapper.insert(T entity, boolean selective)。其中,第二个参数为一个布尔值,表示是否选择只插入非空字段。通过将该参数置为false,我们可以强制Mapper插入所有字段,包括列,从而获得正确的id。例如: ``` User user = new User(); user.setName("张三"); user.setAge(20); user.setEmail("zhangsan@qq.com"); mapper.insert(user, false); //将第二个参数置为false System.out.println("新增用户id:" + user.getId()); ``` 除了使用重载方法之外,我们还可以在实体类的字段上添加一个注解,指示该字段为自增。这样,MyBatis Plus就会自动处理id,在插入数据后将id赋值给实体对象的字段。例如: ``` public class User { @TableId(type = IdType.AUTO) private Long id; private String name; private Integer age; private String email; //...省略getter和setter方法 } ``` 在实际开发中,我们可以根据具体场景选择使用哪种方式获取插入数据的id,以便更好地处理业务逻辑。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值