我是 mybatis 的新手,并且遵循 mybatis3-user-guide.pdf。
我设置了我的第一个应用程序。
但是我发现我并不完全了解映射器接口。
到目前为止,这是我的应用程序的所有配置(以模型用户为例):
mybatis config.xml:
<configuration>
<typeAliases>
<typeAlias alias="User" type="com.king.mapper.User" />
</typeAliases>
<mappers>
<mapper resource="com/king/mapper/UserMapper.xml" />
</mappers>
</configuration>
用户映射器.xml:
<mapper namespace="com.king.mapper.UserMapper">
<select id="selectById" parameterType="int" resultMap="userMap">
select * from users where id = #{id}
</select>
<select id="selectAll" resultType="hashmap">
select * from users order by created_at desc
</select>
<insert id="insert" parameterType="User" useGeneratedKeys="true" keyProperty="id">
insert into users (name,created_at,updated_at) values (#{name},current_timestamp,current_timestamp)
</insert>
<update id="update" parameterType="User">
update users set name = #{name},updated_at=current_timestamp where id = #{id}
</update>
<delete id="delete" parameterType="int">
delete from users where id = #{id}
</delete>
<resultMap id="userMap" type="User">
<result property="createDate" column="created_at" />
<result property="updateDate" column="updated_at" />
</resultMap>
</mapper>
道:
public abstract class AbstractSimpleDaoImpl<T> extends SqlSessionDaoSupport implements IDao<T> {
@Override
public T query(int id) {
return getSqlSession().selectOne(getMapperNamespace() + ".selectById", id);
}
@Override
public List<T> list() {
return getSqlSession().selectList(getMapperNamespace() + ".selectAll");
}
@Override
public int add(T entity) {
return getSqlSession().insert(getMapperNamespace() + ".insert", entity);
}
@Override
public int update(T entity) {
return getSqlSession().update(getMapperNamespace() + ".update", entity);
}
@Override
public void delete(T entity) {
getSqlSession().delete(getMapperNamespace() + ".delete", entity);
}
protected abstract String getMapperNamespace();
}
用户道:
public class UserDao extends AbstractSimpleDaoImpl<User> {
private static String pack = "com.king.mapper.UserMapper";
@Override
protected String getMapperNamespace() {
return pack;
}
}
有效。但是我发现我的mybatis示例会引用mapper接口。
看来我必须在上面的示例中创建一个名为 UserMapper 的接口。
但我想知道是否有必要?我什么时候必须使用它?
顺便说一句,在我看来,我发现映射器接口所做的就像 dao 所做的一样。由于 dao 和 interface 可能有这么多同名的方法。