Mybatis Mapper XML文件-自动映射(Auto-mapping)

如您在前面的部分已经看到的那样,对于简单的情况,MyBatis可以自动为您进行结果映射,而在其他情况下,您需要构建一个结果映射。但正如您将在本节中看到的那样,您也可以混合使用这两种策略。让我们深入了解自动映射是如何工作的。

在自动映射结果时,MyBatis会获取列名并查找具有相同名称(不区分大小写)的属性。这意味着如果找到一个名为ID的列和一个名为id的属性,MyBatis将使用ID列的值设置id属性。

通常情况下,数据库列使用大写字母和下划线命名,而Java属性通常遵循驼峰命名约定。为了在它们之间启用自动映射,请将设置mapUnderscoreToCamelCase设置为true。

自动映射即使在存在特定的结果映射时也可以工作。当发生这种情况时,对于每个结果映射,在ResultSet中出现的所有未进行手动映射的列将被自动映射,然后再处理手动映射。在下面的示例中,id和userName列将被自动映射,而hashed_password列将被手动映射。

<select id="selectUsers" resultMap="userResultMap">
  select
    user_id             as "id",
    user_name           as "userName",
    hashed_password
  from some_table
  where id = #{id}
</select>
<resultMap id="userResultMap" type="User">
  <result property="password" column="hashed_password"/>
</resultMap>

有三个自动映射级别:

  • NONE - 禁用自动映射。只会设置手动映射的属性。
  • PARTIAL - 除了内部定义了嵌套结果映射的结果(联接)之外,其他都会自动映射。
  • FULL - 自动映射所有内容。

默认值是PARTIAL,这是有原因的。当使用FULL时,自动映射将在处理连接结果时执行,而连接会在同一行中检索多个不同实体的数据,因此可能会导致不期望的映射。为了理解风险,请参考以下示例:

<select id="selectBlog" resultMap="blogResult">
  select
    B.id,
    B.title,
    A.username,
  from Blog B left outer join Author A on B.author_id = A.id
  where B.id = #{id}
</select>
<resultMap id="blogResult" type="Blog">
  <association property="author" resultMap="authorResult"/>
</resultMap>

<resultMap id="authorResult" type="Author">
  <result property="username" column="author_username"/>
</resultMap>

使用这个结果映射,Blog和Author都会被自动映射。但请注意,Author有一个id属性,并且ResultSet中有一个名为id的列,所以Author的id将被填充为Blog的id,这不是你所期望的结果。因此,在使用FULL选项时要谨慎。

不论配置了哪个自动映射级别,您都可以通过在特定的ResultMap中添加属性autoMapping来启用或禁用自动映射:

<resultMap id="userResultMap" type="User" autoMapping="false">
  <result property="password" column="hashed_password"/>
</resultMap>

 

  • 7
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
由于问题比较长,我会尽量提供详细的步骤和代码示例,但是可能无法完全覆盖所有细节。如果您有具体的问题或疑问,请随时在评论区提出。 步骤1:创建动态网页工程 这个步骤比较简单,可以在Eclipse或IntelliJ IDEA等集成开发环境中创建。选择一个动态web项目,选择使用Maven或Gradle进行项目构建,选择使用SpringMVC和MyBatis框架,创建完成后,将会自动添加默认的配置文件和目录结构。 步骤2:导入SpringMVC框架相应jar包 这个步骤也比较简单,可以在pom.xml文件中添加以下依赖: ```xml <!-- SpringMVC --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>${spring.version}</version> </dependency> <!-- MyBatis --> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>${mybatis.version}</version> </dependency> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis-spring</artifactId> <version>${mybatis.version}</version> </dependency> ``` 其中,${spring.version}和${mybatis.version}是由您指定的版本号。 步骤3:创建配置文件和相应映射文件 在src/main/resources目录下创建spring-servlet.xml和mybatis-config.xml配置文件,以及相应的Mapper映射文件和Java Bean类。 spring-servlet.xml配置文件示例: ```xml <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p" xmlns:context="http://www.springframework.org/schema/context" xmlns:mvc="http://www.springframework.org/schema/mvc" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd"> <!-- 指定控制器扫描包 --> <context:component-scan base-package="com.example.controller" /> <!-- 开启SpringMVC注解驱动 --> <mvc:annotation-driven /> <!-- 静态资源映射 --> <mvc:resources mapping="/static/**" location="/static/" /> <!-- 视图解析器 --> <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/WEB-INF/views/" /> <property name="suffix" value=".jsp" /> </bean> </beans> ``` mybatis-config.xml配置文件示例: ```xml <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd"> <configuration> <typeAliases> <!-- 指定Java Bean类的包名 --> <package name="com.example.pojo" /> </typeAliases> <mappers> <!-- 指定Mapper映射文件的包名 --> <mapper resource="mapper/UserMapper.xml" /> </mappers> </configuration> ``` Mapper映射文件示例(UserMapper.xml): ```xml <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.example.mapper.UserMapper"> <!-- 查询用户信息 --> <select id="selectUserById" parameterType="int" resultType="com.example.pojo.User"> SELECT * FROM user WHERE id = #{id} </select> <!-- 插入用户信息 --> <insert id="insertUser" parameterType="com.example.pojo.User"> INSERT INTO user(username, password, email) VALUES(#{username}, #{password}, #{email}) </insert> </mapper> ``` Java Bean类示例(User.java): ```java public class User { private Integer id; private String username; private String password; private String email; // getter和setter方法省略 // ... } ``` 步骤4:编写相应配置 在以上配置文件中,已经给出了比较详细的示例。需要注意的是,spring-servlet.xml配置文件中需要指定控制器扫描包,开启SpringMVC注解驱动,以及配置视图解析器和静态资源映射mybatis-config.xml配置文件中需要指定Java Bean类和Mapper映射文件的包名,以及相应的查询和插入操作。 步骤5:编写教师列表功能的控制器方法,返回JSON格式数据 这个步骤需要编写一个控制器方法,用于查询数据库中的教师信息,并将其转换为JSON格式数据返回。在这个示例中,我们使用SpringMVC的@ResponseBody注解将返回值转换为JSON格式数据,使用MyBatis进行数据库查询操作。 控制器示例(UserController.java): ```java @Controller @RequestMapping("/user") public class UserController { @Autowired private UserMapper userMapper; @RequestMapping(value = "/list", method = RequestMethod.GET) @ResponseBody public List<User> list() { return userMapper.selectAll(); } } ``` Mapper接口示例(UserMapper.java): ```java public interface UserMapper { List<User> selectAll(); } ``` 步骤6:用浏览器访问教师列表功能,显示JSON数据 在浏览器中输入http://localhost:8080/user/list,即可访问教师列表功能,并显示JSON数据。如果一切正常,您将会看到类似以下的JSON数据: ```json [{"id":1,"username":"张三","password":"123456","email":"zhangsan@example.com"},{"id":2,"username":"李四","password":"654321","email":"lisi@example.com"}] ``` 至此,用户注册、登录和个人信息查看功能的开发基本完成。您可以根据需求进一步完善和优化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值