java - spring boot 集成mybatis 注解版查询
问题描述
-spring boot 集成 mybatis 使用注解实现 spring boot 和 mybatis已经正常集成,在使用查询时使用的是注解,(项目没有任何XML文件)
@Mapper@Table(name = 't_user')public interface UserMapper { @Select('select * from t_user where user_id = #{id}') public User findUserById(@Param('id') String id);}
这种方式是不知道为什么,只有几个属性会填充值,其他属性查询出来的结果都为null
但是我如果写了
@Results({ @Result(column = 'user_id',property = 'userId'), @Result(column = 'username',property = 'username'), @Result(column = 'pass',property = 'pass'), @Result(column = 'phone_number',property = 'phoneNumber')})
就会完全正确,每个属性都有值问题1: 为什么会出现有的属性有值,有的属性没值?问题2:我不能每个查询语句都这么写,这样会有很多的重复的@Result部分,有没有注解将其在内部进行对应关系实现,不需要每次都写@ Result?
问题解答
回答1:问题1. 因为结果集的column和Bean的property不对应,当然就会null.
问题2. 你可以在sql中用别名,使得column和property对应,这样就不会出现问题1.
回答2:问题一的话,因为数据库字段是你下划线分隔,bean中的字段是驼峰命名的,如user_name和userName,导致无法匹配
如果是通过xml文件来配置的话,只需要开启驼峰命名转换
<setting name='mapUnderscoreToCamelCase' value='true'/>
yml中 大概是这样
mybatis: configuration: map-underscore-to-camel-case: true
相关文章:
1. javascript - 如何使用nodejs 将.html 文件转化成canvas2. 如何解决docker宿主机无法访问容器中的服务?3. angular.js - 输入邮箱地址之后, 如何使其自动在末尾添加分号?4. javascript - html5的data属性怎么指定一个function函数呢?5. javascript - 后台管理系统左侧折叠导航栏数据较多,怎么样直接通过搜索去定位到具体某一个菜单项位置,并展开当前菜单6. python - Scrapy存在内存泄漏的问题。7. 在mac下出现了两个docker环境8. docker-compose中volumes的问题9. java如何生成token?10. 大家好,我想请问一下怎么做搜索栏能够搜索到自己网站的内容。
