这是MyBatis 中极为重要的调整设置,它们会改变MyBatis 的运行时行为。
比如在 mybatis全局配置文件中,添加如下setting 来开启驼峰转化(默认是关闭的)
<!-- settings包含很多重要的设置项 setting:用来设置每一个设置项 name:设置项名 value:设置项取值 下面的setting是用来 将数据库的字段进行驼峰转化用的, 比如数据库的字段 last_name 将映射到 bean中的 lastName【 "_小写字母" 会自动转化成 "大写字母" 】这样就不需要 在映射文件中的sql查询语句里 写别名了 --> <settings> <setting name="mapUnderscoreToCamelCase" value="true"/> </settings>
mybatis接口调用下的映射文件:
<?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.mybatis.mapper.EmployeeMapper"> <!-- 上面的 namespace:名称空间;指定为接口的全类名 下面的 id:唯一标识被规定为接口方法名 【public Employee getEmpById(Integer id);】 下面的 resultType:返回值类型 下面的 #{id}:从传递过来的参数中取出id值 --> <select id="getEmpById" resultType="com.mybatis.bean.Employee"> <!-- 1、之前没有在mybatis的全局配置文件中,开启驼峰转化 setting , 因此执行 select * from tb1_employee where id = #{id} 时, 那时 数据库的字段 last_name 无法直接映射 到bean 中的lastName , 查询结果导致数据库 last_name 无法赋值给employee bean中的lastName 所以,employee 中的 lastName 是空值, 所以需要在 这里的sql语句中取别名 select id,last_name lastName,email,gender from tbl_employee where id = #{id} 2、现在已经开启了驼峰转化,所以就不需要 在sql语句中 取别名了 下面的sql语句 也可以 直接写成:select * from tb1_employee where id = #{id} --> select id,last_name,email,gender from tbl_employee where id = #{id} </select> </mapper>
bean的成员变量如下:数据库字段 last_name与bean中的lastName不能直接映射,要么在mybatis映射文件中的数据库查询中用别名,要么在mybatis全局配置文件中开启驼峰转化设置。
public class Employee { private int id; private String lastName; private String email; private String gender; public int getId() { return id; } public void setId(int id) { this.id = id; } public String getLastName() { return lastName; } public void setLastName(String lastName) { this.lastName = lastName; } public String getEmail() { return email; } public void setEmail(String email) { this.email = email; } public String getGender() { return gender; } public void setGender(String gender) { this.gender = gender; } @Override public String toString() { return "Employee [id=" + id + ", lastName=" + lastName + ", email=" + email + ", gender=" + gender + "]"; } }