解决MyBatis返回结果中有实体类没定义的属性

本文探讨了在MyBatis中处理复杂SQL查询的方法,特别是如何避免在实体类中频繁添加getset方法的问题。通过使用自定义属性和集合映射等技术,实现了更灵活的数据查询与展示。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我的设计思想可能有问题,就是我如果能在sql里干的事情我一般不喜欢放到service里来做。目前我刚开始接触Mybatis,很难习惯查询什么都需要在实体类中加入getset方法,有点繁琐,自己写工具类水平又不够,这个问题让我很纠结。如果你的查询结果中有你用sql拼接而成的内容,而你的实体类中没有定义,mybatis的dao的xml可以这么写:
	<select id="SelectAllRoles" resultType="Hashmap">
	select  id, role, description, available ,
	(select  GROUP_CONCAT(m.name SEPARATOR ',')  from sys_powermenu pm,sys_resource m where pm.type=1 and  sys_role.id=pm.objid and pm.menuid=m.id) as menunames
      from sys_role   where 1=1 
	</select>
我自己拼接了一个属性menunames,类型为String,这样以来返回结果中有了实体类没有的属性,所以使用map来当结果集,在service里这样接收:
List<HashMap<String, Object>> list = dao.SelectAllRoles();

我前台使用的是EasyUI,我接收到数据没有什么问题。

下面是遇到一对多时可使用的自定义属性的例子:

<select id="menus" resultType="String">
	select  m.name as menunames  from sys_powermenu pm,sys_resource m where pm.type=1 and  pm.objid=#{xxx} and pm.menuid=m.id
	</select>
	<resultMap type="HashMap" id="xx">
	<id column="id" property="id"/>
	<result column="role" property="role"/>
	<result column="description" property="description"/>
	<result column="available" property="available"/>
	<collection property="menunames" ofType="String" select="menus" column="id" />
	</resultMap>
	<select id="SelectAllRoles" resultMap="xx">
	select  id, role, description, available 
      from sys_role   where 1=1 
	</select>

这个例子可能举得不合适,但格式就是这样,你可以在多表查询中取出任意表中的数据进行修改,然后传到前台进行展示,而不需要些那些该死的getset。

以后遇到问题的话,我会继续修改的。

一个Mybatis菜鸟在努力争扎。


### MyBatis 中配置实体类主键自增的方法 在 MyBatisMyBatis-Plus 的开发场景下,可以通过多种方式实现主键自增的功能。以下是几种常见的方法及其具体实现。 #### 方法一:通过 MyBatis-Plus 配置全局主键策略 MyBatis-Plus 提供了一种便捷的方式用于定义主键生成策略。可以在 `application.yml` 文件中指定全局的主键生成模式为自动增长: ```yaml mybatis-plus: global-config: db-config: id-type: auto ``` 上述配置表示数据库表的主键由数据库本身负责分配并自增[^1]。需要注意的是,这种方式依赖于底层数据库的支持(如 MySQL 的 AUTO_INCREMENT 属性)。因此,在创建数据表时需确保主键字段已启用该属性。 #### 方法二:解决 XML 插入语句中的主键冲突问题 当手动编写 Insert SQL 并未正确处理主键赋值逻辑时,可能会引发重复插入错误。例如,如果直接将 `id` 字段作为参数传入而未让其参与自增,则可能出现如下异常情况: > Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLIntegrityConstraintViolationException: Duplicate entry '0' for key 'PRIMARY' 这是因为每次插入操作都将默认值设为了零所致[^2]。为了避免此类现象发生,可以移除映射文件内的 `<insert>` 节点里有关 ID 参数的部分声明或者调整为允许 DB 自动生成的形式。 #### 方法三:利用 SelectKey 获取最后插入记录的主键值 对于某些特殊需求场合可能并希望完全交予 RDBMS 控制整个流程而是想获得新产生的 KEY 后再做进一步动作的话,则可通过 `<selectKey>` 标签来完成此目的: ```xml <insert id="insertUser"> <selectKey keyProperty="userId" resultType="java.lang.Integer" order="AFTER"> SELECT LAST_INSERT_ID() </selectKey> insert into users(user_name) values(#{userName}) </insert> ``` 这里的关键在于设置了 `order="AFTER"` 表明只有在真正完成了 INSERT 动作之后才会去查询最新的那个编号填充回对象实例之中;另外还指定了返回的数据类型以及目标变量名以便后续访问使用[^3]. #### 方法四:借助 Mapper 接口定义保存行为 除了以上提到的技术手段外还可以考虑直接修改 DAO Layer 上面所提供的 API 定义形式从而间接影响到底层是如何运作的。比如下面这个例子展示了怎样设计一个能够接受列表批量新增请求的同时又能保证每条记录都拥有独一无二的身份标识符的能力: ```java public interface QuestionMapper { int saveQuestionAnswer(@Param("questionId") Long questionId, @Param("list") List<XzsQuestionsAnswerCreate> list); } ``` 此时只要保证所关联的那个表结构已经开启了相应的特性支持即可无需额外操心太多细节部分[^4]. --- ### 注意事项 无论采用哪种方案都需要确认当前使用的数据库引擎确实具备相应功能并且版本号满足最低要求限制条件才行哦!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值