0

我是 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 可能有这么多同名的方法。

4

1 回答 1

0

您可以创建映射器接口 UserMapper 并避免在您的 Dao 对象上调用方法 getSqlSession()...。因此,使用映射器接口,您的 xml 配置保持不变,但您可以完全避免 Dao 对象。只需像这样定义接口:

  public interface UserMapper {

    public List<User> selectAll();

    public User selectById(@Param("id") int id);

    // rest is ommited
  }

方法的名称必须与映射器文件中的 select/update/insert/detele 的 id 匹配。就是这样。

于 2012-09-06T13:59:51.500 回答